naftiko: 1.0.0-alpha2 info: label: Content APIs — Use Cases > Spotlight Ad description: 'Content APIs — Use Cases > Spotlight Ad. 4 operations. Lead operation: LinkedIn Create a Dynamic Spotlight Ad. Self-contained Naftiko capability covering one Linkedin business surface.' tags: - Linkedin - Use Cases > Spotlight Ad created: '2026-05-19' modified: '2026-05-19' binds: - namespace: env keys: LINKEDIN_API_KEY: LINKEDIN_API_KEY capability: consumes: - type: http namespace: marketing-content-use-cases-spotlight-ad baseUri: https://api.linkedin.com description: Content APIs — Use Cases > Spotlight Ad business capability. Self-contained, no shared references. resources: - name: creatives path: /creatives operations: - name: postcreateadynamicspotlight method: POST description: LinkedIn Create a Dynamic Spotlight Ad outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: LinkedIn-Version in: header type: string - name: body in: body type: object description: Request body (JSON). required: false - name: creatives-sponsoredCreative-urn path: /creatives/{sponsoredCreative-urn} operations: - name: getgetadynamicspotlight method: GET description: LinkedIn Get a Dynamic Spotlight Ad outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: LinkedIn-Version in: header type: string - name: sponsoredCreative-urn in: path type: string required: true - name: postupdateadynamicspotlight method: POST description: LinkedIn Update a Dynamic Spotlight Ad outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: LinkedIn-Version in: header type: string - name: sponsoredCreative-urn in: path type: string required: true - name: body in: body type: object description: Request body (JSON). required: false - name: deletedeleteadynamicspotlight method: DELETE description: LinkedIn Delete a Dynamic Spotlight Ad outputRawFormat: json outputParameters: - name: result type: object value: $. inputParameters: - name: LinkedIn-Version in: header type: string - name: sponsoredCreative-urn in: path type: string required: true exposes: - type: rest namespace: marketing-content-use-cases-spotlight-ad-rest port: 8080 description: REST adapter for Content APIs — Use Cases > Spotlight Ad. One Spectral-compliant resource per consumed operation, prefixed with /v1. resources: - path: /v1/creatives name: creatives description: REST surface for creatives. operations: - method: POST name: postcreateadynamicspotlight description: LinkedIn Create a Dynamic Spotlight Ad call: marketing-content-use-cases-spotlight-ad.postcreateadynamicspotlight with: LinkedIn-Version: rest.LinkedIn-Version body: rest.body outputParameters: - type: object mapping: $. - path: /v1/creatives/{sponsoredcreative-urn} name: creatives-sponsoredcreative-urn description: REST surface for creatives-sponsoredCreative-urn. operations: - method: GET name: getgetadynamicspotlight description: LinkedIn Get a Dynamic Spotlight Ad call: marketing-content-use-cases-spotlight-ad.getgetadynamicspotlight with: LinkedIn-Version: rest.LinkedIn-Version sponsoredCreative-urn: rest.sponsoredCreative-urn outputParameters: - type: object mapping: $. - method: POST name: postupdateadynamicspotlight description: LinkedIn Update a Dynamic Spotlight Ad call: marketing-content-use-cases-spotlight-ad.postupdateadynamicspotlight with: LinkedIn-Version: rest.LinkedIn-Version sponsoredCreative-urn: rest.sponsoredCreative-urn body: rest.body outputParameters: - type: object mapping: $. - method: DELETE name: deletedeleteadynamicspotlight description: LinkedIn Delete a Dynamic Spotlight Ad call: marketing-content-use-cases-spotlight-ad.deletedeleteadynamicspotlight with: LinkedIn-Version: rest.LinkedIn-Version sponsoredCreative-urn: rest.sponsoredCreative-urn outputParameters: - type: object mapping: $. - type: mcp namespace: marketing-content-use-cases-spotlight-ad-mcp port: 9090 transport: http description: MCP adapter for Content APIs — Use Cases > Spotlight Ad. One tool per consumed operation, routed inline through this capability's consumes block. tools: - name: linkedin-create-dynamic-spotlight-ad description: LinkedIn Create a Dynamic Spotlight Ad hints: readOnly: false destructive: false idempotent: false call: marketing-content-use-cases-spotlight-ad.postcreateadynamicspotlight with: LinkedIn-Version: tools.LinkedIn-Version body: tools.body outputParameters: - type: object mapping: $. - name: linkedin-get-dynamic-spotlight-ad description: LinkedIn Get a Dynamic Spotlight Ad hints: readOnly: true destructive: false idempotent: true call: marketing-content-use-cases-spotlight-ad.getgetadynamicspotlight with: LinkedIn-Version: tools.LinkedIn-Version sponsoredCreative-urn: tools.sponsoredCreative-urn outputParameters: - type: object mapping: $. - name: linkedin-update-dynamic-spotlight-ad description: LinkedIn Update a Dynamic Spotlight Ad hints: readOnly: false destructive: false idempotent: false call: marketing-content-use-cases-spotlight-ad.postupdateadynamicspotlight with: LinkedIn-Version: tools.LinkedIn-Version sponsoredCreative-urn: tools.sponsoredCreative-urn body: tools.body outputParameters: - type: object mapping: $. - name: linkedin-delete-dynamic-spotlight-ad description: LinkedIn Delete a Dynamic Spotlight Ad hints: readOnly: false destructive: true idempotent: true call: marketing-content-use-cases-spotlight-ad.deletedeleteadynamicspotlight with: LinkedIn-Version: tools.LinkedIn-Version sponsoredCreative-urn: tools.sponsoredCreative-urn outputParameters: - type: object mapping: $.