This API is responsible for authenticating users and interacting with the user database.
- Ruby version = 2.7.1
- Authentication: Devise & JWT
- Database = Postgresql
http://a87713a1fd4b64cd4b788e8a1592de07-1206905140.us-west-2.elb.amazonaws.com
- Run
bundle install
in root directory - Start server with
rails s
- Default command runs server on
localhost:3000
- Default command runs server on
/users
- Create a new User
- Example Payload:
{ "username":"[email protected]", "password":"password" }
- Example Successful Return:
{ "user": { "id": 3, "username": "[email protected]", "password_digest": "$2a$12$08p1thhSwbRpyJiiQi./uu.fUl2L7OPEpz9JwscvL4ueH0LJqCazO", "device_key": null, "created_at": "2020-10-15T06:09:07.237Z", "updated_at": "2020-10-15T06:09:07.237Z" }, "auth": { "accessToken": "eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjozLCJ0eXBlIjoiYWNjZXNzIiwic2FsdCI6IlxcVG9qPWFOZCJ9.LhrFlPQjmhOMZRks2oP4jIC9O5gKltBwsYs-Vy39Bic", "accessTokenExpiration": "2020-10-15T06:24:07.245Z", "refreshToken": "eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjozLCJ0eXBlIjoicmVmcmVzaCIsInNhbHQiOiJma191MEk4SCJ9.haRij-MTblMtZIa9quxorRsiz_oT10yiMkp8w4aoKEI", "refreshTokenExpiration": "2020-11-14T06:09:07.253Z" } }
/login
- Login an existing user
- Example Payload:
{ "username":"exampleUser", "password":"examplePassword" }
- Example Successful Return:
{ "user": { "id": 3, "username": "[email protected]", "password_digest": "$2a$12$08p1thhSwbRpyJiiQi./uu.fUl2L7OPEpz9JwscvL4ueH0LJqCazO", "device_key": null, "created_at": "2020-10-15T06:09:07.237Z", "updated_at": "2020-10-15T06:09:07.237Z" }, "auth": { "accessToken": "eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjozLCJ0eXBlIjoiYWNjZXNzIiwic2FsdCI6IlxcVG9qPWFOZCJ9.LhrFlPQjmhOMZRks2oP4jIC9O5gKltBwsYs-Vy39Bic", "accessTokenExpiration": "2020-10-15T06:24:07.245Z", "refreshToken": "eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjozLCJ0eXBlIjoicmVmcmVzaCIsInNhbHQiOiJma191MEk4SCJ9.haRij-MTblMtZIa9quxorRsiz_oT10yiMkp8w4aoKEI", "refreshTokenExpiration": "2020-11-14T06:09:07.253Z" } }
/refresh
- Refreshes a users refresh and access tokens
- Example Payload:
{ "refreshToken":"eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoyfQ.68NcogyO1TlhZSp7ZzrgcaxSxTw6tedbiw-zuAUbubg" }
- Example Successful Return:
{ "status": "Refreshed Tokens", "auth": { "accessToken": "eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjozLCJ0eXBlIjoiYWNjZXNzIiwic2FsdCI6IlxcVG9qPWFOZCJ9.LhrFlPQjmhOMZRks2oP4jIC9O5gKltBwsYs-Vy39Bic", "accessTokenExpiration": "2020-10-15T06:24:07.245Z", "refreshToken": "eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjozLCJ0eXBlIjoicmVmcmVzaCIsInNhbHQiOiJma191MEk4SCJ9.haRij-MTblMtZIa9quxorRsiz_oT10yiMkp8w4aoKEI", "refreshTokenExpiration": "2020-11-14T06:09:07.253Z" } }
/logout
- Logout a user
- Example Payload:
{ "accessToken":"eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoyfQ.68NcogyO1TlhZSp7ZzrgcaxSxTw6tedbiw-zuAUbubg" }
- Example Successful Return:
{ "status": "User was succesfully logged out" }
/delete
- Delete a user
- Example Payload:
{ "accessToken":"eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoyfQ.68NcogyO1TlhZSp7ZzrgcaxSxTw6tedbiw-zuAUbubg", "refreshToken":"rt4hbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoyfQ.58NcogyO1TlhZSp7dzrgcaxwxTw6tedbww-zuAUbrbg" }
- Example Successful Return:
{ "status": "User was succesfully deleted" }
/device_key
- Update a users push notification device key
- Example Payload:
{ "accessToken":"eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoyfQ.68NcogyO1TlhZSp7ZzrgcaxSxTw6tedbiw-zuAUbubg", "deviceKey":"testKey" }
- Example Successful Return:
{ "status": "Device Key Succesfully Posted" }
/device_keys
- Returns an array of all User device tokens
- Example Payload:
{ "accessToken":"eyJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoyfQ.68NcogyO1TlhZSp7ZzrgcaxSxTw6tedbiw-zuAUbubg" }
- Example Successful Return:
{ "device_keys": [ "730400683bbf7ab482ab8c5e36c671fd1a151a58f170cd028a243b189ff61ad7", "fSAwLeogRrmjwHpUd6siQE:APA91bGi7leNgGinbwgu0tE3DZrelOCpxEW1woxWODTz9ldR9WKyAAXz0AmLrbjjYxH6oyaDgmJ9JiTicWo12mekYyXoDbY3ZR08cpXlyVzzEgQQAxCMSu0Ttny81Ki-ovf70zE0Qrcp" ] }