v1
Northflank docs for LLMs
API
CLI
JS Client

Team / Team Roles /

Create team role

Creates a new platform role for a team.

Required permission

Account > Admin > Roles > Manage

Path parameters

    • teamId

      string required
      ID of the team

Request body

  • {object}
    • name

      string required
      The name of the role.
      min length
      3
      max length
      100
      pattern
      ^[a-zA-Z0-9]+((-|\s)[a-zA-Z0-9]+)*$
    • description

      string
      A description of the role.
      max length
      200
      pattern
      ^[a-zA-Z0-9.,?\s\\/'"()[\];`%^&*\-_:!]+$
    • permissions

      {object}
      Permissions granted by this role.
      • teamScope

        [array]
        Team-level RBAC permission strings.
        • string
      • projectScope

        [array]
        Project-level RBAC permission strings.
        • string
    • restrictions

      {object}
      Project access restrictions for this role.
      • enabled

        boolean required
      • projects

        [array]
        • string
          min length
          3
          max length
          39
          pattern
          ^[a-zA-Z](-?[a-zA-Z0-9]+(-[a-zA-Z0-9]+)*)?$
      • restrictionMode

        string
        one of
        in, notIn

Response body

  • {object}
    Response object.
    • data

      {object} required
      Result data.
      • id

        string required
        ID of the role.
        pattern
        ^[A-Za-z0-9-]+$
      • name

        string required
        Display name of the role.
      • description

        string
        Description of the role.
      • restrictions

        {object}
        • enabled

          boolean required
        • projects

          [array]
          • string
            min length
            3
            max length
            39
            pattern
            ^[a-zA-Z](-?[a-zA-Z0-9]+(-[a-zA-Z0-9]+)*)?$
        • restrictionMode

          string
          one of
          in, notIn
      • createdAt

        string
        Creation time.
      • updatedAt

        string
        Last updated.
      • permissions

        {object} required
        • teamScope

          [array] required
          Team-level permissions.
          • string
        • projectScope

          [array] required
          Project-level permissions.
          • string
API
CLI
JS Client

POST /v1/teams/{teamId}/roles

Example request

Request body
curl --header "Content-Type: application/json" \
  --header "Authorization: Bearer NORTHFLANK_API_TOKEN" \
  --request POST \
  --data '{"name":"Developer","description":"Role for developers."}' \
  https://api.northflank.com/v1/teams/{teamId}/roles

Example response

200 OK

Details about the newly created team role.

JSON

{
  "data": {
    "id": "developer",
    "name": "Developer",
    "description": "Role for developers.",
    "createdAt": "2021-01-20T11:19:53.175Z",
    "updatedAt": "2021-01-20T11:19:53.175Z"
  }
}

© 2026 Northflank Ltd. All rights reserved.

northflank.com / Terms / Privacy / feedback@northflank.com