mirror of
https://github.com/Kong/insomnia
synced 2024-11-08 23:00:30 +00:00
46d3719b99
* Maybe working POC * Change to use remote url * Other URL too * Some logic * Got the push part working * Made some updates * Fix * Update * Add status code check * Stuff * Implemented new sync api * A bit more robust * Debounce changes * Change timeout * Some fixes * Remove .less * Better error handling * Fix base url * Support for created vs updated docs * Try silent * Silence removal too * Small fix after merge * Fix test * Stuff * Implement key generation algorithm * Tidy * stuff * A bunch of stuff for the new API * Integrated the session stuff * Stuff * Just started on encryption * Lots of updates to encryption * Finished createResourceGroup function * Full encryption/decryption working (I think) * Encrypt localstorage with sessionID * Some more * Some extra checks * Now uses separate DB. Still needs to be simplified a LOT * Fix deletion bug * Fixed unicode bug with encryption * Simplified and working * A bunch of polish * Some stuff * Removed some workspace meta properties * Migrated a few more meta properties * Small changes * Fix body scrolling and url cursor jumping * Removed duplication of webpack port * Remove workspaces reduces * Some small fixes * Added sync modal and opt-in setting * Good start to sync flow * Refactored modal footer css * Update sync status * Sync logger * A bit better logging * Fixed a bunch of sync-related bugs * Fixed signup form button * Gravatar component * Split sync modal into tabs * Tidying * Some more error handling * start sending 'user agent * Login/signup error handling * Use real UUIDs * Fixed tests * Remove unused function * Some extra checks * Moved cloud sync setting to about page * Some small changes * Some things
73 lines
1.6 KiB
JavaScript
73 lines
1.6 KiB
JavaScript
import {PREVIEW_MODE_SOURCE} from '../../previewModes';
|
|
import {METHOD_GET} from '../../constants';
|
|
import * as db from '../index';
|
|
|
|
export const type = 'Request';
|
|
export const prefix = 'req';
|
|
|
|
export function init () {
|
|
return db.initModel({
|
|
url: '',
|
|
name: 'New Request',
|
|
method: METHOD_GET,
|
|
body: '',
|
|
parameters: [],
|
|
headers: [],
|
|
authentication: {},
|
|
metaPreviewMode: PREVIEW_MODE_SOURCE,
|
|
metaResponseFilter: '',
|
|
metaSortKey: -1 * Date.now()
|
|
});
|
|
}
|
|
|
|
export function create (patch = {}) {
|
|
if (!patch.parentId) {
|
|
throw new Error('New Requests missing `parentId`', patch);
|
|
}
|
|
|
|
return db.docCreate(type, patch);
|
|
}
|
|
|
|
export function getById (id) {
|
|
return db.get(type, id);
|
|
}
|
|
|
|
export function findByParentId (parentId) {
|
|
return db.find(type, {parentId: parentId});
|
|
}
|
|
|
|
export function update (request, patch) {
|
|
return db.docUpdate(request, patch);
|
|
}
|
|
|
|
export function updateContentType (request, contentType) {
|
|
let headers = [...request.headers];
|
|
const contentTypeHeader = headers.find(
|
|
h => h.name.toLowerCase() === 'content-type'
|
|
);
|
|
|
|
if (!contentType) {
|
|
// Remove the contentType header if we are un-setting it
|
|
headers = headers.filter(h => h !== contentTypeHeader);
|
|
} else if (contentTypeHeader) {
|
|
contentTypeHeader.value = contentType;
|
|
} else {
|
|
headers.push({name: 'Content-Type', value: contentType})
|
|
}
|
|
|
|
return db.docUpdate(request, {headers});
|
|
}
|
|
|
|
export function duplicate (request) {
|
|
const name = `${request.name} (Copy)`;
|
|
return db.duplicate(request, {name})
|
|
}
|
|
|
|
export function remove (request) {
|
|
return db.remove(request);
|
|
}
|
|
|
|
export function all () {
|
|
return db.all(type);
|
|
}
|