Salt Edge PSD2 Compliance Logo

V1

Funds Check

This endpoints are responsible for creating payment orders on behalf of PSU via TPP interface. Process of payment creation starts once PSU fills a payment template form and submits the request. You can find below sequence diagrams represeting oauth payment creation, oauth payment creation using SCA and funds availability flows.

Funds Availability Flow Funds Availability Flow

Check

This endpoint is used to check availability of funds for a specific account. As a result, Connector should send a success or fail callback to Salt Edge PSD2 Compliance with result of the operation.

CURL

curl -i  \ 
 -H "Authorization: Bearer eyJhbGciOiJSUzI1NiJ9.eyJkYXRhIjp7ImN1cnJlbmN5X2NvZGUiOiJFVVIiLCJhY2NvdW50IjoiODQ1NzI0ODYiLCJzZXNzaW9uX3NlY3JldCI6ImVTU1c1ZEFWYWdib3o4S1h2NGc3IiwicHJvdmlkZXJfY29kZSI6ImRlbW9iYW5rIiwiYW1vdW50IjoiNDAuNzcifSwiZXhwIjoxNzM3MjQyMTM3LCJpc3MiOiJwcmlvcmEuc2FsdGVkZ2UuY29tIn0.oMthxoWSf3BIzXH3UsEDrRg-Vt5aFnAOU18mFconf0dB515mC_OnwVcBo97fN9NUcVdpenOKi6ec9g541CLnbUgSgnnFjjiWc3-DxV0gTV_i6X3OogcUSjdMxlgPsemhILtbo0-KmFrskPu1jrGbFlz4y8c3dab0nK-DgjICUdZSQXHzyM0YYisPLCb5DwbjD0rvUM-lJjRIXVxY3justsjoGj7cxgVzCmC5CjDTVxMpGLL7S8G-dhR7jNA9t2EB1gq6DjO_5cJdpVUzuGFXMETN4opwynGe7avssBLzFutgi1wnE7Ocrfs0oOLDIXaBprt4-9nM68uIJJ8AAuiHEw" \ 
 -H "Access-Token: e41d6d72e68723224cb6e25c2c99ddee95376d1b33e6522f2e36d4e8194fc84f71655993eabf6f020afa10fdbddd54f7d1a60ffbda7b90961045f977f7c450de" \ 
 -H "Accept: application/json" \ 
 -H "Content-Type: application/json" \ 
 -H "Client-Id: 216" \ 
 -X POST "https://your.connector.url/api/priora/v1/payments/check_funds"

Example of request parameters

{"data":{"currency_code":"EUR","account":"84572486","session_secret":"eSSW5dAVagboz8KXv4g7","provider_code":"demobank","amount":"40.77"},"exp":1574093209}
Request

POST https://your.connector.url/api/priora/v1/payments/check_funds

Headers
Header Type Description
Authorization string, required JSON Web Token containing payload, signed using RSA256 and application.private_key.
Access-Token string, required The token which is created by a connector as a result of successful authentication.
Accept string, required Media type that is acceptable for the response. Allowed values: application/json
Content-Type string, required The media type of the body of the request. Allowed values: application/json
Client-Id integer, required Client application identifier in Salt Edge PSD2 Compliance. Should be used to get public key for Authorization header validation.
Consent-Id integer, optional ID of the corresponding consent object as returned by an Account Information Consent Request.
Unpacked Request Authorization
exp
integer, required
The lifetime of the request in timestamp UTC format. Values greater than: Current time.
Response headers
Header Type Description
Retry-After integer, optional Amount of time in seconds after which Salt Edge PSD2 Compliance Solution resends the previously failed request.
Response

Upon successful request, 200 status code should be returned.


Related Errors
Class Code Description
UnknownCurrency 404 Unknown Currency code

Errors

Additional endpoints to be implemented on connector side to improve communication between Salt Edge PSD2 Compliance Solution and Connector.

Notify

This endpoint is responsible for receiving validation errors of responses which Connector sends to Salt Edge PSD2 Compliance Solution

CURL

curl -i  \ 
 -H "Authorization: Bearer eyJhbGciOiJSUzI1NiJ9.eyJkYXRhIjp7InJlcXVlc3QiOnsibWV0aG9kIjoiZGVsZXRlIiwidXJsIjoiaHR0cHM6Ly91c2VyLndpbGwuYmUvcmVkaXJlY3RlZC9oZXJlIiwiaGVhZGVycyI6e319LCJlcnJvciI6eyJlcnJvcl9tZXNzYWdlIjoic29tZXRoaW5nIHdlbnQgd3JvbmciLCJlcnJvcl9jbGFzcyI6IkludGVybmFsUHJvdmlkZXJFcnJvciJ9fSwiZXhwIjoxNzM3MjQyMTM3LCJpc3MiOiJwcmlvcmEuc2FsdGVkZ2UuY29tIn0.GHAOHwvhF2wa89kvE-TJb-N_IHI_StFJccOakQfvaGyxdWGjP1RSfCWNdV9Qps6tNtfMjGJf6MjlMzX5tC-MQhmYiV_OU1mi9KYcvOh_vzDnVcRgZDw3pZAxP-6tJ-2XWUl5Nj_Gfo7qHpXPedqlvOGn1GqAA6l2b8Iqc38o5Xj3FUY43F4WkY9ajRyyanJV6REDxToOFzoHNnPoHsSgjoi8rgcal4gXEtXAzoUNlz02nbfAKnfn7SiLyTRhbVQdMhvuM8fDo6ek7-nFT88tb6feKon5K-TkK_7EIGbde5yybYJCot9qaZVKPNp7oUe5MxDPIwOknIGpFF-iPoFbuA" \ 
 -H "Access-Token: b2077c5c020a5e262767aac63fdbc75fd64461afc660784fbc3451766f586bb4836e3405007c2caf497a1125ba58fb49be65b3c352285dea68328aded84e2f91" \ 
 -H "Accept: application/json" \ 
 -H "Content-Type: application/json" \ 
 -H "Client-Id: 685" \ 
 -X POST "https://your.connector.url/api/priora/v1/errors"

Example of request parameters

{"data":{"request":{"method":"delete","url":"https://user.will.be/redirected/here","headers":{}},"error":{"error_message":"something went wrong","error_class":"InternalProviderError"}},"exp":1574093209}
Request

POST https://your.connector.url/api/priora/v1/errors

Headers
Header Type Description
Authorization string, required JSON Web Token containing payload, signed using RSA256 and application.private_key.
Access-Token string, required The token which is created by a connector as a result of successful authentication.
Accept string, required Media type that is acceptable for the response. Allowed values: application/json
Content-Type string, required The media type of the body of the request. Allowed values: application/json
Client-Id integer, required Client application identifier in Salt Edge PSD2 Compliance. Should be used to get public key for Authorization header validation.
Consent-Id integer, optional ID of the corresponding consent object as returned by an Account Information Consent Request.
Unpacked Request Authorization
exp
integer, required
The lifetime of the request in timestamp UTC format. Values greater than: Current time.
Response headers
Header Type Description
Retry-After integer, optional Amount of time in seconds after which Salt Edge PSD2 Compliance Solution resends the previously failed request.
Response

Upon successful request, 200 status code should be returned.


Funds Availability

Success

Success callback should be used when all verification procedures have passed and connector can tell wether funds are available or not for indicated account.

CURL

curl -i  \ 
 -H "Authorization: Bearer eyJhbGciOiJSUzI1NiJ9.eyJkYXRhIjp7InNlc3Npb25fc2VjcmV0IjoiUnBBb0hQbUg3RHdSTExMeWNqREwiLCJmdW5kc19hdmFpbGFibGUiOnRydWV9LCJleHAiOjE3MzcyNDIxMzcsImlzcyI6InByaW9yYS5zYWx0ZWRnZS5jb20ifQ.P7pP_vEKCQIacC5m7avvZKPT6UpbJP2kF_yjDl54KLBE7Z2rxs4wiEtuItCmB6ZZZ1nQTz_zj5eLxNluI9M1QwjCz0ZaYMYHggyjcf3BL5K2G3t_i5OMedzXG60n8mq4yoal_xXjsX-cSzCc7aNuAG7TFGfd3ujlvG5pureHsE471CAyPGiGCdEpLEG75ntq2WA3T8Dz2YM3GyO2tToMkuj-MYSiH67vQkuXY6YxxKIqKLDzX-t4bqF_IsFlwwGCnHOwqN13SsLla8QQ2woa3d4gNXdcXDIGBm1MJM_--U9LbOX7oM5K8Soh5rK8Y39ws41H-kaTfm_6szRwVC97lA" \ 
 -H "App-Id: tmseeTcEhV-x1t2ZSIOQ4Q" \ 
 -H "App-Secret: wARHNQnMuIhcv3Z21ot-1g" \ 
 -X POST "/api/connectors/v1/funds_availability/success"

Example of request parameters

{"data":{"session_secret":"RpAoHPmH7DwRLLLycjDL","funds_available":true},"exp":1574093208}

Example of response

{"data":{},"meta":{"time":"2019-11-18T16:04:48.634Z"}}
Request

POST /api/connectors/v1/funds_availability/success

Headers
Header Type Description
Authorization string, required JSON Web Token containing payload, signed using RSA256 and application.private_key. Can raise: AuthorizationMissing
App-Id string, required Provider's app_id from connection details tab. Can raise: ProviderNotFound, ProviderDisabled, ConfigurationError
App-Secret string, required Provider's app_secret from connection details tab.
Unpacked Request Authorization
exp
integer, required
The lifetime of the request in timestamp UTC format. Values greater than: Current time.
Response

Upon successful request, 200 status code will be returned. See ‘Related Errors’ table for other possibilities.


data
hash, optional
Wrapper for the data.
Related Errors
Class Code Description
ConfigurationError 400 Missing configurations in dashboard.
AuthorizationMissing 401 Authorization header is missing.
SessionNotFound 404 Session specified in request does not exist or cannot be retrieved.
ProviderNotFound 404 Provider specified in request does not exist or cannot be retrieved.
ProviderDisabled 406 Cooperation with specified Provider is impossible.

Fail

Fail callback should be used when account could not be found or currency_code is not supported.

CURL

curl -i  \ 
 -H "Authorization: Bearer eyJhbGciOiJSUzI1NiJ9.eyJkYXRhIjp7InNlc3Npb25fc2VjcmV0IjoieXl6YnlMaFpTYU05RFpBWF9zVG8iLCJlcnJvcl9jbGFzcyI6IkludGVybmFsUHJvdmlkZXJFcnJvciIsImVycm9yX21lc3NhZ2UiOiJJbnRlcm5hbCBlcnJvciIsImV4dHJhIjp7fX0sImV4cCI6MTczNzI0MjEzNywiaXNzIjoicHJpb3JhLnNhbHRlZGdlLmNvbSJ9.ZGyU7FXQQJmF8MJ3FYzVliCPcvaA-x2EqsfE-MaD18cKGQOWKi95jK6uLbQtWzycDzETZw5XSXEfGCdQoH7Xig7u4e-oy4UeQWZFUG5XDCwDJNjaAX6JqyKA5Eb_TvL-JZPCZxhC4ANv7rfZPA8pW4l3gsh0S9qlJVXhghIupxg08YxrbDDRAzZ3sN1v8pQo3ITnuWBLzOhR6pC8bguCK_kQUkzHGGPurf2ExrX-p1917nI6TNWGWpUF6o8WGiQep2vf1Ki2lO5QKJBF4JHkTeBDvMhira91UWeo6M5Kb0Ejr-PmQf484QkeVi8PG83GZrzQ_BzzJ-mvE_bIMoutgQ" \ 
 -H "App-Id: 7K6q6MmnPgOlJbkuFk1Cgg" \ 
 -H "App-Secret: hET3DChd1v0WVZHTbrS7xw" \ 
 -X POST "/api/connectors/v1/funds_availability/fail"

Example of request parameters

{"data":{"session_secret":"yyzbyLhZSaM9DZAX_sTo","error_class":"InternalProviderError","error_message":"Internal error","extra":{}},"exp":1574093208}

Example of response

{"data":{},"meta":{"time":"2019-11-18T16:04:48.567Z"}}
Request

POST /api/connectors/v1/funds_availability/fail

Headers
Header Type Description
Authorization string, required JSON Web Token containing payload, signed using RSA256 and application.private_key. Can raise: AuthorizationMissing
App-Id string, required Provider's app_id from connection details tab. Can raise: ProviderNotFound, ProviderDisabled, ConfigurationError
App-Secret string, required Provider's app_secret from connection details tab.
Unpacked Request Authorization
exp
integer, required
The lifetime of the request in timestamp UTC format. Values greater than: Current time.
Response

Upon successful request, 200 status code will be returned. See ‘Related Errors’ table for other possibilities.


data
hash, optional
Wrapper for the data.
Related Errors
Class Code Description
ConfigurationError 400 Missing configurations in dashboard.
AuthorizationMissing 401 Authorization header is missing.
SessionNotFound 404 Session specified in request does not exist or cannot be retrieved.
ProviderNotFound 404 Provider specified in request does not exist or cannot be retrieved.
ProviderDisabled 406 Cooperation with specified Provider is impossible.