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: $.