mirror of
https://github.com/Kong/insomnia
synced 2024-11-08 23:00:30 +00:00
0a616fba6b
* VCS proof of concept underway! * Stuff * Some things * Replace deprecated Electron makeSingleInstance * Rename `window` variables so not to be confused with window object * Don't unnecessarily update request when URL does not change * Regenerate package-lock * Fix tests + ESLint * Publish - insomnia-app@1.0.49 - insomnia-cookies@0.0.12 - insomnia-httpsnippet@1.16.18 - insomnia-importers@2.0.13 - insomnia-libcurl@0.0.23 - insomnia-prettify@0.1.7 - insomnia-url@0.1.6 - insomnia-xpath@1.0.9 - insomnia-plugin-base64@1.0.6 - insomnia-plugin-cookie-jar@1.0.8 - insomnia-plugin-core-themes@1.0.5 - insomnia-plugin-default-headers@1.1.9 - insomnia-plugin-file@1.0.7 - insomnia-plugin-hash@1.0.7 - insomnia-plugin-jsonpath@1.0.12 - insomnia-plugin-now@1.0.11 - insomnia-plugin-os@1.0.13 - insomnia-plugin-prompt@1.1.9 - insomnia-plugin-request@1.0.18 - insomnia-plugin-response@1.0.16 - insomnia-plugin-uuid@1.0.10 * Broken but w/e * Some tweaks * Big refactor. Create local snapshots and push done * POC merging and a lot of improvements * Lots of work done on initial UI/UX * Fix old tests * Atomic writes and size-based batches * Update StageEntry definition once again to be better * Factor out GraphQL query logic * Merge algorithm, history modal, other minor things * Fix test * Merge, checkout, revert w/ user changes now work * Force UI to refresh when switching branches changes active request * Rough draft pull() and some cleanup * E2EE stuff and some refactoring * Add ability to share project with team and fixed tests * VCS now created in root component and better remote project handling * Remove unused definition * Publish - insomnia-account@0.0.2 - insomnia-app@1.1.1 - insomnia-cookies@0.0.14 - insomnia-httpsnippet@1.16.20 - insomnia-importers@2.0.15 - insomnia-libcurl@0.0.25 - insomnia-prettify@0.1.9 - insomnia-sync@0.0.2 - insomnia-url@0.1.8 - insomnia-xpath@1.0.11 - insomnia-plugin-base64@1.0.8 - insomnia-plugin-cookie-jar@1.0.10 - insomnia-plugin-core-themes@1.0.7 - insomnia-plugin-file@1.0.9 - insomnia-plugin-hash@1.0.9 - insomnia-plugin-jsonpath@1.0.14 - insomnia-plugin-now@1.0.13 - insomnia-plugin-os@1.0.15 - insomnia-plugin-prompt@1.1.11 - insomnia-plugin-request@1.0.20 - insomnia-plugin-response@1.0.18 - insomnia-plugin-uuid@1.0.12 * Move some deps around * Fix Flow errors * Update package.json * Fix eslint errors * Fix tests * Update deps * bootstrap insomnia-sync * TRy fixing appveyor * Try something else * Bump lerna * try powershell * Try again * Fix imports * Fixed errors * sync types refactor * Show remote projects in workspace dropdown * Improved pulling of non-local workspaces * Loading indicators and some tweaks * Clean up sync staging modal * Some sync improvements: - No longer store stage - Upgrade Electron - Sync UI/UX improvements * Fix snyc tests * Upgraded deps and hot loader tweaks (it's broken for some reason) * Fix tests * Branches dialog, network refactoring, some tweaks * Fixed merging when other branch is empty * A bunch of small fixes from real testing * Fixed pull merge logic * Fix tests * Some bug fixes * A few small tweaks * Conflict resolution and other improvements * Fix tests * Add revert changes * Deal with duplicate projects per workspace * Some tweaks and accessibility improvements * Tooltip accessibility * Fix API endpoint * Fix tests * Remove jest dep from insomnia-importers
147 lines
3.7 KiB
JavaScript
147 lines
3.7 KiB
JavaScript
// @flow
|
|
import * as _clientCertificate from './client-certificate';
|
|
import * as _cookieJar from './cookie-jar';
|
|
import * as _environment from './environment';
|
|
import * as _oAuth2Token from './o-auth-2-token';
|
|
import * as _pluginData from './plugin-data';
|
|
import * as _request from './request';
|
|
import * as _requestGroup from './request-group';
|
|
import * as _requestGroupMeta from './request-group-meta';
|
|
import * as _requestMeta from './request-meta';
|
|
import * as _requestVersion from './request-version';
|
|
import * as _response from './response';
|
|
import * as _settings from './settings';
|
|
import * as _stats from './stats';
|
|
import * as _workspace from './workspace';
|
|
import * as _workspaceMeta from './workspace-meta';
|
|
import { generateId } from '../common/misc';
|
|
|
|
export type BaseModel = {
|
|
_id: string,
|
|
type: string,
|
|
parentId: string,
|
|
modified: number,
|
|
created: number,
|
|
};
|
|
|
|
// Reference to each model
|
|
export const clientCertificate = _clientCertificate;
|
|
export const cookieJar = _cookieJar;
|
|
export const environment = _environment;
|
|
export const oAuth2Token = _oAuth2Token;
|
|
export const pluginData = _pluginData;
|
|
export const request = _request;
|
|
export const requestGroup = _requestGroup;
|
|
export const requestGroupMeta = _requestGroupMeta;
|
|
export const requestMeta = _requestMeta;
|
|
export const requestVersion = _requestVersion;
|
|
export const response = _response;
|
|
export const settings = _settings;
|
|
export const stats = _stats;
|
|
export const workspace = _workspace;
|
|
export const workspaceMeta = _workspaceMeta;
|
|
|
|
export function all() {
|
|
return [
|
|
stats,
|
|
settings,
|
|
workspace,
|
|
workspaceMeta,
|
|
environment,
|
|
cookieJar,
|
|
requestGroup,
|
|
requestGroupMeta,
|
|
request,
|
|
requestVersion,
|
|
requestMeta,
|
|
response,
|
|
oAuth2Token,
|
|
clientCertificate,
|
|
pluginData,
|
|
];
|
|
}
|
|
|
|
export function types(): Array<any> {
|
|
return all().map(model => model.type);
|
|
}
|
|
|
|
export function canSync(d: BaseModel): boolean {
|
|
if ((d: any).isPrivate) {
|
|
return false;
|
|
}
|
|
|
|
const m = getModel(d.type);
|
|
if (!m) {
|
|
return false;
|
|
}
|
|
|
|
return m.canSync || false;
|
|
}
|
|
|
|
export function getModel(type: string): Object | null {
|
|
return all().find(m => m.type === type) || null;
|
|
}
|
|
|
|
export function canDuplicate(type: string) {
|
|
const model = getModel(type);
|
|
return model ? model.canDuplicate : false;
|
|
}
|
|
|
|
export function getModelName(type: string, count: number = 1) {
|
|
const model = getModel(type);
|
|
if (!model) {
|
|
return 'Unknown';
|
|
} else if (count === 1) {
|
|
return model.name;
|
|
} else if (!model.name.match(/s$/)) {
|
|
// Add an 's' if it doesn't already end in one
|
|
return `${model.name}s`;
|
|
} else {
|
|
return model.name;
|
|
}
|
|
}
|
|
|
|
export async function initModel<T: BaseModel>(type: string, ...sources: Array<Object>): Promise<T> {
|
|
const model = getModel(type);
|
|
|
|
if (!model) {
|
|
const choices = all()
|
|
.map(m => m.type)
|
|
.join(', ');
|
|
throw new Error(`Tried to init invalid model "${type}". Choices are ${choices}`);
|
|
}
|
|
|
|
// Define global default fields
|
|
const objectDefaults = Object.assign(
|
|
{},
|
|
{
|
|
_id: null,
|
|
type: type,
|
|
parentId: null,
|
|
modified: Date.now(),
|
|
created: Date.now(),
|
|
},
|
|
model.init(),
|
|
);
|
|
|
|
const fullObject = Object.assign({}, objectDefaults, ...sources);
|
|
|
|
// Generate an _id if there isn't one yet
|
|
if (!fullObject._id) {
|
|
fullObject._id = generateId(model.prefix);
|
|
}
|
|
|
|
// Migrate the model
|
|
// NOTE: Do migration before pruning because we might need to look at those fields
|
|
const migratedDoc = await model.migrate(fullObject);
|
|
|
|
// Prune extra keys from doc
|
|
for (const key of Object.keys(migratedDoc)) {
|
|
if (!objectDefaults.hasOwnProperty(key)) {
|
|
delete migratedDoc[key];
|
|
}
|
|
}
|
|
|
|
return migratedDoc;
|
|
}
|