Skip to content
This repository has been archived by the owner on Feb 25, 2019. It is now read-only.

User Roles and Scope

Christian Smith edited this page Jul 7, 2014 · 6 revisions

Anvil Connect implements Role-Based Access Control using OAuth 2.0 style "scope" as permissions. A role is associated with one or more scopes. A user can be assigned one or more roles. When a client refers a user to the authorization server to authenticate, a scope determination is made based on:

  1. scope requested by the client
  2. scope defined for the authorization server
  3. scope available to every user by default (e.g., openid, profile)
  4. scope available to a user via role assignments

If a client requests scope that is not authorized for the user and the authorization request is otherwise successful, the scope of the issued token will be downgraded to match the user's permissions.

Standard Scope Definitions

Some scopes are available to all users by default.

  • openid – View your identity
  • profile – View your basic account info

In addition, Anvil Connect defines scope that may be required for certain API operations.

  • client – Register and configure clients
  • realm – Administer the security realm

Standard Role Definitions

Users can gain permissions through role assignment. Anvil Connect defines two standard roles with associated scope.

  • authority – this role should only be assigned to the operator(s) of the authorization server

    • realm
  • developer – this role can be assigned to users who may register clients

    • client

Defining New Roles and Scopes using the CLI

$ nv add role '{ "name": "editor" }'
$ nv add scope '{ "name": "blog", "description": "Read and write blog posts" }'
$ nv permit editor blog
$ nv assign [email protected] editor