naftiko: 1.0.0-alpha2 info: label: PostHog API — roles description: 'PostHog API — roles. 10 operations. Lead operation: roles. Self-contained Naftiko capability covering one Posthog business surface.' tags: - Posthog - roles created: '2026-05-19' modified: '2026-05-19' binds: - namespace: env keys: POSTHOG_API_KEY: POSTHOG_API_KEY capability: consumes: - type: http namespace: posthog-roles baseUri: '' description: PostHog API — roles business capability. Self-contained, no shared references. resources: - name: api-organizations-organization_id-roles path: /api/organizations/{organization_id}/roles/ operations: - name: roleslist method: GET description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: limit in: query type: integer description: Number of results to return per page. - name: offset in: query type: integer description: The initial index from which to return the results. - name: rolescreate method: POST description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: body in: body type: object description: Request body (JSON). required: true - name: api-organizations-organization_id-roles-id path: /api/organizations/{organization_id}/roles/{id}/ operations: - name: rolesretrieve method: GET description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: id in: path type: string description: A UUID string identifying this role. required: true - name: rolesupdate method: PUT description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: id in: path type: string description: A UUID string identifying this role. required: true - name: body in: body type: object description: Request body (JSON). required: true - name: rolespartialupdate method: PATCH description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: id in: path type: string description: A UUID string identifying this role. required: true - name: body in: body type: object description: Request body (JSON). required: false - name: rolesdestroy method: DELETE description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: id in: path type: string description: A UUID string identifying this role. required: true - name: api-organizations-organization_id-roles-role_id-role_memberships path: /api/organizations/{organization_id}/roles/{role_id}/role_memberships/ operations: - name: rolesrolemembershipslist method: GET description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: limit in: query type: integer description: Number of results to return per page. - name: offset in: query type: integer description: The initial index from which to return the results. - name: role_id in: path type: string required: true - name: rolesrolemembershipscreate method: POST description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: role_id in: path type: string required: true - name: body in: body type: object description: Request body (JSON). required: true - name: api-organizations-organization_id-roles-role_id-role_memberships-id path: /api/organizations/{organization_id}/roles/{role_id}/role_memberships/{id}/ operations: - name: rolesrolemembershipsretrieve method: GET description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: id in: path type: string description: A UUID string identifying this role membership. required: true - name: role_id in: path type: string required: true - name: rolesrolemembershipsdestroy method: DELETE description: '' outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: id in: path type: string description: A UUID string identifying this role membership. required: true - name: role_id in: path type: string required: true authentication: type: bearer token: '{{env.POSTHOG_API_KEY}}' exposes: - type: rest namespace: posthog-roles-rest port: 8080 description: REST adapter for PostHog API — roles. One Spectral-compliant resource per consumed operation, prefixed with /v1. resources: - path: /v1/api/organizations/{organization-id}/roles name: api-organizations-organization-id-roles description: REST surface for api-organizations-organization_id-roles. operations: - method: GET name: roleslist description: roleslist call: posthog-roles.roleslist with: limit: rest.limit offset: rest.offset outputParameters: - type: object mapping: $. - method: POST name: rolescreate description: rolescreate call: posthog-roles.rolescreate with: body: rest.body outputParameters: - type: object mapping: $. - path: /v1/api/organizations/{organization-id}/roles/{id} name: api-organizations-organization-id-roles-id description: REST surface for api-organizations-organization_id-roles-id. operations: - method: GET name: rolesretrieve description: rolesretrieve call: posthog-roles.rolesretrieve with: id: rest.id outputParameters: - type: object mapping: $. - method: PUT name: rolesupdate description: rolesupdate call: posthog-roles.rolesupdate with: id: rest.id body: rest.body outputParameters: - type: object mapping: $. - method: PATCH name: rolespartialupdate description: rolespartialupdate call: posthog-roles.rolespartialupdate with: id: rest.id body: rest.body outputParameters: - type: object mapping: $. - method: DELETE name: rolesdestroy description: rolesdestroy call: posthog-roles.rolesdestroy with: id: rest.id outputParameters: - type: object mapping: $. - path: /v1/api/organizations/{organization-id}/roles/{role-id}/role-memberships name: api-organizations-organization-id-roles-role-id-role-memberships description: REST surface for api-organizations-organization_id-roles-role_id-role_memberships. operations: - method: GET name: rolesrolemembershipslist description: rolesrolemembershipslist call: posthog-roles.rolesrolemembershipslist with: limit: rest.limit offset: rest.offset role_id: rest.role_id outputParameters: - type: object mapping: $. - method: POST name: rolesrolemembershipscreate description: rolesrolemembershipscreate call: posthog-roles.rolesrolemembershipscreate with: role_id: rest.role_id body: rest.body outputParameters: - type: object mapping: $. - path: /v1/api/organizations/{organization-id}/roles/{role-id}/role-memberships/{id} name: api-organizations-organization-id-roles-role-id-role-memberships-id description: REST surface for api-organizations-organization_id-roles-role_id-role_memberships-id. operations: - method: GET name: rolesrolemembershipsretrieve description: rolesrolemembershipsretrieve call: posthog-roles.rolesrolemembershipsretrieve with: id: rest.id role_id: rest.role_id outputParameters: - type: object mapping: $. - method: DELETE name: rolesrolemembershipsdestroy description: rolesrolemembershipsdestroy call: posthog-roles.rolesrolemembershipsdestroy with: id: rest.id role_id: rest.role_id outputParameters: - type: object mapping: $. - type: mcp namespace: posthog-roles-mcp port: 9090 transport: http description: MCP adapter for PostHog API — roles. One tool per consumed operation, routed inline through this capability's consumes block. tools: - name: roleslist description: roleslist hints: readOnly: true destructive: false idempotent: true call: posthog-roles.roleslist with: limit: tools.limit offset: tools.offset outputParameters: - type: object mapping: $. - name: rolescreate description: rolescreate hints: readOnly: false destructive: false idempotent: false call: posthog-roles.rolescreate with: body: tools.body outputParameters: - type: object mapping: $. - name: rolesretrieve description: rolesretrieve hints: readOnly: true destructive: false idempotent: true call: posthog-roles.rolesretrieve with: id: tools.id outputParameters: - type: object mapping: $. - name: rolesupdate description: rolesupdate hints: readOnly: false destructive: false idempotent: true call: posthog-roles.rolesupdate with: id: tools.id body: tools.body outputParameters: - type: object mapping: $. - name: rolespartialupdate description: rolespartialupdate hints: readOnly: false destructive: false idempotent: true call: posthog-roles.rolespartialupdate with: id: tools.id body: tools.body outputParameters: - type: object mapping: $. - name: rolesdestroy description: rolesdestroy hints: readOnly: false destructive: true idempotent: true call: posthog-roles.rolesdestroy with: id: tools.id outputParameters: - type: object mapping: $. - name: rolesrolemembershipslist description: rolesrolemembershipslist hints: readOnly: true destructive: false idempotent: true call: posthog-roles.rolesrolemembershipslist with: limit: tools.limit offset: tools.offset role_id: tools.role_id outputParameters: - type: object mapping: $. - name: rolesrolemembershipscreate description: rolesrolemembershipscreate hints: readOnly: false destructive: false idempotent: false call: posthog-roles.rolesrolemembershipscreate with: role_id: tools.role_id body: tools.body outputParameters: - type: object mapping: $. - name: rolesrolemembershipsretrieve description: rolesrolemembershipsretrieve hints: readOnly: true destructive: false idempotent: true call: posthog-roles.rolesrolemembershipsretrieve with: id: tools.id role_id: tools.role_id outputParameters: - type: object mapping: $. - name: rolesrolemembershipsdestroy description: rolesrolemembershipsdestroy hints: readOnly: false destructive: true idempotent: true call: posthog-roles.rolesrolemembershipsdestroy with: id: tools.id role_id: tools.role_id outputParameters: - type: object mapping: $.