naftiko: 1.0.0-alpha2 info: label: Unified.to API — course description: 'Unified.to API — course. 6 operations. Lead operation: List all courses. Self-contained Naftiko capability covering one Unified To business surface.' tags: - Unified To - course created: '2026-05-19' modified: '2026-05-19' binds: - namespace: env keys: UNIFIED_TO_API_KEY: UNIFIED_TO_API_KEY capability: consumes: - type: http namespace: hr-talent-course baseUri: https://api.unified.to description: Unified.to API — course business capability. Self-contained, no shared references. resources: - name: lms-connection_id-course path: /lms/{connection_id}/course operations: - name: listlmscourses method: GET description: List all courses outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: limit in: query type: number - name: offset in: query type: number - name: updated_gte in: query type: string description: Return only results whose updated date is equal or greater to this value (ISO-8601 / YYYY-MM-DDTHH:MM:SSZ format) - name: sort in: query type: string - name: order in: query type: string - name: query in: query type: string description: Query string to search. eg. email address or name - name: class_id in: query type: string description: The class ID to filter by (reference to LmsClass) - name: company_id in: query type: string description: The company ID to filter by (reference to HrisCompany) - name: fields in: query type: array description: Fields to return - name: raw in: query type: string description: 'Raw parameters to include in the 3rd-party request. Encoded as a URL component. eg. raw parameters: foo=bar&zoo=bar -> raw=foo%3Dbar%26zoo%3Dbar' - name: connection_id in: path type: string description: ID of the connection required: true - name: createlmscourse method: POST description: Create a course outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: fields in: query type: array description: Fields to return - name: raw in: query type: string description: 'Raw parameters to include in the 3rd-party request. Encoded as a URL component. eg. raw parameters: foo=bar&zoo=bar -> raw=foo%3Dbar%26zoo%3Dbar' - name: connection_id in: path type: string description: ID of the connection required: true - name: body in: body type: object description: Request body (JSON). required: true - name: lms-connection_id-course-id path: /lms/{connection_id}/course/{id} operations: - name: removelmscourse method: DELETE description: Remove a course outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: connection_id in: path type: string description: ID of the connection required: true - name: id in: path type: string description: ID of the Course required: true - name: getlmscourse method: GET description: Retrieve a course outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: fields in: query type: array description: Fields to return - name: raw in: query type: string description: 'Raw parameters to include in the 3rd-party request. Encoded as a URL component. eg. raw parameters: foo=bar&zoo=bar -> raw=foo%3Dbar%26zoo%3Dbar' - name: connection_id in: path type: string description: ID of the connection required: true - name: id in: path type: string description: ID of the Course required: true - name: patchlmscourse method: PATCH description: Update a course outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: fields in: query type: array description: Fields to return - name: raw in: query type: string description: 'Raw parameters to include in the 3rd-party request. Encoded as a URL component. eg. raw parameters: foo=bar&zoo=bar -> raw=foo%3Dbar%26zoo%3Dbar' - name: connection_id in: path type: string description: ID of the connection required: true - name: id in: path type: string description: ID of the Course required: true - name: body in: body type: object description: Request body (JSON). required: true - name: updatelmscourse method: PUT description: Update a course outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: fields in: query type: array description: Fields to return - name: raw in: query type: string description: 'Raw parameters to include in the 3rd-party request. Encoded as a URL component. eg. raw parameters: foo=bar&zoo=bar -> raw=foo%3Dbar%26zoo%3Dbar' - name: connection_id in: path type: string description: ID of the connection required: true - name: id in: path type: string description: ID of the Course required: true - name: body in: body type: object description: Request body (JSON). required: true authentication: type: apikey key: authorization value: '{{env.UNIFIED_TO_API_KEY}}' placement: header exposes: - type: rest namespace: hr-talent-course-rest port: 8080 description: REST adapter for Unified.to API — course. One Spectral-compliant resource per consumed operation, prefixed with /v1. resources: - path: /v1/lms/{connection-id}/course name: lms-connection-id-course description: REST surface for lms-connection_id-course. operations: - method: GET name: listlmscourses description: List all courses call: hr-talent-course.listlmscourses with: limit: rest.limit offset: rest.offset updated_gte: rest.updated_gte sort: rest.sort order: rest.order query: rest.query class_id: rest.class_id company_id: rest.company_id fields: rest.fields raw: rest.raw connection_id: rest.connection_id outputParameters: - type: object mapping: $. - method: POST name: createlmscourse description: Create a course call: hr-talent-course.createlmscourse with: fields: rest.fields raw: rest.raw connection_id: rest.connection_id body: rest.body outputParameters: - type: object mapping: $. - path: /v1/lms/{connection-id}/course/{id} name: lms-connection-id-course-id description: REST surface for lms-connection_id-course-id. operations: - method: DELETE name: removelmscourse description: Remove a course call: hr-talent-course.removelmscourse with: connection_id: rest.connection_id id: rest.id outputParameters: - type: object mapping: $. - method: GET name: getlmscourse description: Retrieve a course call: hr-talent-course.getlmscourse with: fields: rest.fields raw: rest.raw connection_id: rest.connection_id id: rest.id outputParameters: - type: object mapping: $. - method: PATCH name: patchlmscourse description: Update a course call: hr-talent-course.patchlmscourse with: fields: rest.fields raw: rest.raw connection_id: rest.connection_id id: rest.id body: rest.body outputParameters: - type: object mapping: $. - method: PUT name: updatelmscourse description: Update a course call: hr-talent-course.updatelmscourse with: fields: rest.fields raw: rest.raw connection_id: rest.connection_id id: rest.id body: rest.body outputParameters: - type: object mapping: $. - type: mcp namespace: hr-talent-course-mcp port: 9090 transport: http description: MCP adapter for Unified.to API — course. One tool per consumed operation, routed inline through this capability's consumes block. tools: - name: list-all-courses description: List all courses hints: readOnly: true destructive: false idempotent: true call: hr-talent-course.listlmscourses with: limit: tools.limit offset: tools.offset updated_gte: tools.updated_gte sort: tools.sort order: tools.order query: tools.query class_id: tools.class_id company_id: tools.company_id fields: tools.fields raw: tools.raw connection_id: tools.connection_id outputParameters: - type: object mapping: $. - name: create-course description: Create a course hints: readOnly: false destructive: false idempotent: false call: hr-talent-course.createlmscourse with: fields: tools.fields raw: tools.raw connection_id: tools.connection_id body: tools.body outputParameters: - type: object mapping: $. - name: remove-course description: Remove a course hints: readOnly: false destructive: true idempotent: true call: hr-talent-course.removelmscourse with: connection_id: tools.connection_id id: tools.id outputParameters: - type: object mapping: $. - name: retrieve-course description: Retrieve a course hints: readOnly: true destructive: false idempotent: true call: hr-talent-course.getlmscourse with: fields: tools.fields raw: tools.raw connection_id: tools.connection_id id: tools.id outputParameters: - type: object mapping: $. - name: update-course description: Update a course hints: readOnly: false destructive: false idempotent: true call: hr-talent-course.patchlmscourse with: fields: tools.fields raw: tools.raw connection_id: tools.connection_id id: tools.id body: tools.body outputParameters: - type: object mapping: $. - name: update-course-2 description: Update a course hints: readOnly: false destructive: false idempotent: true call: hr-talent-course.updatelmscourse with: fields: tools.fields raw: tools.raw connection_id: tools.connection_id id: tools.id body: tools.body outputParameters: - type: object mapping: $.