Retrieve a capability
Retrieve a specific capability that an account has requested. Read our capabilities guide to learn more.
To access this endpoint using an access token
you'll need to specify the /accounts/{accountID}/capabilities.read scope.
GET
/accounts/{accountID}/capabilities/{capabilityID}
curl -X GET "https://api.moov.io/accounts/{accountID}/capabilities/{capabilityID}" \
-H "Authorization: Bearer {token}" \
-H "X-Moov-Version: v2026.01.00"mc, _ := moov.NewClient()
var accountID string
var capabilityID = moov.CapabilityName_Transfers
mc.GetCapability(ctx, accountID, capabilityID)
import { Moov } from "@moovio/sdk";
const moov = new Moov({
security: {
username: "",
password: "",
},
});
async function run() {
const result = await moov.capabilities.get({
accountID: "c1697ea6-c984-4ba1-9b81-93e5e18660af",
capabilityID: "send-funds",
});
console.log(result);
}
run();declare(strict_types=1);
require 'vendor/autoload.php';
use Moov\MoovPhp;
use Moov\MoovPhp\Models\Components;
$sdk = MoovPhp\Moov::builder()
->setSecurity(
new Components\Security(
username: '',
password: '',
)
)
->build();
$response = $sdk->capabilities->get(
accountID: 'c1697ea6-c984-4ba1-9b81-93e5e18660af',
capabilityID: Components\CapabilityID::SendFunds
);
if ($response->capability !== null) {
// handle response
}package hello.world;
import io.moov.sdk.Moov;
import io.moov.sdk.models.components.CapabilityID;
import io.moov.sdk.models.components.Security;
import io.moov.sdk.models.operations.GetCapabilityResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws Exception {
Moov sdk = Moov.builder()
.security(Security.builder()
.username("")
.password("")
.build())
.build();
GetCapabilityResponse res = sdk.capabilities().get()
.accountID("c1697ea6-c984-4ba1-9b81-93e5e18660af")
.capabilityID(CapabilityID.SEND_FUNDS)
.call();
if (res.capability().isPresent()) {
System.out.println(res.capability().get());
}
}
}from moovio_sdk import Moov
from moovio_sdk.models import components
with Moov(
security=components.Security(
username="",
password="",
),
) as moov:
res = moov.capabilities.get(account_id="c1697ea6-c984-4ba1-9b81-93e5e18660af", capability_id=components.CapabilityID.SEND_FUNDS)
# Handle response
print(res)require 'moov_ruby'
Models = ::Moov::Models
s = ::Moov::Client.new(
security: Models::Components::Security.new(
username: '',
password: ''
)
)
res = s.capabilities.get(account_id: 'c1697ea6-c984-4ba1-9b81-93e5e18660af', capability_id: Models::Components::CapabilityID::SEND_FUNDS_ACH)
unless res.capability.nil?
# handle response
endusing Moov.Sdk;
using Moov.Sdk.Models.Components;
var sdk = new MoovClient(security: new Security() {
Username = "",
Password = "",
});
var res = await sdk.Capabilities.GetAsync(
accountID: "c1697ea6-c984-4ba1-9b81-93e5e18660af",
capabilityID: CapabilityID.SendFundsRtp
);
// handle responseThe request completed successfully.
{
"capability": "transfers",
"accountID": "string",
"status": "enabled",
"requirements": {
"currentlyDue": [
"account.tos-acceptance"
],
"errors": [
{
"requirement": "account.tos-acceptance",
"errorCode": "invalid-value"
}
]
},
"disabledReason": "string",
"createdOn": "2019-08-24T14:15:22Z",
"updatedOn": "2019-08-24T14:15:22Z",
"disabledOn": "2019-08-24T14:15:22Z"
}Response headers
x-request-id
string
required
A unique identifier used to trace requests.
The request contained missing or expired authentication.
Response headers
x-request-id
string
required
A unique identifier used to trace requests.
The user is not authorized to make the request.
Response headers
x-request-id
string
required
A unique identifier used to trace requests.
The requested resource was not found.
Response headers
x-request-id
string
required
A unique identifier used to trace requests.
Request was refused due to rate limiting.
Response headers
x-request-id
string
required
A unique identifier used to trace requests.
The request failed due to an unexpected error.
Response headers
x-request-id
string
required
A unique identifier used to trace requests.
The request failed because a downstream service failed to respond.
Response headers
x-request-id
string
required
A unique identifier used to trace requests.
Headers
X-Moov-Version
string
Set this header to v2026.01.00 to use the API described in this specification. When omitted, the server defaults to v2024.01.00, which may not match the behavior documented here.
Possible values:
v2026.01.00
Path parameters
accountID
string
required
capabilityID
string
required
Possible values:
transfers,
send-funds,
send-funds.push-to-card,
money-transfer.push-to-card,
send-funds.ach,
send-funds.rtp,
send-funds.instant-bank,
collect-funds,
collect-funds.card-payments,
money-transfer.pull-from-card,
collect-funds.ach,
wallet,
wallet.balance,
card-issuing,
production-app,
platform.production-app,
platform.wallet-transfers
Response
accountID
string
required
capability
string<enum>
required
Moov account capabilities.
The production-app, platform.production-app, and / or platform.wallet-transfers capabilities might appear in your list. These are read-only capabilities that Moov requests and uses for account verification purposes. These capabilities remains active with your account and require no additional action.
Possible values:
transfers,
send-funds,
send-funds.push-to-card,
money-transfer.push-to-card,
send-funds.ach,
send-funds.rtp,
send-funds.instant-bank,
collect-funds,
collect-funds.card-payments,
money-transfer.pull-from-card,
collect-funds.ach,
wallet,
wallet.balance,
card-issuing,
platform.production-app,
platform.wallet-transfers
createdOn
string<date-time>
required
status
string<enum>
required
The status of the capability requested for an account.
Possible values:
enabled,
disabled,
pending,
in-review
updatedOn
string<date-time>
required
disabledOn
string<date-time>
disabledReason
string
requirements
object
Represents individual and business data necessary to facilitate the enabling of a capability for an account.
Show child attributes
currentlyDue
array<string>
Possible values:
account.tos-acceptance,
individual.mobile,
individual.email,
individual.email-or-mobile,
individual.firstname,
individual.lastname,
individual.address,
individual.ssn-last4,
individual.ssn,
individual.birthdate,
business.legalname,
business.description-or-website,
business.entity-type,
business.business-type,
business.dba,
business.ein,
business.address,
business.phone,
business.admins,
business.controllers,
business.owners,
business.classification,
business.industry-code-mcc,
business.industry,
business.indicate-owners-provided,
business.average-transaction-size,
business.max-transaction-size,
business.average-monthly-transaction-volume,
business.volume-by-customer-type,
business.card-volume-distribution,
business.fulfillment,
business.description,
business.underwriting-documents-tier-one,
bank-accounts.name,
bank-accounts.routing-number,
bank-accounts.account-number,
document.business.verification,
document.individual.tin,
document.individual.verification,
document.representative.{rep-uuid}.tin,
document.representative.{rep-uuid}.verification,
representative.{rep-uuid}.mobile,
representative.{rep-uuid}.email,
representative.{rep-uuid}.email-or-mobile,
representative.{rep-uuid}.firstname,
representative.{rep-uuid}.lastname,
representative.{rep-uuid}.address,
representative.{rep-uuid}.ssn-last4,
representative.{rep-uuid}.ssn,
representative.{rep-uuid}.birthdate,
representative.{rep-uuid}.job-title,
representative.{rep-uuid}.is-controller,
representative.{rep-uuid}.is-owner,
representative.{rep-uuid}.ownership,
document.{doc-uuid},
underwriting.businessPresence,
underwriting.geographicReach,
underwriting.volumeShareByCustomerType,
underwriting.pendingLitigation,
underwriting.documents.processingStatementsPast3Months,
underwriting.collectFunds.cardPayments.cardAcceptanceMethods,
underwriting.collectFunds.cardPayments.currentlyAcceptsCards,
underwriting.collectFunds.cardPayments.estimatedActivity.averageTransactionAmount,
underwriting.collectFunds.cardPayments.estimatedActivity.maximumTransactionAmount,
underwriting.collectFunds.cardPayments.estimatedActivity.monthlyVolumeRange,
underwriting.collectFunds.cardPayments.fulfillment,
underwriting.collectFunds.cardPayments.refundPolicy,
underwriting.collectFunds.ach.cardAcceptanceMethods,
underwriting.collectFunds.ach.currentlyAcceptsCards,
underwriting.collectFunds.ach.estimatedActivity.averageTransactionAmount,
underwriting.collectFunds.ach.estimatedActivity.maximumTransactionAmount,
underwriting.collectFunds.ach.estimatedActivity.monthlyVolumeRange,
underwriting.collectFunds.ach.fulfillment,
underwriting.collectFunds.ach.refundPolicy,
underwriting.sendFunds.ach.cardAcceptanceMethods,
underwriting.sendFunds.ach.currentlyAcceptsCards,
underwriting.sendFunds.ach.estimatedActivity.averageTransactionAmount,
underwriting.sendFunds.ach.estimatedActivity.maximumTransactionAmount,
underwriting.sendFunds.ach.estimatedActivity.monthlyVolumeRange,
underwriting.sendFunds.ach.fulfillment,
underwriting.sendFunds.ach.refundPolicy,
underwriting.sendFunds.rtp.cardAcceptanceMethods,
underwriting.sendFunds.rtp.currentlyAcceptsCards,
underwriting.sendFunds.rtp.estimatedActivity.averageTransactionAmount,
underwriting.sendFunds.rtp.estimatedActivity.maximumTransactionAmount,
underwriting.sendFunds.rtp.estimatedActivity.monthlyVolumeRange,
underwriting.sendFunds.rtp.fulfillment,
underwriting.sendFunds.rtp.refundPolicy,
underwriting.sendFunds.pushToCard.cardAcceptanceMethods,
underwriting.sendFunds.pushToCard.currentlyAcceptsCards,
underwriting.sendFunds.pushToCard.estimatedActivity.averageTransactionAmount,
underwriting.sendFunds.pushToCard.estimatedActivity.maximumTransactionAmount,
underwriting.sendFunds.pushToCard.estimatedActivity.monthlyVolumeRange,
underwriting.sendFunds.pushToCard.fulfillment,
underwriting.sendFunds.pushToCard.refundPolicy,
underwriting.moneyTransfer.pullFromCard.cardAcceptanceMethods,
underwriting.moneyTransfer.pullFromCard.currentlyAcceptsCards,
underwriting.moneyTransfer.pullFromCard.estimatedActivity.averageTransactionAmount,
underwriting.moneyTransfer.pullFromCard.estimatedActivity.maximumTransactionAmount,
underwriting.moneyTransfer.pullFromCard.estimatedActivity.monthlyVolumeRange,
underwriting.moneyTransfer.pullFromCard.fulfillment,
underwriting.moneyTransfer.pullFromCard.refundPolicy,
underwriting.moneyTransfer.pushToCard.cardAcceptanceMethods,
underwriting.moneyTransfer.pushToCard.currentlyAcceptsCards,
underwriting.moneyTransfer.pushToCard.estimatedActivity.averageTransactionAmount,
underwriting.moneyTransfer.pushToCard.estimatedActivity.maximumTransactionAmount,
underwriting.moneyTransfer.pushToCard.estimatedActivity.monthlyVolumeRange,
underwriting.moneyTransfer.pushToCard.fulfillment,
underwriting.moneyTransfer.pushToCard.refundPolicy
errors
array<object>
Show child attributes
errorCode
string<enum>
Possible values:
invalid-value,
failed-automatic-verification,
failed-other,
invalid-address,
address-restricted,
tax-id-mismatch,
document-id-mismatch,
document-date-of-birth-mismatch,
document-name-mismatch,
document-address.mismatch,
document-number-mismatch,
document-incomplete,
document-failed-risk,
document-illegible,
document-unsupported,
document-not-uploaded,
document-corrupt,
document-expired
requirement
string<enum>
The unique ID of what the requirement is asking to be filled out.
Possible values:
account.tos-acceptance,
individual.mobile,
individual.email,
individual.email-or-mobile,
individual.firstname,
individual.lastname,
individual.address,
individual.ssn-last4,
individual.ssn,
individual.birthdate,
business.legalname,
business.description-or-website,
business.entity-type,
business.business-type,
business.dba,
business.ein,
business.address,
business.phone,
business.admins,
business.controllers,
business.owners,
business.classification,
business.industry-code-mcc,
business.industry,
business.indicate-owners-provided,
business.average-transaction-size,
business.max-transaction-size,
business.average-monthly-transaction-volume,
business.volume-by-customer-type,
business.card-volume-distribution,
business.fulfillment,
business.description,
business.underwriting-documents-tier-one,
bank-accounts.name,
bank-accounts.routing-number,
bank-accounts.account-number,
document.business.verification,
document.individual.tin,
document.individual.verification,
document.representative.{rep-uuid}.tin,
document.representative.{rep-uuid}.verification,
representative.{rep-uuid}.mobile,
representative.{rep-uuid}.email,
representative.{rep-uuid}.email-or-mobile,
representative.{rep-uuid}.firstname,
representative.{rep-uuid}.lastname,
representative.{rep-uuid}.address,
representative.{rep-uuid}.ssn-last4,
representative.{rep-uuid}.ssn,
representative.{rep-uuid}.birthdate,
representative.{rep-uuid}.job-title,
representative.{rep-uuid}.is-controller,
representative.{rep-uuid}.is-owner,
representative.{rep-uuid}.ownership,
document.{doc-uuid},
underwriting.businessPresence,
underwriting.geographicReach,
underwriting.volumeShareByCustomerType,
underwriting.pendingLitigation,
underwriting.documents.processingStatementsPast3Months,
underwriting.collectFunds.cardPayments.cardAcceptanceMethods,
underwriting.collectFunds.cardPayments.currentlyAcceptsCards,
underwriting.collectFunds.cardPayments.estimatedActivity.averageTransactionAmount,
underwriting.collectFunds.cardPayments.estimatedActivity.maximumTransactionAmount,
underwriting.collectFunds.cardPayments.estimatedActivity.monthlyVolumeRange,
underwriting.collectFunds.cardPayments.fulfillment,
underwriting.collectFunds.cardPayments.refundPolicy,
underwriting.collectFunds.ach.cardAcceptanceMethods,
underwriting.collectFunds.ach.currentlyAcceptsCards,
underwriting.collectFunds.ach.estimatedActivity.averageTransactionAmount,
underwriting.collectFunds.ach.estimatedActivity.maximumTransactionAmount,
underwriting.collectFunds.ach.estimatedActivity.monthlyVolumeRange,
underwriting.collectFunds.ach.fulfillment,
underwriting.collectFunds.ach.refundPolicy,
underwriting.sendFunds.ach.cardAcceptanceMethods,
underwriting.sendFunds.ach.currentlyAcceptsCards,
underwriting.sendFunds.ach.estimatedActivity.averageTransactionAmount,
underwriting.sendFunds.ach.estimatedActivity.maximumTransactionAmount,
underwriting.sendFunds.ach.estimatedActivity.monthlyVolumeRange,
underwriting.sendFunds.ach.fulfillment,
underwriting.sendFunds.ach.refundPolicy,
underwriting.sendFunds.rtp.cardAcceptanceMethods,
underwriting.sendFunds.rtp.currentlyAcceptsCards,
underwriting.sendFunds.rtp.estimatedActivity.averageTransactionAmount,
underwriting.sendFunds.rtp.estimatedActivity.maximumTransactionAmount,
underwriting.sendFunds.rtp.estimatedActivity.monthlyVolumeRange,
underwriting.sendFunds.rtp.fulfillment,
underwriting.sendFunds.rtp.refundPolicy,
underwriting.sendFunds.pushToCard.cardAcceptanceMethods,
underwriting.sendFunds.pushToCard.currentlyAcceptsCards,
underwriting.sendFunds.pushToCard.estimatedActivity.averageTransactionAmount,
underwriting.sendFunds.pushToCard.estimatedActivity.maximumTransactionAmount,
underwriting.sendFunds.pushToCard.estimatedActivity.monthlyVolumeRange,
underwriting.sendFunds.pushToCard.fulfillment,
underwriting.sendFunds.pushToCard.refundPolicy,
underwriting.moneyTransfer.pullFromCard.cardAcceptanceMethods,
underwriting.moneyTransfer.pullFromCard.currentlyAcceptsCards,
underwriting.moneyTransfer.pullFromCard.estimatedActivity.averageTransactionAmount,
underwriting.moneyTransfer.pullFromCard.estimatedActivity.maximumTransactionAmount,
underwriting.moneyTransfer.pullFromCard.estimatedActivity.monthlyVolumeRange,
underwriting.moneyTransfer.pullFromCard.fulfillment,
underwriting.moneyTransfer.pullFromCard.refundPolicy,
underwriting.moneyTransfer.pushToCard.cardAcceptanceMethods,
underwriting.moneyTransfer.pushToCard.currentlyAcceptsCards,
underwriting.moneyTransfer.pushToCard.estimatedActivity.averageTransactionAmount,
underwriting.moneyTransfer.pushToCard.estimatedActivity.maximumTransactionAmount,
underwriting.moneyTransfer.pushToCard.estimatedActivity.monthlyVolumeRange,
underwriting.moneyTransfer.pushToCard.fulfillment,
underwriting.moneyTransfer.pushToCard.refundPolicy