Palo Alto Networks · Capability

Palo Alto Networks SASE IAM Service API — Access Policies

Palo Alto Networks SASE IAM Service API — Access Policies. 5 operations. Lead operation: Palo Alto Networks List Access Policies. Self-contained Naftiko capability covering one Palo Alto Networks business surface.

Run with Naftiko Palo Alto NetworksAccess Policies

What You Can Do

GET
Listaccesspolicies — Palo Alto Networks List Access Policies
/v1/access-policies
POST
Createaccesspolicy — Palo Alto Networks Create Access Policy
/v1/access-policies
GET
Getaccesspolicy — Palo Alto Networks Get Access Policy
/v1/access-policies/{id}
PUT
Updateaccesspolicy — Palo Alto Networks Update Access Policy
/v1/access-policies/{id}
DELETE
Deleteaccesspolicy — Palo Alto Networks Delete Access Policy
/v1/access-policies/{id}

MCP Tools

palo-alto-networks-list-access

Palo Alto Networks List Access Policies

read-only idempotent
palo-alto-networks-create-access

Palo Alto Networks Create Access Policy

palo-alto-networks-get-access

Palo Alto Networks Get Access Policy

read-only idempotent
palo-alto-networks-update-access

Palo Alto Networks Update Access Policy

idempotent
palo-alto-networks-delete-access

Palo Alto Networks Delete Access Policy

idempotent

Capability Spec

palo-alto-sase-iam-access-policies.yaml Raw ↑
naftiko: 1.0.0-alpha2
info:
  label: Palo Alto Networks SASE IAM Service API — Access Policies
  description: 'Palo Alto Networks SASE IAM Service API — Access Policies. 5 operations. Lead operation: Palo Alto Networks
    List Access Policies. Self-contained Naftiko capability covering one Palo Alto Networks business surface.'
  tags:
  - Palo Alto Networks
  - Access Policies
  created: '2026-05-19'
  modified: '2026-05-19'
binds:
- namespace: env
  keys:
    PALO_ALTO_NETWORKS_API_KEY: PALO_ALTO_NETWORKS_API_KEY
capability:
  consumes:
  - type: http
    namespace: palo-alto-sase-iam-access-policies
    baseUri: https://api.sase.paloaltonetworks.com/iam/v1
    description: Palo Alto Networks SASE IAM Service API — Access Policies business capability. Self-contained, no shared
      references.
    resources:
    - name: access-policies
      path: /access-policies
      operations:
      - name: listaccesspolicies
        method: GET
        description: Palo Alto Networks List Access Policies
        outputRawFormat: json
        outputParameters:
        - name: result
          type: object
          value: $.
        inputParameters:
        - name: principal_id
          in: query
          type: string
          description: Filter policies by principal ID (service account or user).
        - name: tsg_id
          in: query
          type: string
          description: Filter policies by TSG scope.
        - name: offset
          in: query
          type: integer
          description: Number of results to skip for pagination.
        - name: limit
          in: query
          type: integer
          description: Maximum number of policies to return.
      - name: createaccesspolicy
        method: POST
        description: Palo Alto Networks Create Access Policy
        outputRawFormat: json
        outputParameters:
        - name: result
          type: object
          value: $.
        inputParameters:
        - name: body
          in: body
          type: object
          description: Request body (JSON).
          required: true
    - name: access-policies-id
      path: /access-policies/{id}
      operations:
      - name: getaccesspolicy
        method: GET
        description: Palo Alto Networks Get Access Policy
        outputRawFormat: json
        outputParameters:
        - name: result
          type: object
          value: $.
        inputParameters:
        - name: id
          in: path
          type: string
          description: Unique identifier of the access policy.
          required: true
      - name: updateaccesspolicy
        method: PUT
        description: Palo Alto Networks Update Access Policy
        outputRawFormat: json
        outputParameters:
        - name: result
          type: object
          value: $.
        inputParameters:
        - name: id
          in: path
          type: string
          description: Unique identifier of the access policy to update.
          required: true
        - name: body
          in: body
          type: object
          description: Request body (JSON).
          required: true
      - name: deleteaccesspolicy
        method: DELETE
        description: Palo Alto Networks Delete Access Policy
        outputRawFormat: json
        outputParameters:
        - name: result
          type: object
          value: $.
        inputParameters:
        - name: id
          in: path
          type: string
          description: Unique identifier of the access policy to delete.
          required: true
    authentication:
      type: bearer
      token: '{{env.PALO_ALTO_NETWORKS_API_KEY}}'
  exposes:
  - type: rest
    namespace: palo-alto-sase-iam-access-policies-rest
    port: 8080
    description: REST adapter for Palo Alto Networks SASE IAM Service API — Access Policies. One Spectral-compliant resource
      per consumed operation, prefixed with /v1.
    resources:
    - path: /v1/access-policies
      name: access-policies
      description: REST surface for access-policies.
      operations:
      - method: GET
        name: listaccesspolicies
        description: Palo Alto Networks List Access Policies
        call: palo-alto-sase-iam-access-policies.listaccesspolicies
        with:
          principal_id: rest.principal_id
          tsg_id: rest.tsg_id
          offset: rest.offset
          limit: rest.limit
        outputParameters:
        - type: object
          mapping: $.
      - method: POST
        name: createaccesspolicy
        description: Palo Alto Networks Create Access Policy
        call: palo-alto-sase-iam-access-policies.createaccesspolicy
        with:
          body: rest.body
        outputParameters:
        - type: object
          mapping: $.
    - path: /v1/access-policies/{id}
      name: access-policies-id
      description: REST surface for access-policies-id.
      operations:
      - method: GET
        name: getaccesspolicy
        description: Palo Alto Networks Get Access Policy
        call: palo-alto-sase-iam-access-policies.getaccesspolicy
        with:
          id: rest.id
        outputParameters:
        - type: object
          mapping: $.
      - method: PUT
        name: updateaccesspolicy
        description: Palo Alto Networks Update Access Policy
        call: palo-alto-sase-iam-access-policies.updateaccesspolicy
        with:
          id: rest.id
          body: rest.body
        outputParameters:
        - type: object
          mapping: $.
      - method: DELETE
        name: deleteaccesspolicy
        description: Palo Alto Networks Delete Access Policy
        call: palo-alto-sase-iam-access-policies.deleteaccesspolicy
        with:
          id: rest.id
        outputParameters:
        - type: object
          mapping: $.
  - type: mcp
    namespace: palo-alto-sase-iam-access-policies-mcp
    port: 9090
    transport: http
    description: MCP adapter for Palo Alto Networks SASE IAM Service API — Access Policies. One tool per consumed operation,
      routed inline through this capability's consumes block.
    tools:
    - name: palo-alto-networks-list-access
      description: Palo Alto Networks List Access Policies
      hints:
        readOnly: true
        destructive: false
        idempotent: true
      call: palo-alto-sase-iam-access-policies.listaccesspolicies
      with:
        principal_id: tools.principal_id
        tsg_id: tools.tsg_id
        offset: tools.offset
        limit: tools.limit
      outputParameters:
      - type: object
        mapping: $.
    - name: palo-alto-networks-create-access
      description: Palo Alto Networks Create Access Policy
      hints:
        readOnly: false
        destructive: false
        idempotent: false
      call: palo-alto-sase-iam-access-policies.createaccesspolicy
      with:
        body: tools.body
      outputParameters:
      - type: object
        mapping: $.
    - name: palo-alto-networks-get-access
      description: Palo Alto Networks Get Access Policy
      hints:
        readOnly: true
        destructive: false
        idempotent: true
      call: palo-alto-sase-iam-access-policies.getaccesspolicy
      with:
        id: tools.id
      outputParameters:
      - type: object
        mapping: $.
    - name: palo-alto-networks-update-access
      description: Palo Alto Networks Update Access Policy
      hints:
        readOnly: false
        destructive: false
        idempotent: true
      call: palo-alto-sase-iam-access-policies.updateaccesspolicy
      with:
        id: tools.id
        body: tools.body
      outputParameters:
      - type: object
        mapping: $.
    - name: palo-alto-networks-delete-access
      description: Palo Alto Networks Delete Access Policy
      hints:
        readOnly: false
        destructive: true
        idempotent: true
      call: palo-alto-sase-iam-access-policies.deleteaccesspolicy
      with:
        id: tools.id
      outputParameters:
      - type: object
        mapping: $.