naftiko: 1.0.0-alpha2 info: label: Ngrok API — IP Policy Rules description: 'Ngrok API — IP Policy Rules. 5 operations. Lead operation: Ngrok Create IP Policy Rule. Self-contained Naftiko capability covering one Ngrok business surface.' tags: - Ngrok - IP Policy Rules created: '2026-05-19' modified: '2026-05-19' binds: - namespace: env keys: NGROK_API_KEY: NGROK_API_KEY capability: consumes: - type: http namespace: ngrok-ip-policy-rules baseUri: https://api.ngrok.com description: Ngrok API — IP Policy Rules business capability. Self-contained, no shared references. resources: - name: ip_policy_rules path: /ip_policy_rules operations: - name: createippolicyrule method: POST description: Ngrok Create IP Policy Rule outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: body in: body type: object description: Request body (JSON). required: true - name: listippolicyrules method: GET description: Ngrok List IP Policy Rules outputRawFormat: json outputParameters: - name: result type: object value: $. - name: ip_policy_rules-id path: /ip_policy_rules/{id} operations: - name: getippolicyrule method: GET description: Ngrok Get IP Policy Rule outputRawFormat: json outputParameters: - name: result type: object value: $. - name: updateippolicyrule method: PATCH description: Ngrok Update IP Policy Rule outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: body in: body type: object description: Request body (JSON). required: true - name: deleteippolicyrule method: DELETE description: Ngrok Delete IP Policy Rule outputRawFormat: json outputParameters: - name: result type: object value: $. authentication: type: bearer token: '{{env.NGROK_API_KEY}}' exposes: - type: rest namespace: ngrok-ip-policy-rules-rest port: 8080 description: REST adapter for Ngrok API — IP Policy Rules. One Spectral-compliant resource per consumed operation, prefixed with /v1. resources: - path: /v1/ip-policy-rules name: ip-policy-rules description: REST surface for ip_policy_rules. operations: - method: POST name: createippolicyrule description: Ngrok Create IP Policy Rule call: ngrok-ip-policy-rules.createippolicyrule with: body: rest.body outputParameters: - type: object mapping: $. - method: GET name: listippolicyrules description: Ngrok List IP Policy Rules call: ngrok-ip-policy-rules.listippolicyrules outputParameters: - type: object mapping: $. - path: /v1/ip-policy-rules/{id} name: ip-policy-rules-id description: REST surface for ip_policy_rules-id. operations: - method: GET name: getippolicyrule description: Ngrok Get IP Policy Rule call: ngrok-ip-policy-rules.getippolicyrule outputParameters: - type: object mapping: $. - method: PATCH name: updateippolicyrule description: Ngrok Update IP Policy Rule call: ngrok-ip-policy-rules.updateippolicyrule with: body: rest.body outputParameters: - type: object mapping: $. - method: DELETE name: deleteippolicyrule description: Ngrok Delete IP Policy Rule call: ngrok-ip-policy-rules.deleteippolicyrule outputParameters: - type: object mapping: $. - type: mcp namespace: ngrok-ip-policy-rules-mcp port: 9090 transport: http description: MCP adapter for Ngrok API — IP Policy Rules. One tool per consumed operation, routed inline through this capability's consumes block. tools: - name: ngrok-create-ip-policy-rule description: Ngrok Create IP Policy Rule hints: readOnly: false destructive: false idempotent: false call: ngrok-ip-policy-rules.createippolicyrule with: body: tools.body outputParameters: - type: object mapping: $. - name: ngrok-list-ip-policy-rules description: Ngrok List IP Policy Rules hints: readOnly: true destructive: false idempotent: true call: ngrok-ip-policy-rules.listippolicyrules outputParameters: - type: object mapping: $. - name: ngrok-get-ip-policy-rule description: Ngrok Get IP Policy Rule hints: readOnly: true destructive: false idempotent: true call: ngrok-ip-policy-rules.getippolicyrule outputParameters: - type: object mapping: $. - name: ngrok-update-ip-policy-rule description: Ngrok Update IP Policy Rule hints: readOnly: false destructive: false idempotent: true call: ngrok-ip-policy-rules.updateippolicyrule with: body: tools.body outputParameters: - type: object mapping: $. - name: ngrok-delete-ip-policy-rule description: Ngrok Delete IP Policy Rule hints: readOnly: false destructive: true idempotent: true call: ngrok-ip-policy-rules.deleteippolicyrule outputParameters: - type: object mapping: $.