{"id":34070923,"url":"https://github.com/blueraai/agentic-web-protocol","last_synced_at":"2026-03-10T02:32:50.002Z","repository":{"id":295291101,"uuid":"989341123","full_name":"blueraai/agentic-web-protocol","owner":"blueraai","description":"AWP | Agentic Web Protocol: Discoverable Websites and APIs, for AI Agents interactions","archived":false,"fork":false,"pushed_at":"2025-05-29T21:04:36.000Z","size":604,"stargazers_count":17,"open_issues_count":0,"forks_count":2,"subscribers_count":1,"default_branch":"main","last_synced_at":"2026-03-03T16:56:38.186Z","etag":null,"topics":["agentic","agentic-ai","agentic-protocol","agentic-web","agentic-web-protocol","awp","discoverable","discoverable-api","discoverable-web","discoverable-webpages","discoverable-websites","uin","universal-intelligence","web3"],"latest_commit_sha":null,"homepage":"https://wiki.bluera.ai","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/blueraai.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null},"funding":{"github":"blueraai","patreon":null,"open_collective":null,"ko_fi":null,"tidelift":null,"community_bridge":null,"liberapay":null,"issuehunt":null,"lfx_crowdfunding":null,"polar":null,"buy_me_a_coffee":null,"thanks_dev":null,"custom":null}},"created_at":"2025-05-23T22:59:11.000Z","updated_at":"2026-03-01T02:17:50.000Z","dependencies_parsed_at":"2025-05-24T18:24:10.804Z","dependency_job_id":"a45934d1-93f9-4221-bd10-b6febdcb38df","html_url":"https://github.com/blueraai/agentic-web-protocol","commit_stats":null,"previous_names":["blueraai/agentic-web-protocol"],"tags_count":1,"template":false,"template_full_name":null,"purl":"pkg:github/blueraai/agentic-web-protocol","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blueraai%2Fagentic-web-protocol","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blueraai%2Fagentic-web-protocol/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blueraai%2Fagentic-web-protocol/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blueraai%2Fagentic-web-protocol/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/blueraai","download_url":"https://codeload.github.com/blueraai/agentic-web-protocol/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blueraai%2Fagentic-web-protocol/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":30322645,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-10T01:36:58.598Z","status":"online","status_checked_at":"2026-03-10T02:00:06.579Z","response_time":106,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["agentic","agentic-ai","agentic-protocol","agentic-web","agentic-web-protocol","awp","discoverable","discoverable-api","discoverable-web","discoverable-webpages","discoverable-websites","uin","universal-intelligence","web3"],"created_at":"2025-12-14T07:40:23.495Z","updated_at":"2026-03-10T02:32:49.976Z","avatar_url":"https://github.com/blueraai.png","language":"Python","funding_links":["https://github.com/sponsors/blueraai"],"categories":[],"sub_categories":[],"readme":"![awp-banner](https://fasplnlepuuumfjocrsu.supabase.co/storage/v1/object/public/web-assets//awp-banner-rsmrx.png)\n\n\u003cp align=\"center\"\u003e\n    \u003ca href=\"https://github.com/blueraai/agentic-web-protocol/releases\"\u003e\u003cimg alt=\"GitHub Release\" src=\"https://img.shields.io/github/release/blueraai/agentic-web-protocol.svg?color=1c4afe\"\u003e\u003c/a\u003e\n    \u003ca href=\"https://github.com/blueraai/agentic-web-protocol/blob/main/LICENSE\"\u003e\u003cimg alt=\"License\" src=\"https://img.shields.io/github/license/blueraai/agentic-web-protocol.svg?color=00bf49\"\u003e\u003c/a\u003e\n    \u003ca href=\"https://discord.gg/7g9SrEc5yT\"\u003e\u003cimg alt=\"Discord\" src=\"https://img.shields.io/badge/Join-Discord-7289DA?logo=discord\u0026logoColor=white\u0026color=4911ff\"\u003e\u003c/a\u003e\n\u003c/p\u003e\n\n\u003e ![lng_icon](https://fasplnlepuuumfjocrsu.supabase.co/storage/v1/object/public/web-assets//icons8-python-16.png) This page aims to document **Python** protocols and usage (e.g. cloud, desktop).\n\u003e\n\u003e Looking for [**Javascript/Typescript instructions**](https://github.com/blueraai/agentic-web-protocol/blob/main/README_WEB.md)?\n\n## Overview\n\nThe `Agentic Web Protocol`, or `AWP`, *allows **AI agents** to reliably **understand and interact with the web***.\n\nIt is composed of two protocols, for web pages and APIs, allowing them to be usable by AI agents.\n\nA standard [Universal Tool](https://github.com/blueraai/universal-intelligence) is also provided, for AI agents to be able to instantly leverage `AWP` compliant pages and APIs.\n\n\u003e 🤖 Discoverable Websites and APIs, for AI Agents interactions. [Bluera Inc.](https://bluera.ai)\n\n## Get Started\n\nLearn more about how to support `AWP`, by clicking the most appropriate option for you:\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong style=\"display: inline; cursor: pointer; margin: 0; padding: 0;\"\u003eI make websites or APIs, what do I need to do?\u003c/strong\u003e\u003c/summary\u003e\n\n##### Websites\n\n- See the `AWP` *Protocol Specifications* below, and familiarize yourself with the standard `ai` parameters\n- Add the appropriate `ai` parameters to your website.\n\n\u003e 🎉 Your website can be reliably used by any AI agent!\n\n##### APIs\n\n- See the `AWP` *Protocol Specifications* below, and familiarize yourself with the standard `/ai-handshake` endpoint\n- Add the standard `/ai-handshake` endpoint to your API.\n\n\u003e 🎉 Your API can be reliably used by any AI agent!\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong style=\"display: inline; cursor: pointer; margin: 0; padding: 0;\"\u003eI make/use AI Agents, what do I need to do?\u003c/strong\u003e\u003c/summary\u003e\n\u003cbr\u003e\n\n- See the `AWP` *Tool* below, and familiarize yourself with its `parse_html` and `parse_api` methods.\n- Add the `AWP` *Tool* to your AI Agent.\n\n\u003e 🎉 Your AI agent can now reliably use any `AWP` compliant websites or APIs!\n\n\u003c/details\u003e\n\n## Documentation\n\n\u003e Would you rather [**chat with our docs**](https://wiki.bluera.ai)? 💬\n\u003e \n\u003e *Note: AI responses may include mistakes. Refer to the documentation below for sample code.*\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong style=\"display: inline; cursor: pointer; margin: 0; padding: 0;\"\u003eProtocol Specifications\u003c/strong\u003e\u003c/summary\u003e\n\n## Protocol Specifications\n\n### Web pages\n\n#### Introduction\n\n\u003e ##### The Challenge of Web Interactivity for AI Agents\n\u003e \n\u003e Without information about what a web page is for, how it is structured, what features it provides, and how to interact with it, an AI agent has to figure out everything on its own.\n\u003e\n\u003e This is commonly done through scrappers and/or vision models aimed at guessing what the agent sees.\n\u003e\n\u003e Websites being diverse, complex, dynamic, Javascript-heavy and often moslty made of generic `\u003cdiv\u003e`s, this exercise commonly leads to unreliable parsing and broken/unintended interactions.\n\u003e\n\u003e Intelligent agents need richer semantic hints to parse and interact with these pages reliably.\n\nThe premise of `AWP` is simple: **include standard information in the HTML page** itself, for **any agent to be able to reliably understand and interact** with it.\n\nFor an agent to so, the following information needs to be attached to *meaninful* and/or *interactive* HTML tags:\n\n1. A `description`, for it to know what it is.\n2. A list of possible `interactions`, for it to know what to do.\n3. A list of `prerequisites`, for it to know what to do prior to interacting.\n4. A list of subsequent `features`, for it to know what those interactions lead to.\n\nAdditional optional information such as `states`, or established *accessibility* parameters (eg. `role`, `aria-*`) may also be used to complement the agent's understanding of the page.\n\n#### Contract\n\nLet's start with a simple example. Your agent just found this website by crawling the web:\n\n```html\n\u003chtml\u003e\n  \u003cbody\u003e\n    \u003cform\u003e\n      This site uses cookies\n      \u003cbutton\u003eConfigure\u003c/button\u003e\n    \u003c/form\u003e\n    \u003cform\u003e\n      \u003ch1\u003e Website name \u003c/h1\u003e\n      \u003clabel\u003e What's next? \u003c/label\u003e\n      \u003cinput\n        type=\"text\"\n        name=\"destination\"\n        required\n        minlength=\"3\"\n        maxlength=\"30\"/\u003e\n      \u003cdiv\u003e\n        \u003cbutton disabled\u003e -\u003e \u003c/button\u003e\n        \u003cbutton\u003e Back \u003c/button\u003e\n      \u003c/div\u003e\n    \u003c/form\u003e\n  \u003c/body\u003e\n\u003c/html\u003e\n```\n\nIt now needs to *understand what it is for*, to know if it can be used to answer your query, and if so, *how to interact* with it?\n\nFor all reasons described above, this often becomes a difficult and error-prone task —leading to unintended behaviors and impairing the agent's ability to act reliably on our behalf.\n\nWith `AWP`, this information is now declared in the HTML itself, through standard ***optional*** `ai-*` attributes.\n\n```html\n\u003chtml ai-description=\"Travel site to book flights and trains\"\u003e\n  \u003cbody\u003e\n    \u003cform\u003e\n      This site uses cookies\n      \u003cbutton\u003eConfigure\u003c/button\u003e\n    \u003c/form\u003e\n    \u003cform ai-description=\"Form to book a flight\"\u003e\n      \u003ch1\u003e\n        Website name\n      \u003c/h1\u003e\n      \u003clabel\u003e\n        What's next?\n      \u003c/label\u003e\n      \u003cinput\n        ai-ref=\"\u003cinput-ai-ref\u003e\"\n        ai-description=\"Form input where to enter the destination\"\n        ai-interactions=\"input: enables the form confirmation button, given certain constraints;\"\n        type=\"text\"\n        name=\"destination\"\n        required\n        minlength=\"3\"\n        maxlength=\"30\"/\u003e\n      \u003cdiv\u003e\n        \u003cbutton\n          ai-description=\"Confirmation button to proceed with booking a flight\"\n          ai-interactions=\"click: proceed; hover: diplay additonal information about possible flights;\"\n          ai-prerequisite-click=\"\u003cinput-ai-ref\u003e: input the destination;\"\n          ai-next-click=\"list of available flights; book a flight; login;\"\n          disabled\u003e\n          -\u003e\n        \u003c/button\u003e\n        \u003cbutton\n          ai-description=\"Cancel button to get back to the home page\"\n          ai-interactions=\"click: dismiss form and return to home page;\"\n          ai-next-click=\"access forms to book trains; access forms to book flights;\"\u003e\n          Back\n        \u003c/button\u003e\n      \u003c/div\u003e\n    \u003c/form\u003e\n  \u003c/body\u003e\n\u003c/html\u003e\n```\n\n\u003e The web app can now be reliably **understood and used by *any* AI agents** 🙌\n\n##### Standard Parameters\n\n| Parameter | Description | Requirement |\n|--------|-------------|----------|\n| `ai-description` | A natural language description for agents to know what the element is | • Meaningful Element: `required`\u003cbr\u003e• Interactive Element: `required`\u003cbr\u003e• Other Element: `absent` |\n| `ai-interactions` | A list of possible interactions, for agents to know what to do with the element\u003cbr\u003e\u003cbr\u003eFormat:\u003cbr\u003e\u003cbr\u003e`\u003cinteraction\u003e: \u003cbehavior\u003e; \u003cinteraction\u003e: \u003cbehavior\u003e;..` | • Meaningful Element: `absent`\u003cbr\u003e• Interactive Element: `required`\u003cbr\u003e• Other Element: `absent` |\n| `ai-prerequisite-\u003cinteraction\u003e` | A list of prerequisite interactions, for agents to know what to do prior to interacting with the element\u003cbr\u003e\u003cbr\u003eFormat:\u003cbr\u003e\u003cbr\u003e`\u003cai-ref\u003e: \u003cinteraction\u003e;..` | • Meaningful Element: `absent`\u003cbr\u003e• Interactive Element: `optional`\u003cbr\u003e• Other Element: `absent` |\n| `ai-ref` | A unique identifier for agents to know where those prerequisite interactions should be made | • Meaningful Element: `absent`\u003cbr\u003e• Interactive Element: `optional`\u003cbr\u003e• Other Element: `absent` |\n| `ai-next-\u003cinteraction\u003e` | A list of subsequent features, for agents to know what those interactions lead to\u003cbr\u003e\u003cbr\u003eFormat:\u003cbr\u003e\u003cbr\u003e`\u003cnext feature\u003e; \u003cnext feature\u003e;..` | • Meaningful Element: `absent`\u003cbr\u003e• Interactive Element: `optional`\u003cbr\u003e• Other Element: `absent` |\n| `ai-state` | A natural language description of the state the component is in | • Meaningful Element: `optional`\u003cbr\u003e• Interactive Element: `optional`\u003cbr\u003e• Other Element: `optional` |\n\n\u003e An **AWP Tool** is also distributed by this library to allow any AI agent to reliably use `AWP` compliant websites.\n\n### APIs\n\n#### Introduction\n\n\u003e ##### The Challenge of API Interactivity for AI Agents\n\u003e\n\u003e Without information about what an API is for, how it is structured, what features it provides, and how to interact with it, an AI agent has to figure out everything on its own. \n\u003e\n\u003e This is commonly passed manually as context, fetched via web crawlers attempting to find documentation online, or by spinning up additional middleware servers (eg. [mcp](https://github.com/modelcontextprotocol)) to allow them to be discoverable.\n\nThe premise of `AWP` is simple: **include standard information in the API** itself, for **any agent to be able to reliably understand and interact** with it, without requiring additional middleware servers to do so.\n\nFor an agent to know how to use any API, the following information needs to be discoverable:\n\n1. A list of all each available `endpoints` on that API, to know what they are\n2. A `description` for each endpoint, to know what they are for\n3. `meta` information for each endpoint, to know how to access them\n4. An `input` documentation for each endpoint, to know what to provide\n5. An `output` documentation for each endpoint, to know what to expect\n\n#### Contract\n\nWith `AWP`, the API documentation is made accessible on the API itself, with a standard `/ai-handshake` endpoint.\n\nThis allows AI agents to query `/ai-handshake`, get a complete description of the API, and know how to further interact with it.\n\nFor simplicity, and since it is a well established standard on the web, the `AWP` expects a [OpenAPI](https://swagger.io/specification/) compliant documentation to be returned by that endpoint.\n\nHere is a simple example:\n[https://editor.swagger.io](https://editor.swagger.io)\n\n##### Standard Endpoint\n\n| Path | Description | Type | Method | Input | Output | Requirement |\n|--------|--------------------------------|----------|----------|----------|----------|----------|\n| `/ai-handshake` | Standard endpoint returning a [OpenAPI](https://swagger.io/specification/) compliant documentation of the API which hosts the endpoint, excluding `/ai-handshake`, JSON or YAML based on headers | REST | GET | Headers:\u003cbr\u003e\u003cbr\u003e`\"Content-Type\": \"application/yaml\"`(recommended)\u003cbr\u003eor\u003cbr\u003e`\"Content-Type\": \"application/json\"` | [OpenAPI](https://swagger.io/specification/) compliant documentation, of requested `Content-Type` (eg. YAML, JSON, text) | `required` |\n\n\u003e An **AWP Tool** is also distributed by this library to allow any AI agent to reliably use `AWP` compliant API.\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong style=\"display: inline; cursor: pointer; margin: 0; padding: 0;\"\u003eAWP Tool\u003c/strong\u003e\u003c/summary\u003e\n\n## AWP Tool\n\nThis project also shares a [Universal Tool](https://github.com/blueraai/universal-intelligence) for your agents to be able **reliably understand and interact with the AWP compliant Web pages and APIs**.\n\n\u003e For more information about `Universal Tools`, see [◉ Universal Intelligence](https://github.com/blueraai/universal-intelligence)\n\n### Installation\n\n```bash\npip install awp\n\n# (if using universal tool) Choose relevant UIN install for your device\npip install \"universal-intelligence[community,mps]\" # Apple\npip install \"universal-intelligence[community,cuda]\" # NVIDIA\n```\n\n### Usage\n\n#### Standard\n\n```python\nimport awp\n\n# Get HTML documentation\nhtml_doc = awp.parse_html(html)\n\n# Get API documentation\napi_doc = awp.parse_api(url)\n```\n\n| Method | Parameters | Return Type | Description |\n|--------|------------|-------------|-------------|\n| `parse_html` | • `html: str`: HTML page to parse\u003cbr\u003e• `format: str \\| None = \"YAML\"`: Output format | `Any` | Parses all AWP `ai-*` and accessibility attributes on the page and returns a documentation in the requested format (YAML, JSON), usable by any AI agent to reliably understand and interact with that web page |\n| `parse_api` | • `url: str`: URL of the API to parse\u003cbr\u003e• `authorization: str \\| None = None`: Authentication header if required\u003cbr\u003e• `format: str \\| None = \"YAML\"`: Output format | `Any` | Calls the standard `/ai-handshake` endpoint of that API and returns an [OpenAPI](https://swagger.io/specification/) compliant documentation of that API in the requested format (YAML, JSON), usable by any AI agent to reliably understand and interact with that API |\n\n#### As [Universal Tool](https://github.com/blueraai/universal-intelligence)\n\n```python\nfrom awp import UniversalTool as AWP\n\n# Get HTML documentation\nhtml_doc, logs = AWP().parse_html(html)\n\n# Get API documentation\napi_doc, logs = AWP().parse_api(url)\n```\n\n| Method | Parameters | Return Type | Description |\n|--------|------------|-------------|-------------|\n| `__init__` | • `verbose: bool \\| str = \"DEFAULT\"`: Enable/Disable logs, or set a specific log level | `None` | Initialize a Universal Tool |\n| `parse_html` | • `html: str`: HTML page to parse\u003cbr\u003e• `format: str \\| None = \"YAML\"`: Output format | `Tuple[Any, Dict]` | Parses all AWP `ai-*` and accessibility attributes on the page and returns a documentation in the requested format (YAML, JSON), usable by any AI agent to reliably understand and interact with that web page |\n| `parse_api` | • `url: str`: URL of the API to parse\u003cbr\u003e• `authorization: str \\| None = None`: Authentication header if required\u003cbr\u003e• `format: str \\| None = \"YAML\"`: Output format | `Tuple[Any, Dict]` | Calls the standard `/ai-handshake` endpoint of that API and returns an [OpenAPI](https://swagger.io/specification/) compliant documentation of that API in the requested format (YAML, JSON), usable by any AI agent to reliably understand and interact with that API |\n| `(class).contract` | None | `Contract` | Tool description and interface specification |\n| `(class).requirements` | None | `List[Requirement]` | Tool configuration requirements |\n\n#### Example Output\n\n##### Parse HTML\n\n###### Input\n\n```html\n\u003chtml ai-description=\"Travel site to book flights and trains\"\u003e\n  \u003cbody\u003e\n    \u003cform \n      ai-description=\"Form to book a flight\" \n      ai-state=\"pending\"\n      class=\"form-booking-flight\"\u003e\n      \u003ch1\u003e\n        Book a flight\n      \u003c/h1\u003e\n      \u003clabel\u003e\n        Where to?\n      \u003c/label\u003e\n      \u003cinput\n        ai-ref=\"\u003cinput-ai-ref\u003e\"\n        ai-description=\"Form input where to enter the destination\"\n        ai-interactions=\"input: enables the form confirmation button, given certain constraints;\"\n        role=\"destination-input\"\n        aria-required=\"true\"\n        alt=\"destination input\"\n        type=\"text\"\n        id=\"destination\"\n        name=\"destination\"\n        required\n        minlength=\"3\"\n        maxlength=\"30\"\n        size=\"10\" /\u003e\n      \u003cdiv\u003e\n        \u003cbutton\n          ai-description=\"Confirmation button to proceed with booking a flight\"\n          ai-interactions=\"click: proceed; hover: diplay additonal information about possible flights;\"\n          ai-prerequisite-click=\"\u003cinput-ai-ref\u003e: input destination;\"\n          ai-next-click=\"list of available flights; book a flight; login;\"\n          aria-disabled=\"true\"\n          disabled\u003e\n          See available flights\n        \u003c/button\u003e\n        \u003cbutton\n          ai-description=\"Cancel button to get back to the home page\"\n          ai-interactions=\"click: dismiss form and return to home page;\"\n          ai-next-click=\"access forms to book trains; access forms to book flights;\"\u003e\n          Back\n        \u003c/button\u003e\n      \u003c/div\u003e\n    \u003c/form\u003e\n  \u003c/body\u003e\n\u003c/html\u003e\n```\n\n###### Output\n\n```yaml\nelements:\n- selector: html\n  description: Travel site to book flights and trains\n  contains:\n  - selector: html body form.form-booking-flight\n    description: Form to book a flight\n    state: pending\n    content: Book a flight Where to?\n    contains:\n    - selector: html body form.form-booking-flight input#destination[name='destination'][type='text'][role='destination-input']\n      description: Form input where to enter the destination\n      available_interactions:\n      - type: input\n        description: enables the form confirmation button, given certain constraints\n      attributes:\n        name: destination\n        role: destination-input\n        alt: destination input\n        aria-required: 'true'\n        maxlength: 30\n        minlength: 3\n        required: true\n        type: text\n    - selector: html body form.form-booking-flight div button\n      description: Confirmation button to proceed with booking a flight\n      content: See available flights\n      available_interactions:\n      - type: click\n        description: proceed\n        prerequisites:\n        - selector: html body form.form-booking-flight input#destination[name='destination'][type='text'][role='destination-input']\n          interaction: input destination\n        next_features:\n        - list of available flights\n        - book a flight\n        - login\n      - type: hover\n        description: diplay additonal information about possible flights\n      attributes:\n        aria-disabled: 'true'\n    - selector: html body form.form-booking-flight div button:nth-of-type(2)\n      description: Cancel button to get back to the home page\n      content: Back\n      available_interactions:\n      - type: click\n        description: dismiss form and return to home page\n        next_features:\n        - access forms to book trains\n        - access forms to book flights\n```\n\n\u003e YAML (default) or JSON per requested format. \n\u003e \n\u003e YAML recommended for improved token efficiency and stability.\n\n##### Parse API\n\n###### Input\n\n`GET https//example.api.com/ai-handshake`\n\n###### Output\n\n[OpenAPI](https://swagger.io/specification/) compliant documentation, YAML (default) or JSON per requested format.\n\nExample available [here](https://editor.swagger.io).\n\n\u003e **Tip**: Tools like [Swagger](https://swagger.io) can automatically generate a [OpenAPI](https://swagger.io/specification/) compliant documentation for your API which you may serve at `/ai-handshake`. They usually also provide no-code UIs to display and interact wich that documentation on the web (eg. [Swagger UI](https://editor.swagger.io)).\n\n#### Playground\n\nA ready-made playground is available to help familiarize yourself with the AWP protocols and tools.\n\n```sh\n# Install project dependencies\npip install -r requirements.txt \n# Choose relevant UIN install for your device\npip install \"universal-intelligence[community,mps]\" # Apple\npip install \"universal-intelligence[community,cuda]\" # NVIDIA\n\n# Run\npython -m playground.example \n```\n\n### Cross-Platform Support\n\n![lng_icon](https://fasplnlepuuumfjocrsu.supabase.co/storage/v1/object/public/web-assets//icons8-python-16.png) ![lng_icon](https://fasplnlepuuumfjocrsu.supabase.co/storage/v1/object/public/web-assets//icons8-javascript-16.png) The `AWP` tool can be used across **all platforms** (cloud, desktop, web, mobile).\n\n- ![lng_icon](https://fasplnlepuuumfjocrsu.supabase.co/storage/v1/object/public/web-assets//icons8-python-16.png) [How to use natively with `python` (cloud, desktop)](https://github.com/blueraai/agentic-web-protocol/blob/main/README.md)\n- ![lng_icon](https://fasplnlepuuumfjocrsu.supabase.co/storage/v1/object/public/web-assets//icons8-javascript-16.png) [How to use on the web, or in web-native apps, with `javascript/typescript` (cloud, desktop, web, mobile)](https://github.com/blueraai/agentic-web-protocol/blob/main/README_WEB.md)\n\n\u003c/details\u003e\n\n## Support\n\nThis software is open source, free for everyone, and lives on thanks to the community's support ☕\n\nIf you'd like to support to `agentic-web-protocol` here are a few ways to do so:\n\n- ⭐ Consider leaving a star on this repository to support our team \u0026 help with visibility\n- 👽 Tell your friends and colleagues\n- 📰 Support this project on social medias (e.g. LinkedIn, Youtube, Medium, Reddit)\n- ✅ Adopt the `AWP` specification\n- 💪 Use the [AWP Tool](https://pypi.org/project/awp/)\n- 💡 Help surfacing/resolving issues\n- 💭 Help shape the `AWP` specification\n- 🔧 Help maintain, test, enhance the [AWP Tool](https://github.com/blueraai/agentic-web-protocol/blob/main/awp/)\n- ✉️ Email us security concerns\n- ❤️ Sponsor this project on Github\n- 🤝 [Partner with Bluera](mailto:contact@bluera.ai)\n\n\n## License\n\nApache 2.0 License - [Bluera Inc.](https://bluera.ai)","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fblueraai%2Fagentic-web-protocol","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fblueraai%2Fagentic-web-protocol","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fblueraai%2Fagentic-web-protocol/lists"}