naftiko: 1.0.0-alpha2 info: label: 'Akamai: Application Security API — General configuration settings' description: 'Akamai: Application Security API — General configuration settings. 11 operations. Lead operation: Akamai API Security Create a Configuration. Self-contained Naftiko capability covering one Akamai Api Security business surface.' tags: - Akamai Api Security - General configuration settings created: '2026-05-19' modified: '2026-05-19' binds: - namespace: env keys: AKAMAI_API_SECURITY_API_KEY: AKAMAI_API_SECURITY_API_KEY capability: consumes: - type: http namespace: akamai-api-security-general-configuration-settings baseUri: https://{hostname}/appsec/v1 description: 'Akamai: Application Security API — General configuration settings business capability. Self-contained, no shared references.' resources: - name: configs path: /configs operations: - name: postconfig method: POST description: Akamai API Security Create a Configuration outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: body in: body type: object description: Request body (JSON). required: true - name: getconfigs method: GET description: Akamai API Security List Configurations outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: configs-configId path: /configs/{configId} operations: - name: getconfig method: GET description: Akamai API Security Get a Security Configuration outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: includeHostnames in: query type: boolean description: If `true`, include the list of hostnames protected by this security configuration in the production network. If `false`, exclude the list of hostnames protecte - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: putconfig method: PUT description: Akamai API Security Rename a Security Configuration outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: body in: body type: object description: Request body (JSON). required: true - name: deleteconfig method: DELETE description: Akamai API Security Delete a Configuration outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: configs-configId-versions path: /configs/{configId}/versions operations: - name: postconfigversions method: POST description: Akamai API Security Clone a Configuration Version outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: body in: body type: object description: Request body (JSON). required: true - name: getconfigversions method: GET description: Akamai API Security List Configuration Versions outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: page in: query type: integer description: The index of the result page. If the value is `-1`, then pagination is ignored. The default value is `1`. - name: pageSize in: query type: integer description: The number of items on each result page. The default value is `25`. - name: detail in: query type: boolean description: When `true`, the results contain detailed information on versions. With the default `false`, the results contain summary information on versions. - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: configs-configId-versions-versionNumber path: /configs/{configId}/versions/{versionNumber} operations: - name: getversionnumber method: GET description: Akamai API Security Get Configuration Version Details outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: deleteversionnumber method: DELETE description: Akamai API Security Delete a Configuration Version outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: configs-configId-versions-versionNumber-version-notes path: /configs/{configId}/versions/{versionNumber}/version-notes operations: - name: getversionnotes method: GET description: Akamai API Security Get the Version Notes outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: putversionnotes method: PUT description: Akamai API Security Modify Version Notes outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: accountSwitchKey in: query type: string description: For customers who manage more than one account, this [runs the operation from another account](https://techdocs.akamai.com/developer/docs/manage-many-accounts-w - name: body in: body type: object description: Request body (JSON). required: true exposes: - type: rest namespace: akamai-api-security-general-configuration-settings-rest port: 8080 description: 'REST adapter for Akamai: Application Security API — General configuration settings. One Spectral-compliant resource per consumed operation, prefixed with /v1.' resources: - path: /v1/configs name: configs description: REST surface for configs. operations: - method: POST name: postconfig description: Akamai API Security Create a Configuration call: akamai-api-security-general-configuration-settings.postconfig with: accountSwitchKey: rest.accountSwitchKey body: rest.body outputParameters: - type: object mapping: $. - method: GET name: getconfigs description: Akamai API Security List Configurations call: akamai-api-security-general-configuration-settings.getconfigs with: accountSwitchKey: rest.accountSwitchKey outputParameters: - type: object mapping: $. - path: /v1/configs/{configid} name: configs-configid description: REST surface for configs-configId. operations: - method: GET name: getconfig description: Akamai API Security Get a Security Configuration call: akamai-api-security-general-configuration-settings.getconfig with: includeHostnames: rest.includeHostnames accountSwitchKey: rest.accountSwitchKey outputParameters: - type: object mapping: $. - method: PUT name: putconfig description: Akamai API Security Rename a Security Configuration call: akamai-api-security-general-configuration-settings.putconfig with: accountSwitchKey: rest.accountSwitchKey body: rest.body outputParameters: - type: object mapping: $. - method: DELETE name: deleteconfig description: Akamai API Security Delete a Configuration call: akamai-api-security-general-configuration-settings.deleteconfig with: accountSwitchKey: rest.accountSwitchKey outputParameters: - type: object mapping: $. - path: /v1/configs/{configid}/versions name: configs-configid-versions description: REST surface for configs-configId-versions. operations: - method: POST name: postconfigversions description: Akamai API Security Clone a Configuration Version call: akamai-api-security-general-configuration-settings.postconfigversions with: accountSwitchKey: rest.accountSwitchKey body: rest.body outputParameters: - type: object mapping: $. - method: GET name: getconfigversions description: Akamai API Security List Configuration Versions call: akamai-api-security-general-configuration-settings.getconfigversions with: page: rest.page pageSize: rest.pageSize detail: rest.detail accountSwitchKey: rest.accountSwitchKey outputParameters: - type: object mapping: $. - path: /v1/configs/{configid}/versions/{versionnumber} name: configs-configid-versions-versionnumber description: REST surface for configs-configId-versions-versionNumber. operations: - method: GET name: getversionnumber description: Akamai API Security Get Configuration Version Details call: akamai-api-security-general-configuration-settings.getversionnumber with: accountSwitchKey: rest.accountSwitchKey outputParameters: - type: object mapping: $. - method: DELETE name: deleteversionnumber description: Akamai API Security Delete a Configuration Version call: akamai-api-security-general-configuration-settings.deleteversionnumber with: accountSwitchKey: rest.accountSwitchKey outputParameters: - type: object mapping: $. - path: /v1/configs/{configid}/versions/{versionnumber}/version-notes name: configs-configid-versions-versionnumber-version-notes description: REST surface for configs-configId-versions-versionNumber-version-notes. operations: - method: GET name: getversionnotes description: Akamai API Security Get the Version Notes call: akamai-api-security-general-configuration-settings.getversionnotes with: accountSwitchKey: rest.accountSwitchKey outputParameters: - type: object mapping: $. - method: PUT name: putversionnotes description: Akamai API Security Modify Version Notes call: akamai-api-security-general-configuration-settings.putversionnotes with: accountSwitchKey: rest.accountSwitchKey body: rest.body outputParameters: - type: object mapping: $. - type: mcp namespace: akamai-api-security-general-configuration-settings-mcp port: 9090 transport: http description: 'MCP adapter for Akamai: Application Security API — General configuration settings. One tool per consumed operation, routed inline through this capability''s consumes block.' tools: - name: akamai-api-security-create-configuration description: Akamai API Security Create a Configuration hints: readOnly: false destructive: false idempotent: false call: akamai-api-security-general-configuration-settings.postconfig with: accountSwitchKey: tools.accountSwitchKey body: tools.body outputParameters: - type: object mapping: $. - name: akamai-api-security-list-configurations description: Akamai API Security List Configurations hints: readOnly: true destructive: false idempotent: true call: akamai-api-security-general-configuration-settings.getconfigs with: accountSwitchKey: tools.accountSwitchKey outputParameters: - type: object mapping: $. - name: akamai-api-security-get-security description: Akamai API Security Get a Security Configuration hints: readOnly: true destructive: false idempotent: true call: akamai-api-security-general-configuration-settings.getconfig with: includeHostnames: tools.includeHostnames accountSwitchKey: tools.accountSwitchKey outputParameters: - type: object mapping: $. - name: akamai-api-security-rename-security description: Akamai API Security Rename a Security Configuration hints: readOnly: false destructive: false idempotent: true call: akamai-api-security-general-configuration-settings.putconfig with: accountSwitchKey: tools.accountSwitchKey body: tools.body outputParameters: - type: object mapping: $. - name: akamai-api-security-delete-configuration description: Akamai API Security Delete a Configuration hints: readOnly: false destructive: true idempotent: true call: akamai-api-security-general-configuration-settings.deleteconfig with: accountSwitchKey: tools.accountSwitchKey outputParameters: - type: object mapping: $. - name: akamai-api-security-clone-configuration description: Akamai API Security Clone a Configuration Version hints: readOnly: false destructive: false idempotent: false call: akamai-api-security-general-configuration-settings.postconfigversions with: accountSwitchKey: tools.accountSwitchKey body: tools.body outputParameters: - type: object mapping: $. - name: akamai-api-security-list-configuration description: Akamai API Security List Configuration Versions hints: readOnly: true destructive: false idempotent: true call: akamai-api-security-general-configuration-settings.getconfigversions with: page: tools.page pageSize: tools.pageSize detail: tools.detail accountSwitchKey: tools.accountSwitchKey outputParameters: - type: object mapping: $. - name: akamai-api-security-get-configuration description: Akamai API Security Get Configuration Version Details hints: readOnly: true destructive: false idempotent: true call: akamai-api-security-general-configuration-settings.getversionnumber with: accountSwitchKey: tools.accountSwitchKey outputParameters: - type: object mapping: $. - name: akamai-api-security-delete-configuration-2 description: Akamai API Security Delete a Configuration Version hints: readOnly: false destructive: true idempotent: true call: akamai-api-security-general-configuration-settings.deleteversionnumber with: accountSwitchKey: tools.accountSwitchKey outputParameters: - type: object mapping: $. - name: akamai-api-security-get-version description: Akamai API Security Get the Version Notes hints: readOnly: true destructive: false idempotent: true call: akamai-api-security-general-configuration-settings.getversionnotes with: accountSwitchKey: tools.accountSwitchKey outputParameters: - type: object mapping: $. - name: akamai-api-security-modify-version description: Akamai API Security Modify Version Notes hints: readOnly: false destructive: false idempotent: true call: akamai-api-security-general-configuration-settings.putversionnotes with: accountSwitchKey: tools.accountSwitchKey body: tools.body outputParameters: - type: object mapping: $.