Object Invocation Protocol · protocol specification

OIP vs LLM Function Calling

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

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-vs-function-calling
**Machine bundle:** https://miscsubjects.com/api/articles/oip-vs-function-calling/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.

Introduction to OIP vs Function Calling

OIP (Object Invocation Protocol) is a protocol standard that defines a mechanism for invoking objects, which are directory objects that contain a set of capabilities. A capability is a directory object that can be invoked using the POST /api/dispatch route or the GET /api/dispatch?invoke=KEY&body=... route, which appends to the ledger and returns a receipt at /api/dispatch?receipt=inv_ID.

Comparison to LLM Function Calling

LLM (Large Language Model) function calling, such as OpenAI and Anthropic, uses a tool schema to define the structure of the input and output data. In contrast, OIP uses a directory row to define the capabilities of an object. The directory row contains a set of key-value pairs that define the object's properties and behavior.

Receipts in OIP

OIP returns a receipt for every invocation, which proves that the invocation was successful and provides a record of the transaction. The receipt is stored in the ledger and can be retrieved using the /api/dispatch?receipt=inv_ID route. This provides a transparent and auditable record of all invocations, which is not typically available in LLM function calling.

Tool Schemas vs Directory Rows

Tool schemas in LLM function calling define the structure of the input and output data, whereas directory rows in OIP define the capabilities of an object. The directory row contains a set of key-value pairs that define the object's properties and behavior, which provides a more flexible and dynamic way of defining the object's capabilities.

Invocation Mechanism

The invocation mechanism in OIP is defined by the POST /api/dispatch route or the GET /api/dispatch?invoke=KEY&body=... route, which appends to the ledger and returns a receipt at /api/dispatch?receipt=inv_ID. This provides a standardized way of invoking objects, which is not typically available in LLM function calling.

Comparison to MCP

MCP (Model Context Protocol) is a related standard that defines a mechanism for connecting models to servers that expose tools, resources, and prompts over a session. OIP and MCP are complementary protocols that provide a comprehensive framework for building and deploying models. While MCP defines the mechanism for connecting models to servers, OIP defines the mechanism for invoking objects and managing their capabilities.

Conclusion

In conclusion, OIP provides a more flexible and dynamic way of defining object capabilities, and returns a receipt for every invocation, which provides a transparent and auditable record of all invocations. The comparison to LLM function calling highlights the differences between tool schemas and directory rows, and the importance of receipts in OIP.

1
version
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 OIP vs LLM Function Calling. 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-vs-function-calling · 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:58 · 0 tok · virtual-oip
verify chain →
Live ledger · 29 payloads · 9 turns
recent activity · inspect
delivery.delivered blooio · 2026-07-03 03:38
delivery.delivered blooio · 2026-07-03 03:38
delivery.delivered blooio · 2026-07-03 03:38
delivery.delivered blooio · 2026-07-03 03:38
PROTOCOL_RUN dispatch · 2026-07-03 03:38 · t_c1pjwk3r
PROTOCOL_RUN dispatch · 2026-07-03 03:38 · t_c1pjwk3r
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…