Skip to content

Latest commit

 

History

History
124 lines (104 loc) · 2.52 KB

README.md

File metadata and controls

124 lines (104 loc) · 2.52 KB

payments-sample

Rest API for simple prepaid card

1. How to start the application ?

It is simple just execute mvn spring-boot:run

2. Do I need a database to run it ?

No by default it uses in-memorry database but also it is easy just to change it in application.properties if you want the tables to created in real one.

3. How to use the API ?

User create

curl -i -X POST \ -H "Content-Type:application/json" \ -d \ '{ "username":"[email protected]", "password":"password" }' \ 'http://localhost:8080/users'

User authorize

curl -i -X POST \ -H "Content-Type:application/json" \ -d \ '{ "username":"[email protected]", "password":"password" }' \ 'http://localhost:8080/authorize'

Card create

curl -i -X POST \ -H "Content-Type:application/json" \ -H "Authorization:Bearer <TOKEN>" \ -d \ '{ "currency":"GBP", "amount":5.5, "description":"Coffee" }' \ 'http://localhost:8080/payments/'

Card topup

curl -i -X POST \ -H "Content-Type:application/json" \ -H "Authorization:Bearer <TOKEN>" \ -d \ '{ "currency":"GBP", "amount":15 }' \ 'http://localhost:8080/cards/<CARD_UID>/topup'

Card balance

curl -i -X GET \ -H "Authorization:Bearer <TOKEN>" \ 'http://localhost:8080/cards/<CARD_ID>/balance'

Cards list

curl -i -X GET \ -H "Authorization:Bearer <TOKEN>" \ 'http://localhost:8080/cards'

Payment create

curl -i -X POST \ -H "Content-Type:application/json" \ -H "Authorization:Bearer <TOKEN>" \ -d \ '{ "currency":"GBP", "amount":5.5, "description":"Coffee" }' \ 'http://localhost:8080/payments/'

Payment authorize

curl -i -X POST \ -H "Content-Type:application/json" \ -H "Authorization:Bearer <TOKEN>" \ -d \ '{ "card":"<CARD_UID>" }' \ 'http://localhost:8080/payments/<PAYMENT_UID>/authorize'

Payment capture

curl -i -X POST \ -H "Content-Type:application/json" \ -H "Authorization:Bearer <TOKEN>" \ -d \ '{ "card":"<CARD_UID>", "amount":"2" }' \ 'http://localhost:8080/payments/<PAYMENT_UID>/capture'

Payment reverse

curl -i -X POST \ -H "Content-Type:application/json" \ -H "Authorization:Bearer <TOKEN>" \ -d \ '{ "card":"<CARD_UID>", "amount":"1.5" }' \ 'http://localhost:8080/payments/<PAYMENT_UID>/reverse'

Payment Refund

curl -i -X POST \ -H "Content-Type:application/json" \ -H "Authorization:Bearer <TOKEN>" \ -d \ '{ "card":"<CARD_UID>", "amount":"2.0" }' \ 'http://localhost:8080/payments/<PAYMENT_UID>/refund'