Developers
GraphQL API

GraphQL API

All Wasmer services (accessible via both the registry frontend wasmer.io (opens in a new tab) and the CLI client wasmer-cli (opens in a new tab)) use the Wasmer GraphQL API to interact with and retrieve data.

What is GraphQL?

GraphQL is a query language for APIs and a runtime for fulfilling those queries with your existing data. GraphQL provides a complete and understandable description of the data in your API, gives clients the power to ask for exactly what they need and nothing more, makes it easier to evolve APIs over time, and enables powerful developer tools.

If you want to learn more about GraphQL, please visit the official Website: GraphQL.org (opens in a new tab)

How I can use the Wasmer API?

The Wasmer GraphQL API (and the GraphiQL IDE) can be accessed here:

registry.wasmer.io/graphql (opens in a new tab)

Did you know...? wasmer.sh (opens in a new tab) is using the Wasmer GraphQL API to automatically expose the packages in the online shell.

Examples

Let's see now a few things that we can do with it!

Get a Package Version

We can do a POST to https://registry.wasmer.io/graphql (opens in a new tab) with the the following as the query POST field:

{
    getPackageVersion(name: "python") {
    version
    repository
    homepage
    distribution {
      downloadUrl
      size
    }
  }
}

Which should return something similar to:

{
  "data": {
    "getPackageVersion": {
      "version": "0.1.0",
      "repository": "https://github.com/wapm-packages/python",
      "homepage": null,
      "distribution": {
        "downloadUrl": "https://registry-cdn.wasmer.io/packages/_/python/python-0.1.0.tar.gz",
        "size": 5097541
      }
    }
  }
}

Get all Packages for a given Interface

If we want to search all the packages published that have certain interface (for example, WASI), we can do a POST to https://registry.wasmer.io/graphql (opens in a new tab) with the the following as the query POST field:

{
  getInterfaceVersion(name: "wasi", version: "latest") {
    interface {
      name
      description
    }
    packageVersions {
      edges {
        node {
          version
          package {
            name
          }
          distribution {
            downloadUrl
          }
        }
      }
    }
  }
}

Which should return something similar to:

{
  "data": {
    "getInterfaceVersion": {
      "interface": {
        "name": "wasi",
        "description": "The WebAssembly System Interface. WASI is a modular system interface for WebAssembly. It’s focused on security and portability."
      },
      "packageVersions": {
        "edges": [
          {
            "node": {
              "version": "0.1.0",
              "package": {
                "name": "_/python"
              },
              "distribution": {
                "downloadUrl": "https://registry-cdn.wasmer.io/packages/_/python/python-0.1.0.tar.gz"
              }
            }
          },
          {
            "node": {
              "version": "0.0.2",
              "package": {
                "name": "JeremyLikness/wasi-ubasic"
              },
              "distribution": {
                "downloadUrl": "https://registry-cdn.wasmer.io/packages/JeremyLikness/wasi-ubasic/wasi-ubasic-0.0.2.tar.gz"
              }
            }
          },
          {
            "node": {
              "version": "0.4.6",
              "package": {
                "name": "vshymanskyy/wasm3"
              },
              "distribution": {
                "downloadUrl": "https://registry-cdn.wasmer.io/packages/vshymanskyy/wasm3/wasm3-0.4.6.tar.gz"
              }
            }
          }
        ]
      }
    }
  }
}

Happy hacking! 🎉