Open source API development ecosystem https://hoppscotch.io/

James George a08c6f6b3e chore(cli): drop Node.js `v18` support (#4583) 1 день назад
.devcontainer 0301649aff chore: make devcontainer copy .env.example (#3318) 1 год назад
.github 58407ae9dd feat(ci): portable and installer build workflow for `hoppscotch-agent` (#4472) 1 месяц назад
.husky 7aa43232cc chore: bump dependencies (#4444) 1 месяц назад
packages a08c6f6b3e chore(cli): drop Node.js `v18` support (#4583) 1 день назад
.dockerignore efa40cf6ea feat: container registry friendly docker images and all-in-one container (#3193) 1 год назад
.editorconfig fc05a4bb78 docs: better copy 3 лет назад
.env.example 86fc4d9eb5 bug: .env.example fix comments formatting (#4296) 3 месяцев назад
.firebaserc 660cdb575a Removed absolute Firebase files 4 лет назад
.gitattributes 9f78a4c7e8 chore: add .gitattributes 2 лет назад
.gitignore e8ed938b4c feat: collection runner (#3600) 1 неделя назад
.npmrc 439cd82c88 chore: pin dependencies across packages (#3876) 9 месяцев назад
.prettierignore fc05a4bb78 docs: better copy 3 лет назад
.prettierrc.js 8c57d81718 chore: bump dependencies (#3258) 1 год назад
CHANGELOG.md 758460210a build: bump deps 2 лет назад
CODEOWNERS cc1be91446 chore: update CODEOWNERS 5 месяцев назад
CODE_OF_CONDUCT.md f34d896095 docs: updated screenshots and features list (#3310) 1 год назад
CONTRIBUTING.md 292d752f32 chore: update CONTRIBUTING.md 5 месяцев назад
LICENSE 1350919c78 docs: updated copyright year 2 лет назад
README.md 0d0ad7a2f8 chore: added micro interactions (#3783) 10 месяцев назад
SECURITY.md e6cd03c283 chore: update SECURITY.md 5 месяцев назад
TRANSLATIONS.md f34d896095 docs: updated screenshots and features list (#3310) 1 год назад
aio-multiport-setup.Caddyfile c1bc74635f feat: ability for aio in sub-path access configurations to specify alternate ports (#4480) 1 месяц назад
aio-subpath-access.Caddyfile c1bc74635f feat: ability for aio in sub-path access configurations to specify alternate ports (#4480) 1 месяц назад
aio_run.mjs afea75694f refactor: slim down the backend containers (#4233) 3 месяцев назад
commitlint.config.js a2354b5e9e feat: added commitlint, semantic pr 3 лет назад
docker-compose.deploy.yml afea75694f refactor: slim down the backend containers (#4233) 3 месяцев назад
docker-compose.yml afea75694f refactor: slim down the backend containers (#4233) 3 месяцев назад
firebase.json 36903b338a fix: broken Dockerfile and final start command 2 лет назад
firestore.indexes.json 660cdb575a Removed absolute Firebase files 4 лет назад
firestore.rules 238e41ccda refactor: updated firebase rules 2 лет назад
healthcheck.sh 1105fb8274 fix: broken healthchecks on sh containers (#4300) 3 месяцев назад
jsconfig.json b027eeb846 Revert "Revert "Migrate Postwoman to Nuxt.js (full Vue and SCSS support)"" 5 лет назад
netlify.toml ce0898956d chore: reintroduce updated auth mechanism 1 год назад
package.json e8ed938b4c feat: collection runner (#3600) 1 неделя назад
pnpm-lock.yaml a08c6f6b3e chore(cli): drop Node.js `v18` support (#4583) 1 день назад
pnpm-workspace.yaml b28f82a881 refactor: monorepo+pnpm (removed husky) 3 лет назад
prod.Dockerfile c1bc74635f feat: ability for aio in sub-path access configurations to specify alternate ports (#4480) 1 месяц назад
tailwind.config.ts f93558324f chore: move hoppscotch-ui package out of the monorepo (#3620) 11 месяцев назад

README.md

Hoppscotch

Hoppscotch

Open Source API Development Ecosystem

[![contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen?logo=github)](CODE_OF_CONDUCT.md) [![Website](https://img.shields.io/website?url=https%3A%2F%2Fhoppscotch.io&logo=hoppscotch)](https://hoppscotch.io) [![Tests](https://github.com/hoppscotch/hoppscotch/actions/workflows/tests.yml/badge.svg)](https://github.com/hoppscotch/hoppscotch/actions) [![Tweet](https://img.shields.io/twitter/url?url=https%3A%2F%2Fhoppscotch.io%2F)](https://twitter.com/share?text=%F0%9F%91%BD%20Hoppscotch%20%E2%80%A2%20Open%20source%20API%20development%20ecosystem%20-%20Helps%20you%20create%20requests%20faster,%20saving%20precious%20time%20on%20development.&url=https://hoppscotch.io&hashtags=hoppscotch&via=hoppscotch_io)

Built with ❤︎ by contributors


Hoppscotch

We highly recommend you take a look at the Hoppscotch Documentation to learn more about the app.

Support

Chat on Discord Chat on Telegram Discuss on GitHub

Features

❤️ Lightweight: Crafted with minimalistic UI design.

⚡️ Fast: Send requests and get responses in real time.

🗄️ HTTP Methods: Request methods define the type of action you are requesting to be performed.

  • GET - Requests retrieve resource information
  • POST - The server creates a new entry in a database
  • PUT - Updates an existing resource
  • PATCH - Very similar to PUT but makes a partial update on a resource
  • DELETE - Deletes resource or related component
  • HEAD - Retrieve response headers identical to those of a GET request, but without the response body.
  • CONNECT - Establishes a tunnel to the server identified by the target resource
  • OPTIONS - Describe the communication options for the target resource
  • TRACE - Performs a message loop-back test along the path to the target resource
  • <custom> - Some APIs use custom request methods such as LIST. Type in your custom methods.

🌈 Theming: Customizable combinations for background, foreground, and accent colors — customize now.

  • Choose a theme: System preference, Light, Dark, and Black
  • Choose accent colors: Green, Teal, Blue, Indigo, Purple, Yellow, Orange, Red, and Pink
  • Distraction-free Zen mode

Customized themes are synced with your cloud/local session.

🔥 PWA: Install as a Progressive Web App on your device.

  • Instant loading with Service Workers
  • Offline support
  • Low RAM/memory and CPU usage
  • Add to Home Screen
  • Desktop PWA

🚀 Request: Retrieve response from endpoint instantly.

  1. Choose method
  2. Enter URL
  3. Send
  • Copy/share public "Share URL"
  • Generate/copy request code snippets for 10+ languages and frameworks
  • Import cURL
  • Label requests

🔌 WebSocket: Establish full-duplex communication channels over a single TCP connection.

📡 Server-Sent Events: Receive a stream of updates from a server over an HTTP connection without resorting to polling.

🌩 Socket.IO: Send and Receive data with the SocketIO server.

🦟 MQTT: Subscribe and Publish to topics of an MQTT Broker.

🔮 GraphQL: GraphQL is a query language for APIs and a runtime for fulfilling those queries with your existing data.

  • Set endpoint and get schema
  • Multi-column docs
  • Set custom request headers
  • Query schema
  • Get query response

🔐 Authorization: Allows to identify the end-user.

  • None
  • Basic
  • Bearer Token
  • OAuth 2.0
  • OIDC Access Token/PKCE

📢 Headers: Describes the format the body of your request is being sent in.

📫 Parameters: Use request parameters to set varying parts in simulated requests.

📃 Request Body: Used to send and receive data via the REST API.

  • Set Content Type
  • FormData, JSON, and many more
  • Toggle between key-value and RAW input parameter list

📮 Response: Contains the status line, headers, and the message/response body.

  • Copy the response to the clipboard
  • Download the response as a file
  • View response headers
  • View raw and preview HTML, image, JSON, and XML responses

History: Request entries are synced with your cloud/local session storage.

📁 Collections: Keep your API requests organized with collections and folders. Reuse them with a single click.

  • Unlimited collections, folders, and requests
  • Nested folders
  • Export and import as a file or GitHub gist

Collections are synced with your cloud/local session storage.

📜 Pre-Request Scripts: Snippets of code associated with a request that is executed before the request is sent.

  • Set environment variables
  • Include timestamp in the request headers
  • Send a random alphanumeric string in the URL parameters
  • Any JavaScript functions

👨‍👩‍👧‍👦 Teams: Helps you collaborate across your teams to design, develop, and test APIs faster.

  • Create unlimited teams
  • Create unlimited shared collections
  • Create unlimited team members
  • Role-based access control
  • Cloud sync
  • Multiple devices

👥 Workspaces: Organize your personal and team collections environments into workspaces. Easily switch between workspaces to manage multiple projects.

  • Create unlimited workspaces
  • Switch between personal and team workspaces

⌨️ Keyboard Shortcuts: Optimized for efficiency.

Read our documentation on Keyboard Shortcuts

🌐 Proxy: Enable Proxy Mode from Settings to access blocked APIs.

  • Hide your IP address
  • Fixes CORS (Cross-Origin Resource Sharing) issues
  • Access APIs served in non-HTTPS (http://) endpoints
  • Use your Proxy URL

Official proxy server is hosted by Hoppscotch - GitHub - Privacy Policy.

🌎 i18n: Experience the app in your language.

Help us to translate Hoppscotch. Please read TRANSLATIONS for details on our CODE OF CONDUCT and the process for submitting pull requests to us.

☁️ Auth + Sync: Sign in and sync your data in real-time across all your devices.

Sign in with:

  • GitHub
  • Google
  • Microsoft
  • Email
  • SSO (Single Sign-On)[^EE]

🔄 Synchronize your data: Handoff to continue tasks on your other devices.

  • Workspaces
  • History
  • Collections
  • Environments
  • Settings

Post-Request Tests: Write tests associated with a request that is executed after the request's response.

  • Check the status code as an integer
  • Filter response headers
  • Parse the response data
  • Set environment variables
  • Write JavaScript code

🌱 Environments: Environment variables allow you to store and reuse values in your requests and scripts.

  • Unlimited environments and variables
  • Initialize through the pre-request script
  • Export as / import from GitHub gist
Use-cases --- - By storing a value in a variable, you can reference it throughout your request section - If you need to update the value, you only have to change it in one place - Using variables increases your ability to work efficiently and minimizes the likelihood of error ---

🚚 Bulk Edit: Edit key-value pairs in bulk.

  • Entries are separated by newline
  • Keys and values are separated by :
  • Prepend # to any row you want to add but keep disabled

🎛️ Admin dashboard: Manage your team and invite members.

  • Insights
  • Manage users
  • Manage teams

📦 Add-ons: Official add-ons for hoppscotch.

  • Hoppscotch CLI - Command-line interface for Hoppscotch.
  • Proxy - A simple proxy server created for Hoppscotch.
  • Browser Extensions - Browser extensions that enhance your Hoppscotch experience.

Firefox Firefox  |  Chrome Chrome

Extensions fix CORS issues.

Add-ons are developed and maintained under Hoppscotch Organization.

For a complete list of features, please read our documentation.

Demo

hoppscotch.io

Usage

  1. Provide your API endpoint in the URL field
  2. Click "Send" to simulate the request
  3. View the response

Developing

Follow our self-hosting documentation to get started with the development environment.

Contributing

Please contribute using GitHub Flow. Create a branch, add commits, and open a pull request.

Please read CONTRIBUTING for details on our CODE OF CONDUCT, and the process for submitting pull requests to us.

Continuous Integration

We use GitHub Actions for continuous integration. Check out our build workflows.

Changelog

See the CHANGELOG file for details.

Authors

This project owes its existence to the collective efforts of all those who contribute — contribute now.

License

This project is licensed under the MIT License — see the LICENSE file for details.

[^EE]: Enterprise edition feature. Learn more.