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

Liyas Thomas 0afd6ac749 :bookmark: v1.9.9 4 years ago
.github eb9588fbea Create codeql-analysis.yml 4 years ago
assets fa28aaee44 Fixed #1028 4 years ago
components 4a1988dd23 Fixed crash on proxy error 4 years ago
docs d284002803 :zap: Zap 5 years ago
functions 9ccf9e9def Bump lodash from 4.17.15 to 4.17.19 in /functions 4 years ago
helpers 4a1988dd23 Fixed crash on proxy error 4 years ago
lang 7a3108aca6 Update zh-CN.json 4 years ago
layouts 5d94ac361e Isolate Netlify, Firebase and Helper functions + Import from absolute paths 4 years ago
middleware 1587a44cd7 Lint 4 years ago
netlify 5d94ac361e Isolate Netlify, Firebase and Helper functions + Import from absolute paths 4 years ago
pages 89f552872c Update pages/index.vue 4 years ago
plugins 48100ead55 Commit code with double quotes instead of single quotes 5 years ago
static 0afd6ac749 :bookmark: v1.9.9 4 years ago
store a38ef9e29e :mag: Improving SEO 4 years ago
tests 50be731d06 Fixing CI 4 years ago
.all-contributorsrc 1a3ff5dbb7 docs: update .all-contributorsrc [skip ci] 4 years ago
.dockerignore c54b019d55 :fire: Firebase Hosting 5 years ago
.editorconfig 268748f85f :rotating_light: Removing linter warnings 5 years ago
.env.example d4aa3699f2 :zap: dotenv 4 years ago
.firebaserc cf21a20f05 :green_heart: Fixing CI build 5 years ago
.gitignore 85c5f16e93 tests(fix): update start-server-and-test, update e2e tests, change build test command at ci 5 years ago
.prettierignore 070a830eaa Fix local build 5 years ago
.travis.yml 44de8438ef test: purge travis 5 years ago
CHANGELOG.md 0afd6ac749 :bookmark: v1.9.9 4 years ago
CODE_OF_CONDUCT.md b8b15b9394 :beers: hello@postwoman.io 4 years ago
CONTRIBUTING.md 5f97f49f28 :pencil2: Writing docs 5 years ago
Dockerfile b10a209daf :zap: Improving performance 5 years ago
LICENSE 91c08a5e63 :tada: Initial upload 5 years ago
README.md c2d3918341 #959 4 years ago
TRANSLATIONS.md 4ab512fa93 Translation guidelines 4 years ago
build.js fe9c08e92a :fire: Removed unused variable 4 years ago
cypress.json b10a209daf :zap: Improving performance 5 years ago
database.rules.json b10a209daf :zap: Improving performance 5 years ago
docker-compose.yml ff006a254a Separate dockerfile layers and add volume 5 years ago
firebase.json 777e629b3d Initial prettier formatted files 5 years ago
firestore.indexes.json 777e629b3d Initial prettier formatted files 5 years ago
firestore.rules 7275e8075b :fire: Firestore rules 5 years ago
jsconfig.json b027eeb846 Revert "Revert "Migrate Postwoman to Nuxt.js (full Vue and SCSS support)"" 5 years ago
netlify.toml 5d94ac361e Isolate Netlify, Firebase and Helper functions + Import from absolute paths 4 years ago
nuxt.config.js a38ef9e29e :mag: Improving SEO 4 years ago
package-lock.json a493d996bd Bump firebase from 7.17.0 to 7.17.1 4 years ago
package.json 0afd6ac749 :bookmark: v1.9.9 4 years ago
storage.rules c54b019d55 :fire: Firebase Hosting 5 years ago

README.md

Postwoman.io logo

A free, fast and beautiful API request builder

Web alternative to Postman - Helps you create requests faster, saving precious time on development - Subscribe

[![Travis Build Status](https://img.shields.io/travis/com/liyasthomas/postwoman?logo=Travis)](https://travis-ci.com/liyasthomas/postwoman) [![GitHub release](https://img.shields.io/github/release/liyasthomas/postwoman/all?logo=GitHub)](https://github.com/liyasthomas/postwoman/releases/latest) [![Website](https://img.shields.io/website?url=https%3A%2F%2Fpostwoman.io&logo=Postwoman)](https://postwoman.io) [![Contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen)](CONTRIBUTING.md) [![Financial Contributors on Open Collective](https://img.shields.io/opencollective/all/postwoman?logo=Open-Collective&label=financial+contributors)](https://opencollective.com/postwoman) [![Donate on PayPal](https://img.shields.io/badge/support-PayPal-blue?logo=PayPal)](https://www.paypal.me/liyascthomas) [![Chat on Telegram](https://img.shields.io/badge/chat-Telegram-blueviolet?logo=Telegram)](https://t.me/postwoman_app) [![Chat on Discord](https://img.shields.io/badge/chat-Discord-violet?logo=discord)](https://discord.gg/GAMWxmR) [![Tweet](https://img.shields.io/twitter/url?url=https%3A%2F%2Fpostwoman.io%2F)](https://twitter.com/intent/tweet?url=https%3A%2F%2Fpostwoman.io&text=%F0%9F%91%BD%20Postwoman%20%E2%80%A2%20API%20request%20builder%20-%20Helps%20you%20create%20your%20requests%20faster%2C%20saving%20you%20precious%20time%20on%20your%20development&original_referer=https%3A%2F%2Ftwitter.com%2Fshare%3Ftext%3D%25F0%259F%2591%25BD%2520Postwoman%2520%25E2%2580%25A2%2520API%2520request%2520builder%2520-%2520Helps%2520you%2520create%2520your%2520requests%2520faster%2C%2520saving%2520you%2520precious%2520time%2520on%2520your%2520development%26url%3Dhttps%3A%2F%2Fpostwoman.io%26hashtags%3Dpostwoman%26via%3Dliyasthomas&via=liyasthomas&hashtags=postwoman)

Built with ❤︎ by liyasthomas and contributors


Read: Story behind Postwoman

Chat: Telegram, Discord

Donate: GitHub Sponsors, Open Collective, Patreon, PayPal

Screenshot1
Table of contents --- - [Features](#features-) - [Demo](#demo--) - [Usage](#usage-) - [Built with](#built-with-) - [Developing](#developing-) - [Browser based development environment](#browser-based-development-environment) - [Local development environment](#local-development-environment) - [Docker compose](#docker-compose) - [Docker](#docker--) - [Releasing](#releasing-) - [Contributing](#contributing-) - [Continuous Integration](#continuous-integration--) - [Versioning](#versioning--) - [Change log](#change-log-) - [Authors](#authors-) - [Lead Developers](#lead-developers) - [Testing and Debugging](#testing-and-debugging) - [Collaborators](#collaborators-) - [Thanks](#thanks) - [Financial Contributors](#financial-contributors) - [Organizations](#organizations) - [Individuals](#individuals) - [Code Contributors](#code-contributors) - [License](#license-) - [Acknowledgements](#acknowledgements-) - [Badges](#badges-) ---

Features ✨

❤️ Lightweight: Crafted with minimalistic UI design.

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

Methods:

  • GET - Retrieve information about the REST API resource
  • HEAD - Retrieve response headers identical to those of a GET request, but without the response body.
  • POST - Create a REST API resource
  • PUT - Update a REST API resource
  • DELETE - Delete a REST API 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 - Apply partial modifications to a REST API 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.

Theming: Customize now ✨

  • Choose theme: Kinda Dark (default), Clearly White, Just Black and System theme
  • Choose accent color: Green (default), Yellow, Pink, Red, Purple, Orange, Cyan and Blue
  • Toggle multi-colored headings
  • Toggle auto-scroll to response

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 for JavaScript XHR, Fetch and cURL
  • Import cURL
  • Label requests

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

  • Send and receive data
  • Basic and Bearer Token authentication

📡 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.

  • 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

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

  • Copy response to clipboard
  • Download response as a file
  • View preview of HTML 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.

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 Postwoman Proxy is hosted by Apollo Software - Privacy Policy

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

Use-cases:

  • 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:

  • Send/Cancel Request Ctrl + G
  • Save to Collections Ctrl + S
  • Copy Request Link Ctrl + K
  • Reset Request Ctrl + L

🌎 i18n β: Experience the app in your own language.

  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 Postwoman.

  • Proxy - A simple proxy server created for Postwoman
  • CLI β - A CLI solution for Postwoman
  • Browser Extensions - Browser extensions that simplifies access to Postwoman

Firefox Firefox  |  Chrome Chrome

Extensions fixes CORS issues.

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

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

Sign in with:

  • Google
  • GitHub

Sync:

  • History
  • Collections
  • Environments
  • Notes

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

📝 Notes : Instantly jot down notes, tasks or whatever you feel like as they come to your mind.

Notes are only available for signed-in users

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

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

To find out more, please check out Postwoman Wiki.

Demo 🚀 Website

postwoman.io

Usage 💡

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

Built with 🔧

  • HTML - For the web framework
  • CSS - For styling components
  • JavaScript - For magic!
  • Vue
  • Nuxt

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 postwoman).
  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 🐳 Docker Cloud Build Status

#pull
docker pull liyasthomas/postwoman

#run
docker run -p 3000:3000 liyasthomas/postwoman:latest

#build
docker build -t postwoman:latest .

Releasing 🧞

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

Contributing 🍰

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

Continuous Integration 💚 Travis Build Status

We use Travis CI for continuous integration. Check out our Travis CI Status.

Versioning 🔖 GitHub release

This project is developed by Liyas Thomas using the Semantic Versioning specification. For the versions available, see the releases on this repository.

Change log 📝

See the CHANGELOG file for details.

Authors 🧙

Lead Developers

Testing and Debugging

Collaborators

All Contributors


Liyas Thomas

💻 🎨

John Harker

💻 🎨

Nicholas La Roux

💻

Thomas Yuba

💻

Nick Palenchar

💻

Andrew Bastin

💻

Vladislav

💻

izerozlu

💻

Jacob Anavisca

💻

Nityananda Gohain

💻

Hossein Nedaee

💻

James George

💻

Dmitry Yankowski

💻

Samir Boulema

💻

See the list of contributors who participated in this project.

Thanks

Financial Contributors

Become a financial contributor and help us sustain our community [Contribute].

Organizations

Support this project with your organization. Your logo will show up here with a link to your website [Contribute].

Individuals

Code Contributors

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.

Acknowledgements 🙏

  • Hat tip to anyone whose code was used
  • Inspirations:

Badges 📛

Preview Markdown code


Default
[![Postwoman](https://img.shields.io/badge/Tested_on-Postwoman-202124?logo=Postwoman)](https://postwoman.io)


Success
[![Postwoman](https://img.shields.io/badge/Tested_on-Postwoman-success?logo=Postwoman)](https://postwoman.io)


Critical
[![Postwoman](https://img.shields.io/badge/Tested_on-Postwoman-critical?logo=Postwoman)](https://postwoman.io)


Custom
[![Postwoman](https://img.shields.io/badge/Tested_on-Postwoman-blueviolet?logo=Postwoman)](https://postwoman.io)


Customize
[![Postwoman](https://img.shields.io/badge/your_text-Postwoman-hex_color_code?logo=Postwoman)](https://postwoman.io)

Postwoman.io

Happy Coding ❤︎