Skip to main content

API Keys

API keys are used to authenticate with the PublicSquare API. All API keys contain one or more permissions which will provide ability to manage your account, collect payment methods, and process payments.

Key Types

There are three API key types, which enable different levels of access to the PublicSquare API.

TypeDescription
publishableA publishable key an auto-generated, non-sensitive API key which can be used in your mobile or web application to collect payment methods. Publishable keys only contain the payment-method:capture permission. A single publishable key is generated when your account is created and cannot be edited or removed, but can have the key regenerated.
secretA secret key is an auto-generated, sensitive API key type which contains all permissions to fully manage your account, collect payment methods, and process transactions. Secret keys are the most permissable API key in an account. A single publishable key is generated when your account is created and cannot be edited or removed, but can have the key regenerated.
restrictedA restricted key enables granting granular access to your account. When a restricted key is created, it contains one or more permissions which defines what endpoints can be accessed. You can create one or more restricted keys per account for various business uses.

Permissions

Permissions enable granular access to PublicSquare API endpoints. A publishable API key only has the payment-method:capture permission, however a secret API key has access to all permissions. Restricted API keys can be created to provide limited access to the API for specific use cases.

TypeDescription
account:readAllows reading account details and settings.
account:writeAllows updating account details and settings.
account:deleteAllows deleting your account. This is a permanent action.
account-member:readAllows reading a list of all account members.
account-member:writeAllows updating the role for an existing account member.
account-member:deleteAllows removing a member from the account.
account-invitation:readAllows reading a list of account member invitations.
account-invitation:writeAllows inviting new members to the account or resending the invitation.
account-invitation:deleteAllows deleting member invitations from the account.
api-key:readAllows reading API keys and revealing the key used for authentication.
api-key:writeAllows creating new API keys, updating permissions for existing API keys, and regenerating the API key.
api-key:deleteAllows deleting API keys.
business:readAllows reading business details used for account onboarding and underwriting.
business:writeAllows saving business details used for account onboarding and underwriting.
connection:readAllows reading a list of merchant and seller connections used for payment transfers.
connection:writeAllows creating new seller connection invitations.
connection:deleteAllows removing merchant and seller connections. When removed, payment transfers will no longer be permitted between the accounts.
customer:readAllows reading customer information.
customer:writeAllows creating and updating customer information.
customer:deleteAllows deleting customers in the account.
event:readAllows reading all generated events for the account such as transaction, connection, and onboarding events.
payment-method:captureAllows capturing payment methods with a publishable API key.
payment-method:readAllows reading payment method details.
payment-method:writeAllows creating payment methods with a secret or restricted API key.
payment-method:deleteAllows removing a payment method. This will not remove any payment method details used for payments, payouts, and refunds.
payment:readAllows reading payments.
payment:writeAllows creating and updating payments.
payout:readAllows reading payouts.
payout:writeAllows creating and updating payouts.
refund:readAllows reading refunds.
refund:writeAllows creating and updating refunds.
settlement:readAllows reading settlements and associated transactions.
transaction:readAllows reading transactions such as payments, refunds, payouts and settlements.
transfer:readAllows reading payment transfers.
transfer:writeAllows creating payment transfers.
webhook:readAllows reading webhook details and events sent to the registered webhook URL.
webhook:writeAllows creating or updating webhooks.
webhook:deleteAllows removing webhooks.