api-operator 0.9.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,206 @@
1
+ Metadata-Version: 2.4
2
+ Name: api-operator
3
+ Version: 0.9.0
4
+ Summary: Standalone AI API Operator with pluggable adapters for multi-project APIs
5
+ Project-URL: Homepage, https://github.com/mohammedelkarsh/api-operator
6
+ Project-URL: Repository, https://github.com/mohammedelkarsh/api-operator
7
+ Project-URL: Issues, https://github.com/mohammedelkarsh/api-operator/issues
8
+ Project-URL: Changelog, https://github.com/mohammedelkarsh/api-operator/blob/main/CHANGELOG.md
9
+ Author: Mohammed Elkarsh
10
+ License-Expression: MIT
11
+ License-File: LICENSE
12
+ Keywords: agent,ai,llm,multi-tenant,openapi,saas,tools,yaml
13
+ Classifier: Development Status :: 4 - Beta
14
+ Classifier: Intended Audience :: Developers
15
+ Classifier: License :: OSI Approved :: MIT License
16
+ Classifier: Programming Language :: Python :: 3
17
+ Classifier: Programming Language :: Python :: 3.11
18
+ Classifier: Programming Language :: Python :: 3.12
19
+ Classifier: Programming Language :: Python :: 3.13
20
+ Classifier: Topic :: Software Development :: Libraries :: Python Modules
21
+ Requires-Python: >=3.11
22
+ Requires-Dist: fastapi>=0.111.0
23
+ Requires-Dist: httpx>=0.27.0
24
+ Requires-Dist: pydantic-settings>=2.3.0
25
+ Requires-Dist: pydantic>=2.7.0
26
+ Requires-Dist: pyyaml>=6.0.1
27
+ Requires-Dist: rich>=13.7.0
28
+ Requires-Dist: typer>=0.12.0
29
+ Requires-Dist: uvicorn[standard]>=0.30.0
30
+ Provides-Extra: dev
31
+ Requires-Dist: httpx>=0.27.0; extra == 'dev'
32
+ Requires-Dist: pytest-asyncio>=0.23.0; extra == 'dev'
33
+ Requires-Dist: pytest>=8.2.0; extra == 'dev'
34
+ Provides-Extra: llm
35
+ Requires-Dist: openai>=1.35.0; extra == 'llm'
36
+ Description-Content-Type: text/markdown
37
+
38
+ # API Operator
39
+
40
+ [![Tests](https://github.com/mohammedelkarsh/api-operator/actions/workflows/tests.yml/badge.svg)](https://github.com/mohammedelkarsh/api-operator/actions/workflows/tests.yml)
41
+ [![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE)
42
+ [![Python](https://img.shields.io/badge/python-3.11%2B-blue.svg)](https://www.python.org/downloads/)
43
+
44
+ Standalone **AI operator runtime** with pluggable adapters. Talk to your HTTP APIs instead of clicking through admin panels.
45
+
46
+ Works with Laravel, Go, connectivity platforms, or any backend with a REST API.
47
+
48
+ ## Install
49
+
50
+ ```bash
51
+ git clone https://github.com/mohammedelkarsh/api-operator.git
52
+ cd api-operator
53
+ pip install -e ".[dev]"
54
+ ```
55
+
56
+ Optional OpenAI planner:
57
+
58
+ ```bash
59
+ pip install -e ".[dev,llm]"
60
+ ```
61
+
62
+ ## Quick start
63
+
64
+ ```bash
65
+ api-operator demo
66
+ api-operator tools --adapter mock
67
+ ```
68
+
69
+ ## What ships in the core package
70
+
71
+ | In core | In your projects |
72
+ |---------|------------------|
73
+ | Agent runtime (plan, guard, execute) | `adapter.yaml` per API |
74
+ | `mock` adapter (demo + tests) | OpenAPI specs |
75
+ | `yaml` adapter | API tokens in `.env` |
76
+ | CLI + HTTP server | Optional custom adapters |
77
+
78
+ ## Build an adapter without Python
79
+
80
+ ### Scaffold template
81
+
82
+ ```bash
83
+ api-operator scaffold-adapter my-api --output examples
84
+ ```
85
+
86
+ ### Generate from OpenAPI
87
+
88
+ ```bash
89
+ api-operator generate-from-openapi openapi.yaml \
90
+ --output adapter.yaml \
91
+ --base-url http://api.example.test \
92
+ --path-prefix /api
93
+ ```
94
+
95
+ ### Laravel Tenant Kit example
96
+
97
+ See [`examples/tenant-kit-adapter/`](examples/tenant-kit-adapter/) — pairs with [laravel-tenant-kit](https://github.com/mohammedelkarsh/laravel-tenant-kit).
98
+
99
+ ```bash
100
+ export TENANT_KIT_API_TOKEN="your-sanctum-token"
101
+ api-operator chat \
102
+ --adapter yaml \
103
+ --config examples/tenant-kit-adapter/adapter.yaml \
104
+ --base-url http://laravel-tenant-kit.test
105
+ ```
106
+
107
+ ## adapter.yaml (minimal)
108
+
109
+ ```yaml
110
+ name: my_project
111
+ description: My API adapter
112
+ base_url: http://api.example.test
113
+
114
+ auth:
115
+ type: bearer
116
+ env_token: MY_PROJECT_API_TOKEN
117
+
118
+ tools:
119
+ - name: list_items
120
+ description: List items
121
+ method: GET
122
+ path: /api/items
123
+
124
+ - name: create_item
125
+ description: Create item
126
+ method: POST
127
+ path: /api/items
128
+ dangerous: true
129
+ parameters:
130
+ title:
131
+ type: string
132
+ required: true
133
+ body:
134
+ title: "{title}"
135
+ ```
136
+
137
+ Tenant subdomain APIs:
138
+
139
+ ```yaml
140
+ - name: invite_member
141
+ method: POST
142
+ path: /api/team/invitations
143
+ host: tenant
144
+ tenant_param: subdomain
145
+ parameters:
146
+ subdomain: { type: string, required: true }
147
+ email: { type: string, required: true }
148
+ ```
149
+
150
+ ## HTTP server
151
+
152
+ ```bash
153
+ api-operator serve --port 8100
154
+ ```
155
+
156
+ ```json
157
+ POST /v1/chat
158
+ {
159
+ "adapter": "yaml",
160
+ "config_path": "examples/tenant-kit-adapter/adapter.yaml",
161
+ "adapter_config": { "token": "YOUR_TOKEN" },
162
+ "message": "list workspaces",
163
+ "abilities": ["workspaces:read"]
164
+ }
165
+ ```
166
+
167
+ ## Integration test (Tenant Kit)
168
+
169
+ With [Tenant Kit](https://github.com/mohammedelkarsh/laravel-tenant-kit) running:
170
+
171
+ ```bash
172
+ python scripts/integration_tenant_kit.py
173
+ # Docker on port 8080:
174
+ python scripts/integration_tenant_kit.py --base-url http://laravel-tenant-kit.test:8080
175
+ ```
176
+
177
+ Optional pytest marker (requires env vars):
178
+
179
+ ```bash
180
+ export TENANT_KIT_BASE_URL=http://laravel-tenant-kit.test
181
+ export TENANT_KIT_API_TOKEN=your-token
182
+ pytest -m integration -q
183
+ ```
184
+
185
+ ## Tests
186
+
187
+ ```bash
188
+ pytest -q
189
+ ```
190
+
191
+ ## Configuration
192
+
193
+ Copy `.env.example` to `.env` for local defaults (`api_operator_PLANNER`, port, etc.).
194
+
195
+ ## Architecture
196
+
197
+ ```
198
+ api-operator (core) your projects
199
+ ├── agent runtime ├── adapter.yaml
200
+ ├── mock + yaml adapters ├── openapi.yaml
201
+ └── scaffold / generate CLI └── HTTP APIs (Laravel, Go, …)
202
+ ```
203
+
204
+ ## License
205
+
206
+ MIT — see [LICENSE](LICENSE).
@@ -0,0 +1,26 @@
1
+ api_operator/__init__.py,sha256=kOxjBzrJ014jMfqYgyI3dFwF2l_80kWgslmvySa8ABE,334
2
+ api_operator/factory.py,sha256=wjupDEpx4Ax3yjsSXSRg5ZjruboLzbH-WkhNRtJt5UE,786
3
+ api_operator/adapters/__init__.py,sha256=frcCV1k9oG9oKj3dpUqdJg1PxRT2RSN_XKdLCPjaYaY,2
4
+ api_operator/adapters/base.py,sha256=njGgFXwQMFQIkky9MPO1ixso78V2mZRU-uAPe8SZ9jQ,542
5
+ api_operator/adapters/mock.py,sha256=OZJ1qvLiWFnX8BJe_9QfD_8_aj475vypxO2EV7e2Xz8,5160
6
+ api_operator/adapters/openapi_generator.py,sha256=IIWSUnL2O9b5pqRIdjIpIWA0qU3IDDe8MJLYzRJcVG4,7262
7
+ api_operator/adapters/registry.py,sha256=5t80kY8KDS16VRyvq08y60Vk3x6ymibeW12NdJ3B0PI,2238
8
+ api_operator/adapters/yaml_adapter.py,sha256=b1fLPyrfrH3AhJCLAcoPEFMOo7XRFWnpEf4APQYHaDo,6312
9
+ api_operator/adapters/yaml_spec.py,sha256=A1gdsoIkO_jHdmaATv0sSvfr3PnEwkXWLOF9jwzdSLY,5144
10
+ api_operator/core/agent.py,sha256=RdKv-8ngDP5PH5iwfc45CwFDXHR8y2D9sIT1QW8-430,6080
11
+ api_operator/core/config.py,sha256=_rnub_E7huSJEwb6Cjurx5vNYQIhTpgiAKxl9dvrY_k,528
12
+ api_operator/core/executor.py,sha256=JqmLqXYVhh89igZCAb0Px1bjb8_iIBToe7Xd-rujxmA,1362
13
+ api_operator/core/guardrails.py,sha256=Nnb2MPu0D-u29lSmcjFSOfFm-Fu0rpkgXrmf_V_OmlA,1756
14
+ api_operator/core/memory.py,sha256=R1A4X9MyrW4YVxUI-K5zUkqOt6xKAH0qljAOhrd-Dmo,1506
15
+ api_operator/core/planner.py,sha256=7-NJo0Ks4RePVlctv1G4J2VNor5KpumnH1X-GoY0aKc,6941
16
+ api_operator/core/planner_openai.py,sha256=ump4XuQGGEUOHT4ariNvuadMpAs-XcRJFBdppkWFDBc,2411
17
+ api_operator/rag/indexer.py,sha256=D1CK7tHdCadkOFEClgkWkJP7CqUT_uYbqMH4pZj92fQ,1433
18
+ api_operator/server/app.py,sha256=TzGQgco6SrLGyBTyNe1AD9Nr6XjrpWoGOq9nk9Po-O8,3764
19
+ api_operator/server/cli.py,sha256=40q64nbceaNj4Je368C6TEN2_L-dlGDwXjXLZXXUqiI,7653
20
+ api_operator/tools/base.py,sha256=qJTEkZonofVVOcHgM_2hPLMHdFkfDlEooJQ3P6LCPcQ,2107
21
+ api_operator/tools/schema.py,sha256=YXoa-DmFPflF5cTVv200vS-Mn3PToIC2RxlPngW5Qhs,844
22
+ api_operator-0.9.0.dist-info/METADATA,sha256=hfh0yoJOlJIT7jN2ruE80I19z9ZyUGWXzlrggS_CCl4,5355
23
+ api_operator-0.9.0.dist-info/WHEEL,sha256=mffPy8wBnZQn2VnJUU5jE99KsxaSfiyMHV9Yt0aLVxs,87
24
+ api_operator-0.9.0.dist-info/entry_points.txt,sha256=868Ezyt8zvCkYMUCb_NihUu3Oz1WibHyHvZC02S_NYE,61
25
+ api_operator-0.9.0.dist-info/licenses/LICENSE,sha256=w3qzltsYO93CVULAaT7knAycDWsb3vLv_TnK7XnsAm8,1094
26
+ api_operator-0.9.0.dist-info/RECORD,,
@@ -0,0 +1,4 @@
1
+ Wheel-Version: 1.0
2
+ Generator: hatchling 1.30.1
3
+ Root-Is-Purelib: true
4
+ Tag: py3-none-any
@@ -0,0 +1,2 @@
1
+ [console_scripts]
2
+ api-operator = api_operator.server.cli:app
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 Mohammed Elkarsh
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.