grunt-https-proxy

0.0.1 • Public • Published

grunt-https-proxy

Start http and https proxy server using http-proxy.

Getting Started

If you haven't used grunt before, be sure to check out the Getting Started guide.

From the same directory as your project's Gruntfile and package.json, install this plugin with the following command:

npm install grunt-https-proxy --save-dev

Once that's done, add this line to your project's Gruntfile:

grunt.loadNpmTasks('grunt-https-proxy');

If the plugin has been installed correctly, running grunt --help at the command line should list the newly-installed plugin's task or tasks. In addition, the plugin should be listed in package.json as a devDependency, which ensures that it will be installed whenever the npm install command is run.

The "proxy" task

Overview

In your project's Gruntfile, add a section named proxy to the data object passed into grunt.initConfig().

grunt.initConfig({
  proxy: {
    proxy1 : {
     options : {
     port : 8050,                 // start proxy server, listening to the port 8050
        target : {                   // make it forward all the requests to localhost:8011
          host: 'localhost',
          port: 8011
        }
          }
    },
    proxy2 : {
     options : {
     port : 8051,               // start proxy server, listening to the port 8051
              router : {                    // make it forward requests according to this table
          'localhost/host1' : 'localhost:8011',
          'localhost/host2' : 'localhost:8012'
              }
          }
    },
    proxy3 : {
      options : {
        port : 8443,               // start https proxy server, listening to the port 8443
        router : {                    // make it forward requests according to this table
          'localhost/host1' : 'localhost:8011',
          'localhost/host2' : 'localhost:8012'
        },
        https: {                       // Pass in relative path to security cert and key
          cert: 'certs/server.crt',
          ca: 'certs/ca.crt',
          key: 'certs/server.key'
        },
      }
    }
  }
})

Options

options.port

Type: Integer Default value: none

A port number to which the proxy server should listen

options.target

Type: Object Default value: none

An object with properties host and port. If this option is given then all the requests to the proxy server will be proxied to the specified target.

options.router

Type: Object Default value: none

Proxy table, which is a simple lookup table that maps incoming requests to proxy target locations. If options.target is also given the proxy table is totally ignored (this behaviour will be changed in the future).

options.https

Type: 'Object' Default value: none

This is the block of https options which will be passed through to http-proxy. If this configuration block exists, grunt-https-proxy will load the certificates and key from the specified relative file paths and pass them through to http-proxy. Http-proxy will then accept and serve https requests. If https options are not specified, http-proxy will accept and serve http requests.

Usage Examples

see tests

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using grunt.

Release History

(Nothing yet)

Readme

Keywords

none

Package Sidebar

Install

npm i grunt-https-proxy

Weekly Downloads

0

Version

0.0.1

License

none

Last publish

Collaborators

  • asegal