c4c48d4104
refs https://github.com/TryGhost/Admin/pull/2209 - `miragejs` has been extracted to a framework-independent library, the re-exports of `miragejs` elements in `ember-cli-mirage` have been deprecated making our test logs very noisy - added `miragejs` as a top-level dependency - updated all relevant imports to pull from `miragejs` instead of `ember-cli-mirage`
68 lines
2.3 KiB
JavaScript
68 lines
2.3 KiB
JavaScript
import moment from 'moment';
|
|
import {Response} from 'miragejs';
|
|
import {paginatedResponse} from '../utils';
|
|
|
|
export default function mockIntegrations(server) {
|
|
server.get('/integrations/', paginatedResponse('integrations'));
|
|
|
|
server.post('/integrations/', function ({integrations}, {requestBody}) {
|
|
let body = JSON.parse(requestBody);
|
|
let [params] = body.integrations;
|
|
|
|
// all integrations created via the API have a type of 'custom'
|
|
params.type = 'custom';
|
|
|
|
if (!params.name) {
|
|
return new Response(422, {}, {errors: [{
|
|
type: 'ValidationError',
|
|
message: 'Name is required',
|
|
property: 'name'
|
|
}]});
|
|
}
|
|
|
|
if (integrations.findBy({name: params.name}) || params.name.match(/Duplicate/i)) {
|
|
return new Response(422, {}, {errors: [{
|
|
type: 'ValidationError',
|
|
message: 'Name has already been used',
|
|
property: 'name'
|
|
}]});
|
|
}
|
|
|
|
// allow factory to create defaults
|
|
if (!params.slug) {
|
|
delete params.slug;
|
|
}
|
|
|
|
// use factory creation to auto-create api keys
|
|
return server.create('integration', params);
|
|
});
|
|
|
|
server.put('/integrations/:id/', function (schema, {params}) {
|
|
let {integrations, apiKeys, webhooks} = schema;
|
|
let attrs = this.normalizedRequestAttrs();
|
|
let integration = integrations.find(params.id);
|
|
let _apiKeys = [];
|
|
let _webhooks = [];
|
|
|
|
// this is required to work around an issue with ember-cli-mirage and
|
|
// embedded records. The `attrs` object will contain POJOs of the
|
|
// embedded apiKeys and webhooks but mirage expects schema model
|
|
// objects for relations so we need to fetch model records and replace
|
|
// the relationship keys
|
|
attrs.apiKeys.forEach((apiKey) => {
|
|
_apiKeys.push(apiKeys.find(apiKey.id));
|
|
});
|
|
attrs.webhooks.forEach((webhook) => {
|
|
_webhooks.push(webhooks.find(webhook.id));
|
|
});
|
|
attrs.apiKeys = _apiKeys;
|
|
attrs.webhooks = _webhooks;
|
|
|
|
attrs.updatedAt = moment.utc().format();
|
|
|
|
return integration.update(attrs);
|
|
});
|
|
|
|
server.del('/integrations/:id/');
|
|
}
|