Go to file
2021-08-02 21:38:04 +05:30
.github feat: refactor buttons 2021-07-06 18:00:39 +00:00
.husky ci: enforce commitlint + skip build on tests 2021-06-29 06:50:38 +05:30
assets fix: color contrast 2021-08-01 23:03:54 +05:30
components feat: storybook 2021-08-02 21:38:04 +05:30
helpers feat: effective url environment templates work with headers, url and params 2021-07-31 22:21:14 -04:00
lang feat: init new i18n format 2021-08-02 20:57:18 +05:30
layouts feat: init new i18n format 2021-08-02 20:57:18 +05:30
middleware refactor: move actions from app header to app footer 2021-07-23 18:28:07 +00:00
netlify chore: lint 2021-05-22 20:50:23 +05:30
newstore fix: color contrast 2021-08-01 23:03:54 +05:30
pages feat: init new i18n format 2021-08-02 20:57:18 +05:30
plugins feat: supported copy to clipboard utlity 2021-07-31 22:50:08 +05:30
static refactor: cleanup 2021-07-30 13:52:43 +05:30
store feat: zenmode + toggle left, right & header panes 2021-07-21 15:25:46 +05:30
types refactor: lint 2021-05-17 17:11:58 +05:30
.dockerignore docs: update links 2021-04-23 11:38:17 +00:00
.editorconfig docs: better copy 2021-04-23 11:38:56 +00:00
.env.example feat: update env with FB_MEASUREMENT_ID 2021-07-05 12:42:44 -04:00
.eslintrc.js Fix localStorage usage 2021-06-21 00:27:45 -04:00
.firebaserc Removed absolute Firebase files 2020-11-03 08:01:55 +05:30
.gitignore feat: init storybook 2021-07-16 20:35:15 +05:30
.prettierignore docs: better copy 2021-04-23 11:38:56 +00:00
.prettierrc.js refactor: lint options 2021-05-25 21:43:13 +05:30
.stylelintrc.js feat: remove tailwindcss + introduce windicss 2021-06-25 23:44:27 +00:00
babel.config.js Bump graphql-language-service-interface and fix build issues 2021-04-12 11:50:25 -04:00
CHANGELOG.md release: v1.12.0 2021-05-27 15:11:01 +00:00
CODE_OF_CONDUCT.md chore(deps): bump 2021-04-23 11:39:20 +00:00
commitlint.config.js feat: added commitlint, semantic pr 2021-06-28 00:24:16 +05:30
CONTRIBUTING.md docs: update links 2021-04-23 11:38:17 +00:00
docker-compose.yml fix:add 'helpers' folder to docker compose volumes (#1258) 2020-10-10 16:52:02 +05:30
Dockerfile refactor(ui): minor font tweaks 2021-06-21 16:31:40 +05:30
firebase.json feat: setup firebase hosting for prod 2021-06-27 12:06:57 +05:30
firestore.indexes.json Removed absolute Firebase files 2020-11-03 08:01:55 +05:30
firestore.rules docs: better copy 2021-04-23 11:38:56 +00:00
jest.config.js feat: added commitlint, semantic pr 2021-06-28 00:24:16 +05:30
jest.setup.js added jest-dom as dev dependency and added jest setup script 2020-08-24 15:41:59 -04:00
jsconfig.json Revert "Revert "Migrate Postwoman to Nuxt.js (full Vue and SCSS support)"" 2019-08-24 22:09:29 +05:30
LICENSE Updated license copyright (c) 2020, migrated docker container to organization, chores 2020-12-06 12:04:55 +05:30
netlify.toml fix: update Netlify build Node version to 14 2021-07-30 23:39:50 -04:00
nuxt.config.js Merge branch 'refactor/ui' into feat/storybook 2021-08-02 21:00:09 +05:30
package-lock.json feat: storybook 2021-08-02 21:38:04 +05:30
package.json feat: storybook 2021-08-02 21:38:04 +05:30
README.md fix: color contrast 2021-08-01 23:03:54 +05:30
TRANSLATIONS.md Fixed typo, updated sponsors list 2020-09-06 14:26:54 +05:30
tsconfig.json feat: added commitlint, semantic pr 2021-06-28 00:24:16 +05:30
vue-shim.d.ts feat: migrate all copy to clipboard actions to v-clipboard 2021-07-27 18:17:41 +05:30
windi.config.js feat: new components and UI improvements 2021-07-13 22:07:01 +05:30

Hoppscotch Logo

Hoppscotch

Open source API development ecosystem

contributions welcome Website Tests Tweet

Built with ❤︎ by contributors


Screenshot

Contact

Chat on Discord Chat on Telegram

Table of contents

Features

❤️ Lightweight: Crafted with minimalistic UI design.

Fast: Send requests and get/copy responses in real-time.

HTTP Methods
  • GET - Requests retrieve resource information
  • HEAD - Retrieve response headers identical to those of a GET request, but without the response body.
  • POST - The server creates a new entry in a database
  • PUT - Updates an existing resource
  • DELETE - Deletes resource or related component
  • 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
  • PATCH - Very similar to PUT but makes a partial update on a resource
  • <custom> - Some APIs use custom request methods such as LIST. Type in your custom methods.

🌈 Make it yours: Customizable combinations for background, foreground and accent colors. Customize now

Theming
  • Choose theme: System (default), Light, Dark and Black
  • Choose accent color: Green (default), Teal, Blue, Indigo, Purple, Yellow, Orange, Red and Pink
  • Toggle auto-scroll to response

Screenshot


Customized themes are synced with local session storage

🔥 PWA: Install as a PWA on your device.

Features
  • 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.

  • Choose method
  • Enter URL
  • Send
Features
  • 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 a HTTP connection without resorting to polling.

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

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

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

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

🔐 Authentication: Allows to identify the end user.

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

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

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

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

Options
  • Set Content Type
  • Add or remove Parameter list
  • Toggle between key-value and RAW input parameter list

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

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

History: Request entries are synced with cloud / local session storage to restore with a single click.

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

Features
  • Unlimited collections, folders and requests
  • Nested folders
  • Export as / import from GitHub gist

Collections are synced with cloud / local session storage

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

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

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

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

Use-cases
  • Initialize environment variables
  • Include timestamp in the request headers
  • Send a random alphanumeric string in the URL parameters

📄 API Documentation: Create and share dynamic API documentation easily, quickly.

Usage
  1. Add your requests to Collections and Folders
  2. Export Collections and easily share your APIs with the rest of your team
  3. Import Collections and Generate Documentation on-the-go

⌨️ Keyboard Shortcuts: Optimized for efficiency.

Shortcuts WIki

🌎 i18n: Experience the app in your own language.

Usage
  1. Scroll down to the footer
  2. Click "Choose Language" icon button
  3. Select your language from the menu

Keep in mind: Translations aren't available for all source and target language combinations

To provide a localized experience for users around the world, you can add you own translations.

All i18n contributions are welcome to i18n branch only!

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

Add-ons are developed and maintained under Official Hoppscotch Organization.

☁️ Auth + Sync: Sign in and sync in real-time.

Sign in with

  • Google
  • GitHub

Sync

  • History
  • Collections
  • Environments

Post-Request Tests β: Write tests associated with a request that are executed after the request response.

Use-cases
  • Check the status code as an integer
  • Filter response headers
  • Parse the response data

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

Features
  • Unlimited environments and variables
  • Initialize through 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

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

Features
  • Unlimited team collections and shared requests
  • Unlimited team members
  • User roles

To find out more, please check out Hoppscotch Wiki.

Demo

hoppscotch.io

Usage

  1. Choose method
  2. Enter URL
  3. Send request
  4. Get response

Built with

Developing

  1. Update .env.example file found in repository's root directory with your own keys and rename it to .env.

Sample keys only works with the production build.

Browser based development environment

Open in Gitpod

Local development environment

  1. Clone this repo with git.
  2. Install dependencies by running npm install within the directory that you cloned (probably hoppscotch).
  3. Start the development server with npm run dev.
  4. Open development site by going to http://localhost:3000 in your browser.

Docker compose

  1. Clone this repo with git.
  2. Run docker-compose up
  3. Open development site by going to http://localhost:3000 in your browser.

Docker

Official container   hoppscotch/hoppscotch

docker run --rm --name hoppscotch -p 3000:3000 hoppscotch/hoppscotch:latest

Releasing

  1. Clone this repo with git.
  2. Install dependencies by running npm install within the directory that you cloned (probably hoppscotch).
  3. Build the release files with npm run generate.
  4. Find the built project in ./dist.

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 exists thanks to all the people who contribute [Contribute].

License

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