Miro · Capability
Miro Developer Platform — Project Members
Miro Developer Platform — Project Members. 5 operations. Lead operation: Add member in a project. Self-contained Naftiko capability covering one Miro business surface.
What You Can Do
POST
Enterpriseaddprojectmember
— Add member in a project
/v1/v2/orgs/{org-id}/teams/{team-id}/projects/{project-id}/members
GET
Enterprisegetprojectmembers
— List of project members
/v1/v2/orgs/{org-id}/teams/{team-id}/projects/{project-id}/members
GET
Enterprisegetprojectmember
— Get project member
/v1/v2/orgs/{org-id}/teams/{team-id}/projects/{project-id}/members/{member-id}
PATCH
Enterpriseupdateprojectmember
— Update project member
/v1/v2/orgs/{org-id}/teams/{team-id}/projects/{project-id}/members/{member-id}
DELETE
Enterprisedeleteprojectmember
— Remove project member
/v1/v2/orgs/{org-id}/teams/{team-id}/projects/{project-id}/members/{member-id}
MCP Tools
add-member-project
Add member in a project
list-project-members
List of project members
read-only
idempotent
get-project-member
Get project member
read-only
idempotent
update-project-member
Update project member
idempotent
remove-project-member
Remove project member
idempotent
Capability Spec
naftiko: 1.0.0-alpha2
info:
label: Miro Developer Platform — Project Members
description: 'Miro Developer Platform — Project Members. 5 operations. Lead operation: Add member in a project. Self-contained
Naftiko capability covering one Miro business surface.'
tags:
- Miro
- Project Members
created: '2026-05-19'
modified: '2026-05-19'
binds:
- namespace: env
keys:
MIRO_API_KEY: MIRO_API_KEY
capability:
consumes:
- type: http
namespace: miro-project-members
baseUri: https://api.miro.com
description: Miro Developer Platform — Project Members business capability. Self-contained, no shared references.
resources:
- name: v2-orgs-org_id-teams-team_id-projects-project_id-members
path: /v2/orgs/{org_id}/teams/{team_id}/projects/{project_id}/members
operations:
- name: enterpriseaddprojectmember
method: POST
description: Add member in a project
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: org_id
in: path
type: string
description: The ID of the organization to which the project belongs.
required: true
- name: team_id
in: path
type: string
description: The ID of the team to which the project belongs.
required: true
- name: project_id
in: path
type: string
description: The ID of the project to which you want to add a user.
required: true
- name: body
in: body
type: object
description: Request body (JSON).
required: true
- name: enterprisegetprojectmembers
method: GET
description: List of project members
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: org_id
in: path
type: string
description: The ID of the organization to which the project belongs.
required: true
- name: team_id
in: path
type: string
description: The ID of the team to which the project belongs.
required: true
- name: project_id
in: path
type: string
description: The ID of the project for which you want to retrieve the list of members.
required: true
- name: limit
in: query
type: integer
description: The maximum number of results to return per call. If the number of project members in the response
is greater than the limit specified, the response returns the
- name: cursor
in: query
type: string
description: An indicator of the position of a page in the full set of results. To obtain the first page leave it
empty. To obtain subsequent pages set it to the value retur
- name: v2-orgs-org_id-teams-team_id-projects-project_id-members-member_id
path: /v2/orgs/{org_id}/teams/{team_id}/projects/{project_id}/members/{member_id}
operations:
- name: enterprisegetprojectmember
method: GET
description: Get project member
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: org_id
in: path
type: string
description: The ID of the organization to which the project belongs.
required: true
- name: team_id
in: path
type: string
description: The ID of the team to which the project belongs.
required: true
- name: project_id
in: path
type: string
description: The ID of the project from which you want to retrieve specific member information.
required: true
- name: member_id
in: path
type: string
description: The ID of the member for which you want to retrieve information.
required: true
- name: enterpriseupdateprojectmember
method: PATCH
description: Update project member
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: org_id
in: path
type: string
description: The ID of the organization to which the project member belongs.
required: true
- name: team_id
in: path
type: string
description: The ID of the team to which the project member belongs.
required: true
- name: project_id
in: path
type: string
description: The ID of a Project.
required: true
- name: member_id
in: path
type: string
description: The ID of the member whose details you want to update.
required: true
- name: body
in: body
type: object
description: Request body (JSON).
required: true
- name: enterprisedeleteprojectmember
method: DELETE
description: Remove project member
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: org_id
in: path
type: string
description: The ID of the organization to which the project belongs.
required: true
- name: team_id
in: path
type: string
description: The ID of the team to which the project belongs.
required: true
- name: project_id
in: path
type: string
description: The ID of the project from which you want to remove a member.
required: true
- name: member_id
in: path
type: string
description: The ID of the member that you want to remove from a project.
required: true
authentication:
type: bearer
token: '{{env.MIRO_API_KEY}}'
exposes:
- type: rest
namespace: miro-project-members-rest
port: 8080
description: REST adapter for Miro Developer Platform — Project Members. One Spectral-compliant resource per consumed
operation, prefixed with /v1.
resources:
- path: /v1/v2/orgs/{org-id}/teams/{team-id}/projects/{project-id}/members
name: v2-orgs-org-id-teams-team-id-projects-project-id-members
description: REST surface for v2-orgs-org_id-teams-team_id-projects-project_id-members.
operations:
- method: POST
name: enterpriseaddprojectmember
description: Add member in a project
call: miro-project-members.enterpriseaddprojectmember
with:
org_id: rest.org_id
team_id: rest.team_id
project_id: rest.project_id
body: rest.body
outputParameters:
- type: object
mapping: $.
- method: GET
name: enterprisegetprojectmembers
description: List of project members
call: miro-project-members.enterprisegetprojectmembers
with:
org_id: rest.org_id
team_id: rest.team_id
project_id: rest.project_id
limit: rest.limit
cursor: rest.cursor
outputParameters:
- type: object
mapping: $.
- path: /v1/v2/orgs/{org-id}/teams/{team-id}/projects/{project-id}/members/{member-id}
name: v2-orgs-org-id-teams-team-id-projects-project-id-members-member-id
description: REST surface for v2-orgs-org_id-teams-team_id-projects-project_id-members-member_id.
operations:
- method: GET
name: enterprisegetprojectmember
description: Get project member
call: miro-project-members.enterprisegetprojectmember
with:
org_id: rest.org_id
team_id: rest.team_id
project_id: rest.project_id
member_id: rest.member_id
outputParameters:
- type: object
mapping: $.
- method: PATCH
name: enterpriseupdateprojectmember
description: Update project member
call: miro-project-members.enterpriseupdateprojectmember
with:
org_id: rest.org_id
team_id: rest.team_id
project_id: rest.project_id
member_id: rest.member_id
body: rest.body
outputParameters:
- type: object
mapping: $.
- method: DELETE
name: enterprisedeleteprojectmember
description: Remove project member
call: miro-project-members.enterprisedeleteprojectmember
with:
org_id: rest.org_id
team_id: rest.team_id
project_id: rest.project_id
member_id: rest.member_id
outputParameters:
- type: object
mapping: $.
- type: mcp
namespace: miro-project-members-mcp
port: 9090
transport: http
description: MCP adapter for Miro Developer Platform — Project Members. One tool per consumed operation, routed inline
through this capability's consumes block.
tools:
- name: add-member-project
description: Add member in a project
hints:
readOnly: false
destructive: false
idempotent: false
call: miro-project-members.enterpriseaddprojectmember
with:
org_id: tools.org_id
team_id: tools.team_id
project_id: tools.project_id
body: tools.body
outputParameters:
- type: object
mapping: $.
- name: list-project-members
description: List of project members
hints:
readOnly: true
destructive: false
idempotent: true
call: miro-project-members.enterprisegetprojectmembers
with:
org_id: tools.org_id
team_id: tools.team_id
project_id: tools.project_id
limit: tools.limit
cursor: tools.cursor
outputParameters:
- type: object
mapping: $.
- name: get-project-member
description: Get project member
hints:
readOnly: true
destructive: false
idempotent: true
call: miro-project-members.enterprisegetprojectmember
with:
org_id: tools.org_id
team_id: tools.team_id
project_id: tools.project_id
member_id: tools.member_id
outputParameters:
- type: object
mapping: $.
- name: update-project-member
description: Update project member
hints:
readOnly: false
destructive: false
idempotent: true
call: miro-project-members.enterpriseupdateprojectmember
with:
org_id: tools.org_id
team_id: tools.team_id
project_id: tools.project_id
member_id: tools.member_id
body: tools.body
outputParameters:
- type: object
mapping: $.
- name: remove-project-member
description: Remove project member
hints:
readOnly: false
destructive: true
idempotent: true
call: miro-project-members.enterprisedeleteprojectmember
with:
org_id: tools.org_id
team_id: tools.team_id
project_id: tools.project_id
member_id: tools.member_id
outputParameters:
- type: object
mapping: $.