Tutorial: Get Verified Proof That You Are the Best at Playing Snake (Part I)

January 15, 2024

An image displaying game achievement credentials in a wallet and the snake from the snake game.

Check out the YouTube video of this tutorial for a complete walkthrough of the demo application and its workflows.

Ready to build a decentralized identity solution fast? 🚀

Verifiable Credentials are a digital form of credentials that enable you to send and receive proof of any digitally issued identity information. While this reasonably new technology is incredibly powerful, as it enables you to share information in a way that’s fast, user-centric, private, and secure, it can also be difficult to work with.

If you’re looking to get all the benefits from using verifiable credentials in your application, with none of the months-long learning curve, we highly recommend you take a look at Paradym. Paradym is a workflow builder specialized in working with verifiable credentials (VCs). The straightforward YAML syntax enables you to start building immediately, with no time spent decoding overly complex infrastructure issues.

In this tutorial, we’ll show you how to build an actual use case using verifiable credentials and how to integrate Paradym into your project.

This tutorial is divided into two parts: Issuance and Verification. In the Issuance section, we'll issue a credential for achieving a highscore in a snake game 🐍 using Paradym. The second part will involve creating a custom Discord server with restricted access granted through the presented credential. We’ll be building a total of two workflows and integrating those in a TypeScript-based web application using Paradyms REST API and webhook interface.

Again, check out the YouTube video below for a complete walkthrough of the demo application and its workflows. Let’s get into it!


  1. Register a high score badge credential 🪪
  2. Issue a high score badge 🏆
  3. Integrate with the web application 🛠️

Before you begin

This tutorial uses Paradym, a workflow builder for developers that provides the actions, workflows, and infrastructure you need to use verifiable credentials in your solution.

If you don't have an account yet, you can start with our quick start guide.

This demo also uses the Paradym Wallet, an open-source companion app to the Paradym platform available on the Apple App Store and Google Play Store.

This demo app requires two workflows, which we'll put in this tutorial and on GitHub, as well as the web application used to demo the integrated end result.

0. Intro

The workflows you build in Paradym are used for any process where information or proof of information is exchanged. A typical workflow contains four components:

  • Name, a way to recognize your workflow in the platform
  • Trigger, a way to execute your custom-made workflows
  • Input Object, a JSONSchema that validates the input of your workflow
  • Actions Array, the steps that your workflow takes to reach its overall goal

The actions are the building blocks with which you can customize your workflow. They enable you to make connections, issue credentials, request presentations, etc., in any order your application requires. Your workflow can hold for the input of a third party or execute all at once, depending on the specific actions you’ve chosen. Often, one workflow is to implement one user flow, meaning that at the beginning, a new user process is started, and at the end, a result is achieved.

Our snake high score credentials app requires two workflows.

  • Register Credential Template: workflow used to register your credential schema and definition. The result of this workflow is used in the issuance workflow.
  • Issue High Score Badge: workflow used to issue the achievement credential once the player beats the high score.

If you’re new to verifiable credentials and want to learn more about their features and benefits, we recommend taking a look at this repository.

1. Register a Credential 🪪

The first step is to register the "High Score Badge" credential through the Paradym UI.

When we register a credential template, we basically store the general form of a credential in order to use it later, as many times as needed. For example, a credential template for a driver’s license might contain name, date of birth, and other personal attributes, as well as attributes for the type of vehicle you’re licensed for.

The registered credential template does not have any actual user information in it yet, just the attributes that make up the credential.

Using Paradym you can define the credential attributes in the template itself (see our tutorial on Issuing and Verifying Education Credentials for that), or use a general template and define the attributes through the UI or API. If you intend to reuse your workflow to register different credentials, you might want to choose a reusable workflow template. For our snake game that's exaclty what we'll do. We can use the Paradym template for registering a credential by selecting it in the workflow editor through 'templates'.

This template can be published and ran immeidately without changes, and it will prompt you to fill out the expected attributes like the name of the credential, the version, the network and the attribute names.

  • highscore
  • timestamp


  1. Create a new workflow from the Register Credential Template template

  2. The workflow will be triggered through an API call

  3. The workflow requires input in the form of an object. Remember, we're keeping this generic and filling it with our specific High Score Badge attributes later! The input properties are: a. attributeNames, an array of the credentials attributes b. name, the name of the credential c. version, the version of the credential d. network, the network the credential template will be stored on

  4. The actions array requires two actions:

    1. Create a schema with our previously mentioned attributes that we get from the input object. The createSchema action will output a schemaId for future use.
    2. Create a Credential Definition using the created schema.

You can access action output in other sections of the workflow using $.actions.<actionId>.output.<value> You can read more about the specific inputs and outputs of the createSchema and createCredentialDefinition actions in the Paradym Docs.

name: Register Credential Template

  type: api

# Workflow can be triggered through the API (or manually through the UI)
  type: api

# Input object allows to dynamically pass the name, version and attributes of the schema
  type: "object"
      type: array
        type: string
      type: string
      type: string
      description: Must match x.x.x or x.x (e.g. 1.0 or 1.0.0)
      default: "1.0"
      type: string
      default: "cheqd:mainnet"
        - "cheqd:testnet"
        - "cheqd:mainnet"
    - name
    - version
    - attributeNames
    - network

  - id: createSchema
    name: anoncreds/createSchema@v1
      attributeNames: $.input.attributeNames
      name: $.input.name
      version: $.input.version
      network: $.input.network

  - id: createCredentialDefinition
    name: anoncreds/createCredentialDefinition@v1
      schemaId: $.actions.createSchema.output.schemaId
      tag: $.input.name

The process to actually register the credential is pretty straightforward. You’ll just have to execute it:

  1. Publish the workflow, by clicking 'Publish'.
  2. Run the workflow, by clicking 'Run'.

When running the workflow you'll be prompted for input, just like we instructed our workflow to do! Now fill out the following fields:

Image of an input modal with filled fields.

You only have to register a credential one time to use it to issue as many credentials as you want.

The output will show the generated Credential Definition ID, which you'll need for the next workflow. You can copy the Credential Definition ID in the execution window by hovering over and copying it.

Image of executed workflow in Paradym platform

2. Issue a High Score Badge 🏆

Next, we’re going to create a workflow to issue the certificate we just registered. Once a template is registered, credentials can be issued as many times as you need. An issued credential does contain the actual user information (not just the empty attributes) and is bound to the person to whom it is issued. An issued certificate of a driver’s license might contain your specific name, date of birth, and other relevant information.

A person or organization stores their credentials in a wallet. For this tutorial, we recommend you use the Paradym mobile wallet. It’s available on iOS & Android, free and open-source, and will enable you to try your demo project end-to-end yourself!

The workflow we’ll create will make a connection and then issue a highs score badge credential to that connection.


  1. Create a new workflow and name it Issue High Score Badge, you can copy the one below or edit the Issue an Employee Badge template

  2. The workflow will be triggered through an API call

  3. The workflow requires some input

    1. It requires information to fill in the attributes we defined when creating the credential template. A highscore, and a timestamp.
  4. The actions array requires two actions:

    1. Create a connection between the Game platform (issuer) and the Player (holder).
    2. Issue the credential to the connection made using the created connectionId (internal reference) and credentialDefinitionId from the previous workflow (the one you copied from the output).

You can read more about the specific inputs and outputs of the createConnection and issueCredential actions in the Paradym Docs[1][2].

name: Issue High Score Badge

  type: api

  type: 'object'
      title: Highscore
      description: Highscore of the user
      type: string
      title: Timestamp
      description: Date and time of when the highscore was achieved
      type: string
    - highscore
    - timestamp

  - id: createConnection
    name: didcomm/createConnection@v1

  - id: issueCredential
    name: didcomm/issueCredential@v1
      connectionId: $.actions.createConnection.output.connection.connectionId
        credentialDefinitionId: <YOUR_CREDENTIAL_DEFINITION_ID>
          highscore: $.input.highscore
          timestamp: $.input.timestamp

Publish the workflow to make it active. When running this workflow, an invitation URL will be created that, when turned into a QR code, can be accepted by the user (player) through their mobile wallet.

The workflow does not need to be executed manually, as it will be executed through the demo application & API.

3. Integrate with the web application 🛠️

For this section we recommend also checking out the README as it has more detailed project setup information

Before we can see the whole end-to-end application (and our workflows in action), we need to integrate Paradym with the demo application. The demo application can be cloned from the GitHub repository. We will need to do some general setup to get the project up and running, as well as some Paradym specific setup to connect our workflows. We will also use ngrok to run the project.

In the projects' packages/server/.env file we will have to define a couple of environment values.

  • Paradym API Key, to call the API to execute our workflows
  • Paradym Webhook Secret, using webhooks we can listen for changes in our workflow executions
  • Workflow ID of the "Issue High Score Badge" workflow, so we know which workflow to trigger

The API key and webhook secret can be generated in the ‘API Keys’ and 'Webhooks' tab in the Paradym dashboard respectively.

Image of API Key tab in Paradym platform


  1. Create an API Key in the Paradym dashboard by giving it a name (like 'snake-api') and pressing the ‘Create’ button. Copy the API key and set it as the value for the PARADYM_API_KEY environment variable in packages/server/.env.
  2. Expose port 3000 to the internet by using ngrok. a. Install ngrok b. Connect (and make) your ngrok account c. Once you have installed ngrok, you can run ngrok http 3000. Make sure to put 3000 as that is where your app is.
  3. Use the https 'Forwarding URL' that ngrok generates to create your webhook in the Paradym dashboard. Make sure to add /webhook after the url (e.g. https://107a-123-123-123-123.ngrok-free.app/webhook).
  4. After creating the webhook endpoint, copy the webhook secret and set it as the value for the PARADYM_HMAC_SIGNATURE in packages/server/.env.

NOTE: Keep the ngrok server running and use a different terminal window for the following steps. If you restart the ngrok process, the URL will change and you have to reconfigure the webhook URL in paradym

  1. Copy the workflow ID (from the "Issue High Score Badge" workflow) into the app. You can find this ID in the executions page of the workflow.

  2. Run the demo application!

    1. Run yarn && yarn dev in the project folder to start the demo application
    2. It will now be available on localhost 3000

You can now use the application together with the Paradym wallet! You can play the game and if you get a high score, claim your badge!

Great job! 🚀

We’ve built two workflows that enable our game platform to issue credentials. We’ve learned how to integrate these flows into our demo application. And we’ve become digital identity pros! Stay tuned for part two 👀 where we'll use the high score badge for selective access in our Discord server.

Don’t forget to join the Paradym Community Slack and show us all of the awesome things you’re building (or ask us all of the questions).

The Paradym rocket