Create a new role
When creating roles you can pass a number of project-wide permissions, plus more granular permissions on models and build triggers.
For models you can specify the action that can be done, on which models and on records created by who.
The actions that can be performed are:
- all: everything
- read: read-only
- update: update records, to be used together with- readif you want to be able to read and update
- create: create new records
- delete: delete records
- publish: mark a record as published
- edit_creator: change the creator of a record
- take_over: when two people are working on the same record, you can take over the control of the record
Then you should specify the models on which the actions should be performed.
Finally you have the option to specify if you can perform the allowed actions on records created by:
- anyone: meaning every record
- self: only on records created by the user
- role: only on records created by users with the same role
The resulting object should look something like this:
{  action: 'all',  item_type: { type: 'item_type', id: '44' },  onCreator: 'self'}Body parameters
Must be exactly "role".
The name of the role
"Editor"
 Can edit favicon, global SEO settings and no-index policy
Can change project global properties
Can create/edit models and plugins
Can customize content navigation bar
Can change locales, timezone and UI theme
Can promote environments to primary and manage maintenance mode
Specifies the environments the user can access
"primary_only"
 Grants access to all environments
Grants access exclusively to the primary environment
Grants access exclusively to sandbox environments
No access to any environment. This value is typically used when the role is intended to inherit access settings from other roles
Can create/edit roles and invite/remove collaborators
Can create/edit shared filters (both for models and the media area)
Can create/edit upload collections
Can create/edit Build triggers
Can create/edit webhooks
Can create/delete sandbox environments and promote them to primary environment
Can manage Single Sign-On settings
Can access Audit Log
Can create/edit workflows
Can manage API tokens
Can perform Site Search API calls
Can access the build events log
Allowed actions on a model (or all) for a role
ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted action
"all"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Content under a specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Prohibited actions on a model (or all) for a role
ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted action
"all"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Content under a specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Allowed actions on a model (or all) for a role
Permitted action
"all"
 ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Localized content in specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Prohibited actions on a model (or all) for a role
Permitted action
"all"
 ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Localized content in specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Allowed build triggers for a role
Prohibited build triggers for a role
The final set of permissions considering also inherited roles
Can change project global properties
Can edit favicon, global SEO settings and no-index policy
Can create/edit models and plugins
Can customize content navigation bar
Can create/edit roles and invite/remove collaborators
Can create/delete sandbox environments and promote them to primary environment
Can create/edit webhooks
Specifies the environments the user can access
"primary_only"
 Grants access to all environments
Grants access exclusively to the primary environment
Grants access exclusively to sandbox environments
No access to any environment. This value is typically used when the role is intended to inherit access settings from other roles
Can manage Single Sign-On settings
Can access Audit Log
Can create/edit workflows
Can change locales, timezone and UI theme
Can promote environments to primary and manage maintenance mode
Can create/edit shared filters (both for models and the media area)
Can create/edit Build triggers
Can create/edit upload collections
Can manage API tokens
Can perform Site Search API calls
Can access the build events log
Allowed actions on a model (or all) for a role
ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted action
"all"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Content under a specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Prohibited actions on a model (or all) for a role
ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted action
"all"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Content under a specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Allowed actions on a model (or all) for a role
Permitted action
"all"
 ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Localized content in specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Prohibited actions on a model (or all) for a role
Permitted action
"all"
 ID of environment. Can only contain lowercase letters, numbers and dashes
"main"
 Permitted creator
"self"
 Created by anyone
Created by the user itself
Created by a user with the same role
Permitted content scope
"all"
 Any content (localized/unlocalized)
Localized content in specific locale (locale must be defined)
Non-localized content
Permitted localized content in this locale. Required when localization_scope is localized
"en"
 Allowed build triggers for a role
Prohibited build triggers for a role
The roles from which this role inherits permissions
Returns
Returns a resource object of type role.
Examples
POST https://site-api.datocms.com/roles HTTP/1.1Authorization: Bearer YOUR-API-TOKENAccept: application/jsonX-Api-Version: 3Content-Type: application/vnd.api+json
{  "data": {    "type": "role",    "attributes": {      "name": "Editor"    }  }}curl -g 'https://site-api.datocms.com/roles' \  -X POST \  -H "Authorization: Bearer YOUR-API-TOKEN" \  -H "Accept: application/json" \  -H "X-Api-Version: 3" \  -H "Content-Type: application/vnd.api+json" \  --data-binary '{"data":{"type":"role","attributes":{"name":"Editor"}}}'await fetch("https://site-api.datocms.com/roles", {  method: "POST",  headers: {    Authorization: "Bearer YOUR-API-TOKEN",    Accept: "application/json",    "X-Api-Version": "3",    "Content-Type": "application/vnd.api+json",  },  body: JSON.stringify({    data: { type: "role", attributes: { name: "Editor" } },  }),});HTTP/1.1 200 OKContent-Type: application/jsonCache-Control: cache-control: max-age=0, private, must-revalidateX-RateLimit-Limit: 30X-RateLimit-Remaining: 28
{  "data": {    "type": "role",    "id": "34",    "attributes": {      "name": "Editor",      "can_edit_site": true,      "can_edit_favicon": true,      "can_edit_schema": true,      "can_manage_menu": true,      "can_manage_users": true,      "can_manage_shared_filters": true,      "can_manage_upload_collections": true,      "can_manage_environments": true,      "can_manage_webhooks": true,      "environments_access": "primary_only",      "can_manage_sso": true,      "can_access_audit_log": true,      "can_manage_workflows": true,      "can_edit_environment": true,      "can_promote_environments": true,      "can_manage_build_triggers": true,      "can_manage_access_tokens": true,      "can_perform_site_search": true,      "can_access_build_events_log": true,      "positive_item_type_permissions": [        {          "environment": "main",          "action": "all"        }      ],      "negative_item_type_permissions": [        {          "environment": "main",          "action": "all"        }      ],      "positive_upload_permissions": [        {          "action": "all",          "environment": "main"        }      ],      "negative_upload_permissions": [        {          "action": "all",          "environment": "main"        }      ],      "positive_build_trigger_permissions": [        {}      ],      "negative_build_trigger_permissions": [        {}      ]    },    "relationships": {      "inherits_permissions_from": {        "data": [          {            "type": "role",            "id": "34"          }        ]      }    },    "meta": {      "final_permissions": {        "can_edit_site": true,        "can_edit_favicon": true,        "can_edit_schema": true,        "can_manage_menu": true,        "can_manage_users": true,        "can_manage_environments": true,        "can_manage_webhooks": true,        "environments_access": "primary_only",        "can_manage_sso": true,        "can_access_audit_log": true,        "can_manage_workflows": true,        "can_edit_environment": true,        "can_promote_environments": true,        "can_manage_shared_filters": true,        "can_manage_build_triggers": true,        "can_manage_upload_collections": true,        "can_manage_access_tokens": true,        "can_perform_site_search": true,        "can_access_build_events_log": true,        "positive_item_type_permissions": [          {            "environment": "main",            "action": "all"          }        ],        "negative_item_type_permissions": [          {            "environment": "main",            "action": "all"          }        ],        "positive_upload_permissions": [          {            "action": "all",            "environment": "main"          }        ],        "negative_upload_permissions": [          {            "action": "all",            "environment": "main"          }        ],        "positive_build_trigger_permissions": [          {}        ],        "negative_build_trigger_permissions": [          {}        ]      }    }  }}