I'd recommend switching away from Rocket if you can. It is not very actively maintained and Axum has become the better choice.
Rust
Welcome to the Rust community! This is a place to discuss about the Rust programming language.
Wormhole
Credits
- The icon is a modified version of the official rust logo (changing the colors to a gradient and black background)
Thanks for the update, I wrote using rocket a few years ago so I figured everyone was still using that!
If you are looking to do something like Github's Personal Access Tokens (PAT) then it is easiest to just think about it like a password:
- Create a high entropy (secure) string
- Store the hash of the string in a database table
- Store the permissions and other metadata with the PAT's hash
- Validate the PAT (permissions, revoke status, etc) on each request to the server
Storing the hash of the token, like you do with passwords, is a good practice in case your db is ever compromised as it wont leave the tokens accessible and reusable without a lot of effort.
Don't forget to add some salt to that hash.
why would you need to salt long random strings?
also if you salt them you have to have an id too so you can look up who's api key it is. otherwise you can just look up the key hash to get everything
why would you need to salt long random strings?
also if you salt them you have to have an id too so you can look up who's api key it is. otherwise you can just look up the key hash to get everything
That depends on scale. For our IOT device, we just had a private key on the device and gave the customer an encrypted packet that had their privileges spelled out, and set a field on their user account appropriately. That wouldn't be secure at scale, but it worked really well for our B2B app.
If I were doing something at scale, I'd follow suggestions from others here.
I mean, that sounds sorta like JWTs which are used commonly enough for this type of thing
I guess. Our use case was a bit different in that it carried which features they had access to, not just that they had some access. You could probably do that with a JWT as well, but we just issued them an encrypted upgrade file that matched the serial of their device and granted all usersln that device access to the feature.
That was simple enough for us.