• Stars
    star
    991
  • Rank 46,212 (Top 1.0 %)
  • Language
    JavaScript
  • License
    Apache License 2.0
  • Created over 5 years ago
  • Updated about 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Common repository for all code generators shipped with Postman


Manage all of your organization's APIs in Postman, with the industry's most complete API development environment.

Supercharge your API workflow.
Modern software is built on APIs. Postman helps you develop APIs faster.

postman-code-generators Build Status

This module converts a Postman SDK Request Object into a code snippet of chosen language.

Every code generator has two identifiers: language and variant.

  • language of a code generator is the programming language in which the code snippet is generated.
  • variant of a code generator is the methodology or the underlying library used by the language to send requests.

List of supported code generators:

Language Variant
C libcurl
C# HttpClient
C# RestSharp
cURL cURL
Dart http
Go Native
HTTP HTTP
Java OkHttp
Java Unirest
JavaScript Fetch
JavaScript jQuery
JavaScript XHR
Kotlin OkHttp
NodeJs Axios
NodeJs Native
NodeJs Request
NodeJs Unirest
Objective-C NSURLSession
OCaml Cohttp
PHP cURL
PHP Guzzle
PHP pecl_http
PHP HTTP_Request2
PowerShell RestMethod
Python http.client
Python Requests
R httr
R RCurl
Rust Reqwest
Ruby Net:HTTP
Shell Httpie
Shell wget
Swift URLSession

Table of contents

Getting Started

To install postman-code-generators as your dependency

$ npm install postman-code-generators

To get a copy on your local machine

$ git clone https://github.com/postmanlabs/postman-code-generators.git

Prerequisite

To run any of the postman-code-generators, ensure that you have NodeJS >= v8. A copy of the NodeJS installable can be downloaded from https://nodejs.org/en/download/package-manager.

Usage

Using postman-code-generators as a Library

There are three functions that are exposed in postman-code-generators: getLanguageList, getOptions, and convert.

getLanguageList

This function returns a list of supported code generators.

Example:
var codegen = require('postman-code-generators'), // require postman-code-generators in your project
    supportedCodegens = codegen.getLanguageList();
    console.log(supportedCodegens);
    // output:
    // [
    //   {
    //     key: 'nodejs',
    //     label: 'NodeJs',
    //     syntax_mode: 'javascript',
    //     variant: [
    //       {
    //         key: 'Requests'
    //       },
    //       {
    //         key: 'Native'
    //       },
    //       {
    //         key: 'Unirest'
    //       }
    //     ]
    //   },
    //   ...
    // ]

getOptions

This function takes in three parameters and returns a callback with error and supported options of that code generator.

  • language - language key from the language list returned from getLanguageList function
  • variant - variant key provided by getLanguageList function
  • callback - callback function with first parameter as error and second parameter as array of options supported by the codegen.

A typical option has the following properties:

  • name - Display name
  • id - unique ID of the option
  • type - Data type of the option. (Allowed data types: boolean, enum, positiveInteger)
  • default - Default value. The value that is used if this option is not specified while creating code snippet
  • description - User friendly description.
Example:
var codegen = require('postman-code-generators'), // require postman-code-generators in your project
    language = 'nodejs',
    variant = 'Request';

    codegen.getOptions(language, variant, function (error, options) {
      if (error) {
        // handle error
      }
      console.log(options);
    });
// output: 
//     [
//     {
//       name: 'Set indentation count',
//       id: 'indentCount',
//       type: 'positiveInteger',
//       default: 2,
//       description: 'Set the number of indentation characters to add per code level'
//     },
//     {
//       name: 'Set indentation type',
//       id: 'indentType',
//       type: 'enum',
//       availableOptions: ['Tab', 'Space'],
//       default: 'Space',
//       description: 'Select the character used to indent lines of code'
//     },
//     ...
//   ];

convert

This function takes in five parameters and returns a callback with error and generated code snippet

  • language - lang key from the language list returned from getLanguageList function
  • variant - variant key provided by getLanguageList function
  • request - Postman-SDK Request Object
  • options - Options that can be used to configure generated code snippet. Defaults will be used for the unspecified attributes
  • callback - callback function with first parameter as error and second parameter as string for code snippet
Example:
var codegen = require('postman-code-generators'), // require postman-code-generators in your project
    sdk = require('postman-collection'), // require postman-collection in your project
    request = new sdk.Request('https://www.google.com'),  //using postman sdk to create request 
    language = 'nodejs',
    variant = 'request',
    options = {
        indentCount: 3,
        indentType: 'Space',
        trimRequestBody: true,
        followRedirect: true
    };
codegen.convert(language, variant, request, options, function(error, snippet) {
    if (error) {
        //  handle error
    }
    //  handle snippet
});

Development

Installing dependencies

This command will install all the dependencies in production mode.

$ npm install;

To install dev dependencies also for all codegens run:

$ npm run deepinstall dev; 

Testing

To run common repo test as well as tests (common structure test + individual codegen tests) for all the codegens

$ npm test; 

To run structure and individual tests on a single codegen

$ npm test <codegen-name>;
# Here "codege-name" is the folder name of the codegen inside codegens folder

Packaging

To create zipped package of all codegens

$ npm run package;

Note: The zipped package is created inside each codegen's folder.

To create zipped package of a single codegen

$ npm run package <codegen-name>

Contributing

Please take a moment to read our contributing guide to learn about our development process. Open an issue first to discuss potential changes/additions.

License

This software is licensed under Apache-2.0. Copyright Postman, Inc. See the LICENSE.md file for more information.

More Repositories

1

httpbin

HTTP Request & Response Service, written in Python + Flask.
Python
12,664
star
2

newman

Newman is a command-line collection runner for Postman
JavaScript
6,859
star
3

postman-app-support

Postman is an API platform for building and using APIs. Postman simplifies each step of the API lifecycle and streamlines collaboration so you can create better APIsβ€”faster.
5,826
star
4

openapi-to-postman

Plugin for converting OpenAPI 3.0 specs to the Postman Collection (v2) format
JavaScript
918
star
5

postman-docs

Documentation for Postman, a collaboration platform for API development. Available for Mac, Windows, and Linux.
JavaScript
559
star
6

postman-collection

Javascript module that allows a developer to work with Postman Collections
JavaScript
456
star
7

postman-runtime

JavaScript
238
star
8

postman-chrome-interceptor

Helper extension for the Postman packaged app. Also helps send restricted headers.
JavaScript
207
star
9

covid-19-apis

Postman COVID-19 API Resource Centerβ€”API collections to help in the COVID-19 fight.
JavaScript
127
star
10

npm-cli-login

JavaScript
113
star
11

swagger2-to-postman

Converter for swagger 2.0 JSON to Postman Collection
JavaScript
113
star
12

postman-sandbox

Sandbox for Postman Scripts to run in Node.js or browser
JavaScript
104
star
13

postman-chrome-extension-legacy

Postman REST Client Chrome Extension (Legacy Version)
JavaScript
94
star
14

postman-collection-transformer

Perform rapid conversion and validation of JSON structure between Postman Collection Format v1 and v2.
JavaScript
87
star
15

postman-flows

We're maintaining this repo to share the progress of Flows publicly and get feedback at the same time.
86
star
16

newman-docker

Docker images for Newman Collection Runner
Shell
80
star
17

swagger2-postman2

Module and library to convert Swagger 2.0 to a Postman Collection (v2.0)
JavaScript
79
star
18

newman-reporter-html

HTML
76
star
19

curl-to-postman

Converts curl requests to Postman Collection v2 request objects
JavaScript
62
star
20

sails-mysql-transactions

sails/waterline ORM with mySQL transaction support
JavaScript
58
star
21

uvm

Universal Virtual Machine for Node and Browser
JavaScript
40
star
22

schemas

Repository of all schemas for JSON structures compatible with Postman (such as the Postman Collection Format)
JavaScript
38
star
23

postman-updater-linux

A simple bash script to update Postman from the command line (for Linux)
Shell
35
star
24

graphql-to-postman

Plugin for converting GraphQL to the Postman Collection (v2) format
JavaScript
34
star
25

gsoc

Postman - Google Summer of Code
32
star
26

node-doc-kube

🐱 URL shortener using cat verbs, cat adjectives, and cat emojis
JavaScript
31
star
27

chai-postman

Chai plugin to assert on Postman Collections
JavaScript
28
star
28

postman-collection-code-generators

Repository for generating code from Postman Collection
JavaScript
22
star
29

postman

21
star
30

e-commerce-store-express

JavaScript
20
star
31

newman-dashboard

A WebUI companion for Newman to control, view and debug runs. πŸš€βœ¨
JavaScript
18
star
32

raml2postman

Coverts RAML specs to Postman Collections (v1 of the collection format)
JavaScript
18
star
33

postman-url-encoder

Implements URL encoding according to the WHATWG specification
JavaScript
18
star
34

runscope-to-postman

Convert Runscope Radar Tests to Postman Collection v2
JavaScript
14
star
35

postman-jsdoc-theme

A JSDoc Theme
JavaScript
13
star
36

wsdl-to-postman

Enables Postman support of the WSDL specification
JavaScript
13
star
37

uniscope

Evaluate a code within a controlled environment
JavaScript
12
star
38

env-lift

Simple namespaced environment variable configuration management solution
JavaScript
12
star
39

templates

11
star
40

spectral-postman

A sample API that retrieves constellations as an example to demonstrate features in the OpenAPI 3.0 specification.
Shell
11
star
41

devrel-content

Project to track content creation requests and progress for the Postman Developer Relations team.
10
star
42

api-spec-converter

JavaScript
10
star
43

raml1-to-postman

Converter for RAML1.0 specs to Postman v2 collections
JavaScript
10
star
44

http-reasons

Database to lookup http reasons from http response status code
JavaScript
9
star
45

generic-bitmask

Module to compute and manipulate bitmasks in JavaScript
JavaScript
9
star
46

postman-zendesk-support-theme

Zendesk v2 API theme support for Postman Support Center
Handlebars
8
star
47

letsencrypt-manager

JavaScript
7
star
48

swagger2-postman2-lambda

JavaScript
7
star
49

postmanlabs.github.io

Content for the laboratory website!
HTML
7
star
50

open-technologies-docs

Open Technology Documentation
JavaScript
6
star
51

postman-blog

JavaScript
6
star
52

intergalactic-apifirst

6
star
53

newman-reporter-remote

JavaScript
6
star
54

labs-docs

JavaScript
6
star
55

sails-hook-rewire

Installable sailsjs hook that lets you rewire sails components during tests
JavaScript
5
star
56

codegen-curl

curl snippet generator for Postman Requests
JavaScript
5
star
57

liquid-json

Implementation of JSON that ignores BOM and thows friendly error
JavaScript
5
star
58

uptime-monitors

5
star
59

galaxy-workshop

Supporting resources for the 2020 Postman Galaxy Tour
5
star
60

dhc-to-postman

Converts a DHC Project to a Postman Collection (v1)
JavaScript
5
star
61

postman-badge-checker

Used for checking and awarding Postman badges
5
star
62

node-oauth1

An implementation of OAuth1 signature generation
JavaScript
4
star
63

postman-api-environments-utils

Utilities to manage Postman environments using the Postman API.
JavaScript
4
star
64

postman-japanese-ea

Issue tracking for the Postman App Japanese Early Access release
4
star
65

serialised-error

Serialises error object to normal object
JavaScript
4
star
66

swagger1-to-postman

JavaScript
3
star
67

schema-compiler

json-schema-builder
JavaScript
3
star
68

sails-hook-responders

An installable sailsjs hook that adds policies, called responders, to a request
JavaScript
3
star
69

postman-validator

JavaScript
3
star
70

.github

3
star
71

learning-resources

3
star
72

postman-sdk-go

Go SDK powering Live Collections
Go
3
star
73

execute-postman-monitor

GitHub action that executes a Postman Monitor.
JavaScript
3
star
74

newman-orb

CircleCI Orb for running collections with Newman - https://circleci.com/orbs/registry/orb/postman/newman
3
star
75

async-domino

A module to allow time guaranteed asynchronous functions
JavaScript
3
star
76

har-to-postman

JavaScript
3
star
77

save-as-postman-request

Command line utility to process piped curl responses and create postman a request on a collection using the Postman API
JavaScript
3
star
78

solutions

Useful learning resources, scripts, videos, snippets and materials etc. collated by the Solutions Engineering team at Postman.
2
star
79

postman-learning

Postman and API Development
2
star
80

gists

2
star
81

examples

2
star
82

intergalactic-ice-cream

2
star
83

ical-json

JSON representation of calendar entries (with cron compatibility)
JavaScript
2
star
84

mime-format

Database to mime-format based on content-type header and content
JavaScript
2
star
85

pratishat

Percent-encode specific characters in the string
JavaScript
2
star
86

push-openapi-to-postman

Github action that pushes an OpenAPI in the repository to a specific API in a Postman workspace, creating a new version.
JavaScript
2
star
87

sails-env-switch

JavaScript
2
star
88

postman-mock-servers

1
star
89

raml-to-postman

RAML
1
star
90

packity

Sanity check of installed packages as per package.json
JavaScript
1
star
91

livestream-content

Content used and shared on Livestream events
Python
1
star
92

eslint-config-postman

Common ESLint rules for Postman! πŸ‘•
JavaScript
1
star
93

orbit-actions

1
star
94

collection-format-docs

Documentation for postman collection format, the open source specification that powers collections in postman
JavaScript
1
star
95

postman-collection-spectral-linter

Utility to lint and validate the quality of a Postman collection
JavaScript
1
star