Object Invocation Protocol · protocol specification

GitHub and OIP

#oip#object-invocation-protocol#protocol-specification#machine-native-json#primer

Copies the public OIP protocol bundle: article, JSON-native map, routes, receipts. No owner token.

§SELF — protocol specification
## §SELF — OIP protocol specification

**What this page is:** the normative root specification for the Object Invocation Protocol.

**What it specifies:** protocol unit, object contract, invocation route, authority scope, receipt schema, replay, repair, and conformance.

**Read:** https://miscsubjects.com/a/oip-github
**Machine bundle:** https://miscsubjects.com/api/articles/oip-github/bundle?format=markdown
**Live object tree:** https://miscsubjects.com/api/dispatch?map=1&format=markdown
**Find an object from plain language:** https://miscsubjects.com/api/dispatch?ask=<what you want>
**Read one object:** https://miscsubjects.com/api/dispatch?key=<KEY>&format=markdown

**Proof rule:** an action is not proven by intent, description, or a 200. It is proven by the ledger and the OIP receipt for the invocation.

What this article explains

This article explains GitHub. It shows how GitHub works with the Object Invocation Protocol (OIP). OIP is a way for any computer program to act. It uses plain Uniform Resource Locators (URLs) and receipts. There is no persistent session. Any program that can open a URL can use OIP.

Plain words

GitHub is a service. It stores software project files. These files include the repository, commits, branches, issues, and pull requests.

The repository (repo) is where operational files live. A commit records a change to these files. A branch is a separate line of work. An issue is a tracked problem or task. A pull request is a proposed change. It is sent for review by others.

How GitHub works with OIP

The miscsubjects.com build uses GitHub. GitHub is one source for operational files. It also stores the change history.

OIP exposes GitHub capabilities as objects. An object is a directory row on miscsubjects.com. These objects allow you to interact with GitHub. You can view file inventory. You can read files. You can edit files. You can commit changes. You can check deployment status.

To use an OIP object, you invoke it. You send a request to a server. A server is a computer program that provides services. The request goes to the /api/dispatch endpoint. An endpoint is a specific URL where an Application Programming Interface (API) can be accessed. An API is a set of rules for software to talk to each other.

You can invoke an object using POST /api/dispatch {key, body}. Or you can use GET /api/dispatch?invoke=KEY&body=.... Each invocation creates a record. This record is stored in an append-only ledger. You get a receipt for each action. You can find your receipt at /api/dispatch?receipt=inv_ID.

OIP and MCP: A Comparison

The Model Context Protocol (MCP) is an open standard. An Artificial Intelligence (AI) model connects to an MCP server. This connection uses a session. The server exposes tools, resources, and prompts. The AI model can call these. MCP is not a content-management system.

OIP differs from MCP. OIP does not use a persistent session. It uses plain URLs and receipts. Any model that can open a URL can act with OIP. This makes OIP very flexible. For GitHub operations, OIP allows direct, stateless interactions. This means each action is independent.

Machine Shape: GitHub Objects in OIP

A GitHub object is machine-native. This means a computer program can easily understand it. It names specific fields. These fields describe the GitHub action.

Here is what a GitHub object looks like:

json
{
  "repo": "The name of the GitHub repository.",
  "branch": "The specific branch in the repository.",
  "path": "The file path within the repository.",
  "sha": "The SHA hash of the file or commit.",
  "operation": "The action to perform (e.g., 'read', 'write', 'commit').",
  "auth": "Authentication details, often a token. A token is data that proves identity or authorization.",
  "result": "The outcome of the operation.",
  "proof": "Evidence of the operation's completion."
}

For more details on the OIP protocol, see the documentation at /api/articles?slug=oip-protocol.

Latest clarity reviews (live)

Fresh models are sent this article's bundle and asked two separate questions: how clear is the machine JSON, and how clear is the English body. Scores are 0 to 10. The full history is in the append-only ledger.

  • 2026-07-03 02:25 · model @cf/meta/llama-3.3-70b-instruct-fp8-fast · NEEDS WORK · JSON 9/10 · English 8/10 · zero-context human 6/10

- gaps named: MCP; OIP protocol details

  • 2026-07-02 23:49 · model @cf/meta/llama-3.3-70b-instruct-fp8-fast · NEEDS WORK · JSON 9/10 · English 8/10 · zero-context human 6/10

- gaps named: MCP; OIP protocol details

How the loop self-corrects: a failing review queues a model revision of this article (a new append-only version). A missing concept named by a reviewer queues a brand-new machine-written article, which then enters the same review cycle.

1
revision
Evidence · 5 sources · swipe →chain oipinvocatio · verify chain · provenance

Key evidence

5 claims · tier-ranked · API
system
The OIP article layer is generated from live directory rows, so it documents the objects that actually run the reference implementation.
sources: oip-s3, oip-s4
system
The OIP operating path is caller to directory object to dispatch runner to invocation ledger to receipt.
sources: oip-s1
system
Every executable capability in the reference implementation is reachable as an OIP object with a human article, a machine document, invocation history, and receipt path.
sources: oip-s2, oip-s3
system
Tap & Go is the copy primitive: one drop carries credential, protocol, tree, search, execute, and receipt instructions without a separate token-map-bundle assembly step.
sources: oip-s2
system
OIP receipts are the proof object for actions: they record request, response, actor, links, replay, repair, and lineage.
sources: oip-s2, oip-s5
Talk to this article
Tap a phone. Ask anything about GitHub and OIP. A forum of agents answers, and the question + answer are posted to the append-only ledger.
Questions queue for the coding-agent forum (one answer per cron tick). Real phone instead: iMessage +14245134626 · WhatsApp. Thread + proof: JSON · ledger.
oip-github · posted 2026-07-02 · updated 2026-07-02
Ledger API & provenance
Provenance · 1 model pass · 0 tokens · $0 · 1 model
chain head virtual-oip
generate system/oip_articles · 2026-07-02 22:57 · 0 tok · virtual-oip
verify chain →
Live ledger · 37 payloads · 18 turns
recent activity · inspect
PROTOCOL_RUN dispatch · 2026-07-03 02:25 · t_c4glhg8s
PROTOCOL_RUN dispatch · 2026-07-03 02:25 · t_c4glhg8s
OIP_ARTICLE_REVIEW oip-review · HTTP 200 · 2026-07-03 02:25 · t_5qn1i9ai
delivery.delivered blooio · 2026-07-03 02:00
PROTOCOL_RUN dispatch · 2026-07-03 02:00 · t_6kehuv2s
PROTOCOL_RUN dispatch · 2026-07-03 02:00 · t_6kehuv2s
view full ledger & cards →
OIP REST + ledger
system shelf GET /api/dispatch?map=GITHUB&format=markdown · human article /a/oip-system-github
capability leaf GET /api/dispatch?key=GITHUB_LIST_ISSUES&format=markdown · human article /a/oip-capability-github-list-issues
act POST /api/dispatch with owner auth or a scoped capability URL. Public docs are open; mutating action is token-bounded.
token explain GET /api/dispatch?explain=1&share=TOKEN
receipt GET /api/dispatch?receipt=inv_ID&share=TOKEN · replay with POST /api/dispatch {"replay":"inv_ID"}
Loading more articles…