1.0.5 • Published 2 years ago
request-options-gen v1.0.5
request-options-gen
JS Library to generate options for request library by templates files
Install
npm install --save request
npm install --save request-options-genSuper simple to use:
var rog = require('request-options-gen');
var request = require('request');
var options = rog.gen({
  basePath: 'tests/data',
  path: 'reqres/list-users'
});
console.log('Options: ');
console.log(JSON.stringify(options));
request(options,  function (error, response, body) {
  console.log('\nBody: ');
  console.log(JSON.stringify(JSON.parse(body)));
});Will process the following files with this template folder:
♦
└┄ ▼ tests
   └┄ ▼ data
      ├┄ ▼ reqres
      │  ├┄ ▼ list-users
      │  │  ├┄ • qs.txt
      │  │  └┄ • url.txt
      │  ├┄ • default-headers.txt
      │  └┄ • init-config.js
      ├┄ • config.js
      └┄ • generic-headers.txtOptions:
{
	"headers": {
		"Content-Type": "application/json",
		"gtw-transaction-id": "2017-09-28T16:33:45.280Z-Note_M_17294",
		"Pragma": "no-cache",
		"Cache-Control": "no-cache"
	},
	"qs": {
		"page": "2"
	},
	"url": "https://reqres.in/api/users"
}
Body: 
{
	"page": 2,
	"per_page": 3,
	"total": 12,
	"total_pages": 4,
	"data": [{
			"id": 4,
			"first_name": "Eve",
			"last_name": "Holt",
			"avatar": "https://s3.amazonaws.com/uifaces/faces/twitter/marcoramires/128.jpg"
		}, {
			"id": 5,
			"first_name": "Charles",
			"last_name": "Morris",
			"avatar": "https://s3.amazonaws.com/uifaces/faces/twitter/stephenmoon/128.jpg"
		}, {
			"id": 6,
			"first_name": "Tracey",
			"last_name": "Ramos",
			"avatar": "https://s3.amazonaws.com/uifaces/faces/twitter/bigmancho/128.jpg"
		}
	]
}Table of contents
Methods
See: Options Method 1: Without edit options
const rog = require('request-options-gen');
rog.gen(options).request(callback);Method 2: Permit edit options
const request = require('request');
const rog = require('request-options-gen');
let data = rog.gen(options);
request(data.options, callback);Options
Specials Files
Named files that end with:
url.txt
Generate:
{
  "url": "${value}"
}Sample File 1:
http://google.com
  ↕
{
  "url": "http://google.com"
}Sample File 2:
`http://${p.host}:${p.port}.com/my-url/`
  ↕
{
  "url": "http://my-host:8080.com/my-url/"
}qs.txt
Generate:
{
  "qs": {
    "${attr-name-1}": "${attr-value}",
    "${attr-name-2}": "${attr-value}",
    "${attr-name-n}": "${attr-value}"
  }
}Sample File:
id:`require('uuid/v4')()`
page:2
  ↕
{
  "qs": {
    "id": "110ec58a-a0f2-4ac4-8393-c866d813b8d1",
    "page": "2"
  }
}headers.txt
{
  "headers": {
    "${attr-name-1}": "${attr-value}",
    "${attr-name-2}": "${attr-value}",
    "${attr-name-n}": "${attr-value}"
  }
}Sample File:
Pragma:no-cache
Cache-Control:no-cache
x-time:`new Date().toISOString()`
  ↕
{
  "headers": {
    "Pragma": "no-cache",
    "Cache-Control": "no-cache",
    "x-time": "2017-10-02T14:11:35.511Z"
  }
}body.txt
{
  "body": "${value}"
}config.js
Generates temporary values to be used by other processors.
Sample:
data/main-config.js
'use strict';
module.exports = function (p) {
  p.env = process.env.ENVIRONMENT || 'PRD';
  p.hotels = p.hotels || {};
  p.hotels.middleware = p.hotels.middleware || {};
  switch (p.env) {
    case 'PRD':
      p.hotels.middleware.host = 'prod.sample.com.br';
      p.hotels.middleware.port = '80';
      break;
    default:
      p.hotels.middleware.host = '127.0.0.1';
      p.hotels.middleware.port = '7011';
  }
};data/hotel/url.txt
`http://${p.hotels.middleware.host}:${p.hotels.middleware.port}/hotels`Generate:
- if ENVIRONMENT == PRD: http://prod.sample.com.br:80/hotels
- if ENVIRONMENT <> PRD: http://127.0.0.1:7011/hotels