GitHub · Capability
github-repos-api — Releases
github-repos-api — Releases. 8 operations. Lead operation: GitHub List Releases. Self-contained Naftiko capability covering one Github business surface.
What You Can Do
GET
Listreleases
— GitHub List Releases
/v1/repos/{owner}/{repo}/releases
POST
Createrelease
— GitHub Create Release
/v1/repos/{owner}/{repo}/releases
POST
Generatereleasenotescontentforrelease
— GitHub Generate Release Notes Content for Release
/v1/repos/{owner}/{repo}/releases/generate-notes
GET
Getthelatestrelease
— GitHub Get the Latest Release
/v1/repos/{owner}/{repo}/releases/latest
GET
Getreleasebytagname
— GitHub Get Release by Tag Name
/v1/repos/{owner}/{repo}/releases/tags/{tag}
GET
Getrelease
— GitHub Get Release
/v1/repos/{owner}/{repo}/releases/{release-id}
PATCH
Updaterelease
— GitHub Update Release
/v1/repos/{owner}/{repo}/releases/{release-id}
DELETE
Deleterelease
— GitHub Delete Release
/v1/repos/{owner}/{repo}/releases/{release-id}
MCP Tools
github-list-releases
GitHub List Releases
read-only
idempotent
github-create-release
GitHub Create Release
github-generate-release-notes-content
GitHub Generate Release Notes Content for Release
github-get-latest-release
GitHub Get the Latest Release
read-only
idempotent
github-get-release-tag-name
GitHub Get Release by Tag Name
read-only
idempotent
github-get-release
GitHub Get Release
read-only
idempotent
github-update-release
GitHub Update Release
idempotent
github-delete-release
GitHub Delete Release
idempotent
Capability Spec
naftiko: 1.0.0-alpha2
info:
label: github-repos-api — Releases
description: 'github-repos-api — Releases. 8 operations. Lead operation: GitHub List Releases. Self-contained Naftiko capability
covering one Github business surface.'
tags:
- Github
- Releases
created: '2026-05-19'
modified: '2026-05-19'
binds:
- namespace: env
keys:
GITHUB_API_KEY: GITHUB_API_KEY
capability:
consumes:
- type: http
namespace: repos-releases
baseUri: http://localhost:8080/rest/github-repos-api/1.1.4
description: github-repos-api — Releases business capability. Self-contained, no shared references.
resources:
- name: repos-owner-repo-releases
path: /repos/{owner}/{repo}/releases
operations:
- name: listreleases
method: GET
description: GitHub List Releases
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
- name: createrelease
method: POST
description: GitHub Create Release
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
- name: body
in: body
type: object
description: Request body (JSON).
required: true
- name: repos-owner-repo-releases-generate-notes
path: /repos/{owner}/{repo}/releases/generate-notes
operations:
- name: generatereleasenotescontentforrelease
method: POST
description: GitHub Generate Release Notes Content for Release
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
- name: body
in: body
type: object
description: Request body (JSON).
required: true
- name: repos-owner-repo-releases-latest
path: /repos/{owner}/{repo}/releases/latest
operations:
- name: getthelatestrelease
method: GET
description: GitHub Get the Latest Release
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
- name: repos-owner-repo-releases-tags-tag
path: /repos/{owner}/{repo}/releases/tags/{tag}
operations:
- name: getreleasebytagname
method: GET
description: GitHub Get Release by Tag Name
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: tag
in: path
type: string
description: tag parameter
required: true
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
- name: repos-owner-repo-releases-release_id
path: /repos/{owner}/{repo}/releases/{release_id}
operations:
- name: getrelease
method: GET
description: GitHub Get Release
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
- name: updaterelease
method: PATCH
description: GitHub Update Release
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
- name: body
in: body
type: object
description: Request body (JSON).
required: false
- name: deleterelease
method: DELETE
description: GitHub Delete Release
outputRawFormat: json
outputParameters:
- name: result
type: object
value: $.
inputParameters:
- name: Authorization
in: header
type: string
- name: X-GitHub-Api-Version
in: header
type: string
- name: Accept
in: header
type: string
authentication:
type: bearer
token: '{{env.GITHUB_API_KEY}}'
exposes:
- type: rest
namespace: repos-releases-rest
port: 8080
description: REST adapter for github-repos-api — Releases. One Spectral-compliant resource per consumed operation, prefixed
with /v1.
resources:
- path: /v1/repos/{owner}/{repo}/releases
name: repos-owner-repo-releases
description: REST surface for repos-owner-repo-releases.
operations:
- method: GET
name: listreleases
description: GitHub List Releases
call: repos-releases.listreleases
with:
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
outputParameters:
- type: object
mapping: $.
- method: POST
name: createrelease
description: GitHub Create Release
call: repos-releases.createrelease
with:
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
body: rest.body
outputParameters:
- type: object
mapping: $.
- path: /v1/repos/{owner}/{repo}/releases/generate-notes
name: repos-owner-repo-releases-generate-notes
description: REST surface for repos-owner-repo-releases-generate-notes.
operations:
- method: POST
name: generatereleasenotescontentforrelease
description: GitHub Generate Release Notes Content for Release
call: repos-releases.generatereleasenotescontentforrelease
with:
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
body: rest.body
outputParameters:
- type: object
mapping: $.
- path: /v1/repos/{owner}/{repo}/releases/latest
name: repos-owner-repo-releases-latest
description: REST surface for repos-owner-repo-releases-latest.
operations:
- method: GET
name: getthelatestrelease
description: GitHub Get the Latest Release
call: repos-releases.getthelatestrelease
with:
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
outputParameters:
- type: object
mapping: $.
- path: /v1/repos/{owner}/{repo}/releases/tags/{tag}
name: repos-owner-repo-releases-tags-tag
description: REST surface for repos-owner-repo-releases-tags-tag.
operations:
- method: GET
name: getreleasebytagname
description: GitHub Get Release by Tag Name
call: repos-releases.getreleasebytagname
with:
tag: rest.tag
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
outputParameters:
- type: object
mapping: $.
- path: /v1/repos/{owner}/{repo}/releases/{release-id}
name: repos-owner-repo-releases-release-id
description: REST surface for repos-owner-repo-releases-release_id.
operations:
- method: GET
name: getrelease
description: GitHub Get Release
call: repos-releases.getrelease
with:
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
outputParameters:
- type: object
mapping: $.
- method: PATCH
name: updaterelease
description: GitHub Update Release
call: repos-releases.updaterelease
with:
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
body: rest.body
outputParameters:
- type: object
mapping: $.
- method: DELETE
name: deleterelease
description: GitHub Delete Release
call: repos-releases.deleterelease
with:
Authorization: rest.Authorization
X-GitHub-Api-Version: rest.X-GitHub-Api-Version
Accept: rest.Accept
outputParameters:
- type: object
mapping: $.
- type: mcp
namespace: repos-releases-mcp
port: 9090
transport: http
description: MCP adapter for github-repos-api — Releases. One tool per consumed operation, routed inline through this
capability's consumes block.
tools:
- name: github-list-releases
description: GitHub List Releases
hints:
readOnly: true
destructive: false
idempotent: true
call: repos-releases.listreleases
with:
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
outputParameters:
- type: object
mapping: $.
- name: github-create-release
description: GitHub Create Release
hints:
readOnly: false
destructive: false
idempotent: false
call: repos-releases.createrelease
with:
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
body: tools.body
outputParameters:
- type: object
mapping: $.
- name: github-generate-release-notes-content
description: GitHub Generate Release Notes Content for Release
hints:
readOnly: false
destructive: false
idempotent: false
call: repos-releases.generatereleasenotescontentforrelease
with:
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
body: tools.body
outputParameters:
- type: object
mapping: $.
- name: github-get-latest-release
description: GitHub Get the Latest Release
hints:
readOnly: true
destructive: false
idempotent: true
call: repos-releases.getthelatestrelease
with:
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
outputParameters:
- type: object
mapping: $.
- name: github-get-release-tag-name
description: GitHub Get Release by Tag Name
hints:
readOnly: true
destructive: false
idempotent: true
call: repos-releases.getreleasebytagname
with:
tag: tools.tag
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
outputParameters:
- type: object
mapping: $.
- name: github-get-release
description: GitHub Get Release
hints:
readOnly: true
destructive: false
idempotent: true
call: repos-releases.getrelease
with:
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
outputParameters:
- type: object
mapping: $.
- name: github-update-release
description: GitHub Update Release
hints:
readOnly: false
destructive: false
idempotent: true
call: repos-releases.updaterelease
with:
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
body: tools.body
outputParameters:
- type: object
mapping: $.
- name: github-delete-release
description: GitHub Delete Release
hints:
readOnly: false
destructive: true
idempotent: true
call: repos-releases.deleterelease
with:
Authorization: tools.Authorization
X-GitHub-Api-Version: tools.X-GitHub-Api-Version
Accept: tools.Accept
outputParameters:
- type: object
mapping: $.