This demo showcases how to use loyalty tokens using the idea of NFT based implementation of OAuth 2.0. This demo shows an authentication NFT minted by an issuer, delivered to a client wallet and then a protected resource granting and denying access to wallets based on whether they have the correct NFT.
This project gives uses the Plutus Platform starter project as the template.
Please refer to Setting up section of the plutus starter project.
With the PAB we can serve and interact with contracts over a web API. You can read more about the PAB here: PAB Architecture.
Here, the PAB is configured with two contracts, AuthNFTIssuer
and ProtectedResource
contracts under /src
folder.
Here's an example of running and interacting with this contract via the API. For this it will help if you have jq
installed.
- Build the PAB executable:
cabal build plutus-starter-pab
- Run the PAB binary:
cabal exec -- plutus-starter-pab
This will then start up the server on port 9080. The devcontainer process will then automatically expose this port so that you can connect to it from any terminal (it doesn't have to be a terminal running in the devcontainer).
- Perform the setup for Plutus as described in the plutus starter project.
- Clone this repo to your local environment.
- Start a nix shell from the plutus repo from the first step.
- Build the PAB executable:
cabal build plutus-starter-pab
Ignore the unused import warnings. Did not get time to clean that up.
- Run the PAB binary:
cabal exec -- plutus-starter-pab
- Now, execute
run.sh
for the demo.- You might need to do
chmod +x run.sh
first in case execute permissions are missing.
- You might need to do
Finally, also node that the PAB also exposes a websocket, which you can read about in the general PAB Architecture documentation.
The token name used in this demo was built using the public key hash of the client wallet (NFT requestor). The token name can be encoded with more information like the expiry time of the auth NFT, the list of privileges obtained by holding this NFT etc.
The contract code can be cleaned up a bit. Did not get time to tidy up some unused imports.
ls src/<file name>.hs | entr -r cabal build plutus-starter-pab --dependencies-only --disable-documentation
If you're looking for support, or would simply like to report a bug, feature request, etc. please do so over on the main plutus repository.
Thanks!