Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hamednn76/postman-fetch
A package for fetch from your postman collection easily with name of your request
https://github.com/hamednn76/postman-fetch
angular javascript node postman postman-json-collection react vue
Last synced: 3 days ago
JSON representation
A package for fetch from your postman collection easily with name of your request
- Host: GitHub
- URL: https://github.com/hamednn76/postman-fetch
- Owner: HamedNN76
- License: mit
- Created: 2019-06-09T21:54:28.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-02T20:29:11.000Z (10 months ago)
- Last Synced: 2024-11-06T22:52:01.268Z (2 months ago)
- Topics: angular, javascript, node, postman, postman-json-collection, react, vue
- Language: JavaScript
- Homepage:
- Size: 229 KB
- Stars: 11
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: License.md
Awesome Lists containing this project
README
# Postman Fetch
A package for fetch from your postman collection easily with name of your request.
## Description
In every project there is a pain for having a full document for an application services or APIs.
The Postman application is a good place for testing or using our services, so we need to set headers, body or query params and etc for a service to work and also you have environment variables.But you need to set all the parameters in code to call your services.
With this package and Postman JSON collection we can fetch our services easily with the request name that we set in postman application.
## InstallingEasily installing from npm with blow command:
```
npm i -s postman-fetch
```### Using the package
This package provide PostmanFetch class for handle your API requests.
We have to pass two parameters to this class:
- Postman exported JSON collection (v2.1).
- Options:
- variables: pass your postman environment variables as an object.
- headers: use global headers in all requests.
- debug: this flag log the important thing like request and params for development.For example you can make fetch.js file like this:
```
import PostmanFetch from 'postman-fetch';
import * as postmanCollection from 'path/to/postmanCollection';const options = {
variables: {
baseURL: 'https://api.com/v1',
adminToken: 'A jwt token',
userToken: 'A jwt token',
...
},
headers: {
"Content-Type": "application/json",
...
},
debug: true //default false
};
const { fetch } = new PostmanFetch(postmanCollection, options);export default fetch;
```For example you have a request with "getUsers" name.
And then in another file use the fetch method:
```
import fetch from '/path/to/fetch.js';fetch('getUsers')
```
Or if you have created directory in your postman for example:adminPanel -> users -> getAllUsers
You can do like this:
```
import fetch from '/path/to/fetch.js';fetch('adminPanel.users.getAllUsers')
```From now you can fetch your request the headers, url, variables and all the thing that set in postman before.
What if you need to change a variable in some events in your application? For example you want to save the authenticated user token in your fetch method or remove it after logout.
You can easily set your new variables with "setVariables" method in PostmanFetch class.
So we have some changes in fetch.js file:
```
const { fetch, setVariables } = new PostmanFetch(postmanCollection, options);export {
fetch,
setVariables
};
export default fetch;
```And then in another file your need to pass an object as new variables to update the PostmanFetch class:
```
import { setVariables } from '/path/to/fetch.js';const newVariables = {
userToken: 'new jwt token',
...
};
setVariables(newVariables); //this method only update the passed property!
```## Examples
In Example directory there is a express application that provide book resource in rest structure. And also there is a React application that using the postman-fetch package for making the API calls.
## License
This project is licensed under the MIT License - see the [LICENSE.md](LICENSE.md) file for details.