insomnia/app/models/request.js

218 lines
5.7 KiB
JavaScript
Raw Normal View History

import {METHOD_GET, getContentTypeFromHeaders, CONTENT_TYPE_FORM_URLENCODED, CONTENT_TYPE_FORM_DATA, CONTENT_TYPE_FILE} from '../common/constants';
2016-11-10 05:56:23 +00:00
import * as db from '../common/database';
2016-11-10 17:33:28 +00:00
import {getContentTypeHeader} from '../common/misc';
import {deconstructToParams, buildFromParams} from '../common/querystring';
export const name = 'Request';
export const type = 'Request';
export const prefix = 'req';
export function init () {
2016-11-10 01:15:27 +00:00
return {
url: '',
name: 'New Request',
method: METHOD_GET,
body: {},
parameters: [],
headers: [],
authentication: {},
2017-01-24 22:18:11 +00:00
metaSortKey: -1 * Date.now(),
2016-11-10 01:15:27 +00:00
};
}
export function newBodyRaw (rawBody, contentType) {
if (typeof contentType !== 'string') {
return {text: rawBody};
}
const mimeType = contentType.split(';')[0];
return {mimeType, text: rawBody};
}
export function newBodyFormUrlEncoded (parameters) {
// Remove any properties (eg. fileName) that might not fit
parameters = (parameters || []).map(parameter => {
const newParameter = {
name: parameter.name,
value: parameter.value
};
if (parameter.hasOwnProperty('id')) {
newParameter.id = parameter.id;
}
if (parameter.hasOwnProperty('disabled')) {
newParameter.disabled = parameter.disabled;
} else {
newParameter.disabled = false;
}
return newParameter;
});
return {
mimeType: CONTENT_TYPE_FORM_URLENCODED,
params: parameters
}
}
2016-11-22 22:26:52 +00:00
export function newBodyFile (path) {
return {
mimeType: CONTENT_TYPE_FILE,
fileName: path
}
}
export function newBodyForm (parameters) {
return {
mimeType: CONTENT_TYPE_FORM_DATA,
params: parameters || []
}
}
export function migrate (doc) {
doc = migrateBody(doc);
doc = migrateWeirdUrls(doc);
return doc;
}
export function create (patch = {}) {
2016-09-21 20:32:45 +00:00
if (!patch.parentId) {
throw new Error('New Requests missing `parentId`', patch);
}
return db.docCreate(type, patch);
}
2016-09-21 20:32:45 +00:00
export function getById (id) {
return db.get(type, id);
}
2016-09-21 20:32:45 +00:00
export function findByParentId (parentId) {
return db.find(type, {parentId: parentId});
}
2016-09-21 20:32:45 +00:00
export function update (request, patch) {
2016-09-21 20:32:45 +00:00
return db.docUpdate(request, patch);
}
2016-09-21 20:32:45 +00:00
export function updateMimeType (request, mimeType, doCreate = false) {
let headers = request.headers ? [...request.headers] : [];
2016-11-10 17:33:28 +00:00
const contentTypeHeader = getContentTypeHeader(headers);
2016-09-21 20:32:45 +00:00
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ //
// 1. Update Content-Type header //
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ //
if (!mimeType) {
2016-09-21 20:32:45 +00:00
// Remove the contentType header if we are un-setting it
headers = headers.filter(h => h !== contentTypeHeader);
} else if (contentTypeHeader) {
contentTypeHeader.value = mimeType;
2016-09-21 20:32:45 +00:00
} else {
headers.push({name: 'Content-Type', value: mimeType})
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~ //
// 2. Make a new request body //
// ~~~~~~~~~~~~~~~~~~~~~~~~~~ //
let body;
if (mimeType === request.body.mimeType) {
// Unchanged
body = request.body;
} else if (mimeType === CONTENT_TYPE_FORM_URLENCODED) {
// Urlencoded
body = request.body.params ?
newBodyFormUrlEncoded(request.body.params) :
newBodyFormUrlEncoded(deconstructToParams(request.body.text));
} else if (mimeType === CONTENT_TYPE_FORM_DATA) {
// Form Data
body = request.body.params ?
newBodyForm(request.body.params) :
newBodyForm(deconstructToParams(request.body.text));
2016-11-22 22:26:52 +00:00
} else if (mimeType === CONTENT_TYPE_FILE) {
// File
body = newBodyFile('');
} else if (typeof mimeType !== 'string') {
// No body
body = newBodyRaw('');
} else {
// Raw Content-Type (ex: application/json)
body = request.body.params ?
newBodyRaw(buildFromParams(request.body.params, false), mimeType) :
newBodyRaw(request.body.text || '', mimeType);
2016-09-21 20:32:45 +00:00
}
// ~~~~~~~~~~~~~~~~~~~~~~~~ //
// 2. create/update request //
// ~~~~~~~~~~~~~~~~~~~~~~~~ //
if (doCreate) {
return create(Object.assign({}, request, {headers, body}));
} else {
return update(request, {headers, body});
}
}
2016-09-21 20:32:45 +00:00
export async function duplicate (request) {
2016-09-21 20:32:45 +00:00
const name = `${request.name} (Copy)`;
// Get sort key of next request
const q = {metaSortKey: {$gt: request.metaSortKey}};
const [nextRequest] = await db.find(type, q, {metaSortKey: 1});
const nextSortKey = nextRequest ? nextRequest.metaSortKey : request.metaSortKey + 100;
// Calculate new sort key
const sortKeyIncrement = (nextSortKey - request.metaSortKey) / 2;
const metaSortKey = request.metaSortKey + sortKeyIncrement;
2016-11-10 01:15:27 +00:00
return db.duplicate(request, {name, metaSortKey})
}
2016-09-21 20:32:45 +00:00
export function remove (request) {
2016-09-21 20:32:45 +00:00
return db.remove(request);
}
export function all () {
return db.all(type);
}
// ~~~~~~~~~~ //
// Migrations //
// ~~~~~~~~~~ //
function migrateBody (request) {
2016-12-01 18:48:49 +00:00
if (request.body && typeof request.body === 'object') {
return request;
}
// Second, convert all existing urlencoded bodies to new format
const contentType = getContentTypeFromHeaders(request.headers) || '';
const wasFormUrlEncoded = !!contentType.match(/^application\/x-www-form-urlencoded/i);
if (wasFormUrlEncoded) {
// Convert old-style form-encoded request bodies to new style
const params = deconstructToParams(request.body, false);
request.body = newBodyFormUrlEncoded(params);
2016-12-01 18:48:49 +00:00
} else if (!request.body && !contentType) {
request.body = {};
} else {
request.body = newBodyRaw(request.body, contentType);
}
return request;
}
function migrateWeirdUrls (request) {
// Some people seem to have requests with URLs that don't have the indexOf
// function. This should clear that up. This can be removed at a later date.
if (typeof request.url !== 'string') {
request.url = '';
}
return request;
}