{"id":24956147,"url":"https://github.com/superglue-ai/superglue","last_synced_at":"2025-05-14T13:00:18.197Z","repository":{"id":275372848,"uuid":"914997268","full_name":"superglue-ai/superglue","owner":"superglue-ai","description":"Self-healing integration agent. Use it as a layer between you and any complex / legacy APIs and always get the data that you want in the format you expect.","archived":false,"fork":false,"pushed_at":"2025-05-07T14:22:19.000Z","size":1520,"stargazers_count":1736,"open_issues_count":11,"forks_count":78,"subscribers_count":7,"default_branch":"main","last_synced_at":"2025-05-07T15:32:10.148Z","etag":null,"topics":["api","api-gateway","etl-automation","graphql","transformations"],"latest_commit_sha":null,"homepage":"https://superglue.ai","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/superglue-ai.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2025-01-10T18:38:47.000Z","updated_at":"2025-05-07T14:22:23.000Z","dependencies_parsed_at":null,"dependency_job_id":"8cb089d0-9ffb-4f39-b8d6-7beb94ee2f39","html_url":"https://github.com/superglue-ai/superglue","commit_stats":null,"previous_names":["superglue-ai/superglue"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/superglue-ai%2Fsuperglue","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/superglue-ai%2Fsuperglue/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/superglue-ai%2Fsuperglue/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/superglue-ai%2Fsuperglue/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/superglue-ai","download_url":"https://codeload.github.com/superglue-ai/superglue/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":254149595,"owners_count":22022846,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","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":["api","api-gateway","etl-automation","graphql","transformations"],"created_at":"2025-02-03T06:27:42.139Z","updated_at":"2025-05-14T13:00:18.168Z","avatar_url":"https://github.com/superglue-ai.png","language":"TypeScript","funding_links":[],"categories":["TypeScript","📚 Projects (1974 total)","Corporate and Analytical Applications"],"sub_categories":["MCP Servers","Data Integration and Specialized Solutions"],"readme":"\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://github.com/user-attachments/assets/be0e65d4-dcd8-4133-9841-b08799e087e7\" width=\"350\" alt=\"superglue_logo_white\"\u003e\n\u003c/p\u003e\n\n\u003ch2 align=\"center\"\u003eone SDK to manage all your data pipelines.\n 🍯\u003c/h2\u003e\n\nsuperglue bundles your pipelines into one stable, self-healing endpoint. Comes with automated schema-drift detection, retries and remappings so your data keeps moving no matter what - no connector maintenance, no rewrites. You can deploy it as a proxy between you and any SaaS app, API and data source and always get the data that you want in the format you expect.\n\n- Drop‑in proxy: point it at any REST / GraphQL / SQL / file endpoint.\n- LLM‑assisted mapping at setup; cached JSONata transforms at runtime (no LLM latency).\n- Self‑healing drift detector: when the upstream schema changes, superglue regenerates the transform, bumps a version, and keeps the pipeline running.\n- Security‑first: zero data stored; run fully on‑prem or use our hosted version.\n- Agent‑ready: every pipeline is exposed as a single, deterministic endpoint that LangChain, Retool or internal no‑code tools can call without knowing the ugly stuff underneath.\n\n\u003cdiv align=\"center\"\u003e\n\n[![GitHub](https://img.shields.io/github/license/superglue-ai/superglue?style=flat-square)](https://github.com/superglue-ai/superglue/blob/main/LICENSE)\n[![Y Combinator](https://img.shields.io/badge/Y%20Combinator-W25-orange?style=flat-square)](https://www.ycombinator.com/companies/superglue)\n[![Client SDK](https://img.shields.io/npm/v/@superglue/client?style=flat-square\u0026logo=npm)](https://www.npmjs.com/package/@superglue/client)\n[![Docker](https://img.shields.io/docker/pulls/superglueai/superglue?style=flat-square\u0026logo=Docker)](https://hub.docker.com/r/superglueai/superglue)\n[![Twitter Adina](https://img.shields.io/twitter/follow/adinagoerres?style=flat-square\u0026logo=X)](https://twitter.com/adinagoerres)\n[![Twitter Stefan](https://img.shields.io/twitter/follow/sfaistenauer?style=flat-square\u0026logo=X)](https://twitter.com/sfaistenauer)\n[![Weave Badge](https://img.shields.io/endpoint?url=https%3A%2F%2Fapp.workweave.ai%2Fapi%2Frepository%2Fbadge%2Forg_0S2o9PLamHvNsTjHbszc38vC%2F914997268\u0026cacheSeconds=3600\u0026labelColor=#EC6341)](https://app.workweave.ai/reports/repository/org_0S2o9PLamHvNsTjHbszc38vC/914997268)\n\n\n\u003c/div\u003e\n\n## quick start\n### hosted version\n\n1. Run on our [cloud-hosted version](https://superglue.ai)\n\n2. Install the superglue js/ts client:\n```bash\nnpm install @superglue/client\n```\n\n3. Configure your first api call:\n```javascript\nimport { SuperglueClient } from \"@superglue/client\";\n\nconst superglue = new SuperglueClient({\n  apiKey: \"************\"\n});\n\nconst workflowResult = await superglue.executeWorkflow({\n  // input can be an ID of a pre-saved workflow or a WorkflowInput object\n    workflow: {\n      id: \"myTodoUserWorkflow\",\n      steps: [\n        {\n          id: \"fetchTodos\", // Unique ID for this step\n          apiConfig: {\n            id: \"jsonplaceholderTodos\",\n            urlHost: \"https://jsonplaceholder.typicode.com\",\n            urlPath: \"/todos\",\n            method: HttpMethod.GET,\n            instruction: \"Fetch a list of todos. We only need the first one for this example.\",\n          },\n        },\n        {\n          id: \"fetchUser\",\n          apiConfig: {\n            id: \"jsonplaceholderUsers\",\n            urlHost: \"https://jsonplaceholder.typicode.com\",\n            urlPath: \"/users/\u003c\u003c$.fetchTodos[0].userId\u003e\u003e\", // JSONata path parameter for first userId\n            method: HttpMethod.GET,\n            instruction: \"Fetch user details by user ID for the first todo.\"\n          },\n        },\n      ],\n      // Transform the results of the steps into the final desired output. If not given, this will be generated from the reponse schema\n      finalTransform: \"$\",\n      responseSchema: { // define the expected final output structure\n        type: \"object\",\n        description: \"first todo\",\n        properties: {\n            todoTitle: { type: \"string\" },\n            userName: { type: \"string\" }\n        }\n      }\n  },\n  // `payload` could be used to pass initial data to the first step if needed. E.g. IDs to fetch, filters, etc. In short, things that can change across calls.\n  // payload: { userId: 1 },\n  // `credentials` can be used to authenticate requests. They need to be referenced in the api config (e.g. \"headers\": {\"Authorization\": \"Bearer \u003c\u003chubspot_api_key\u003e\u003e\"})\n  // credentials: { hubspot_api_key: \"pa_xxx\" },      \n});\nconsole.log(JSON.stringify(workflowResult, null, 2));\n```\n\n## what people build with superglue\n- Ship connectors 10x faster, without the maintenance overhead\n- Simple interface for legacy API pipelines\n- CMS or cloud migration\n- Transforming SQL queries into Rest API calls\n- Data lake consolidation\n- Track data lineage\n- And many more...\n\n\n## key features\n\n- **API Proxy**: Configure APIs and intercept responses in real-time with minimal added latency\n- **LLM-Powered Data Mapping**: Automatically generate data transformations using large language models \n- **Schema Validation**: Ensure data compliance with your specified schemas\n- **File Processing**: Handle various file formats (CSV, JSON, XML) with automatic decompression\n- **Flexible Authentication**: Support for various auth methods including header auth, api keys, oauth, and more\n- **Smart Pagination**: Handle different pagination styles automatically\n- **Caching \u0026 Retry Logic**: Built-in caching and configurable retry strategies\n\n## 📖 Documentation\n\nFor detailed documentation, visit [docs.superglue.cloud](https://docs.superglue.cloud).\n\n## 🤝 contributing\nWe love contributions! Feel free to open issues for bugs or feature requests.\n\n[//]: # (To contribute to the docs, check out the /docs folder.)\n\n## license\n\nsuperglue is GPL licensed. The superglue client SDKs are MIT licensed. See [LICENSE](LICENSE) for details.\n\n## 🙋‍♂️ support\n\n- 💬 Discord: [Join our community](https://discord.gg/vUKnuhHtfW)\n- 🐛 Issues: [GitHub Issues](https://github.com/superglue-ai/superglue/issues)\n\n[![Twitter](https://img.shields.io/twitter/follow/superglue_d?style=social)](https://twitter.com/superglue_d)\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsuperglue-ai%2Fsuperglue","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsuperglue-ai%2Fsuperglue","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsuperglue-ai%2Fsuperglue/lists"}