travis-web/mirage/config.js
2016-03-07 13:28:51 +01:00

140 lines
3.8 KiB
JavaScript

import Ember from 'ember';
import Mirage from 'ember-cli-mirage';
export default function() {
let _turnIntoV3Singular = function(type, record) {
if(record.attrs) {
record = record.attrs;
}
record['@type'] = type;
record['@href'] = `/${type}/${record.id}`;
return record;
};
let turnIntoV3 = function(type, payload) {
let response;
if(Ember.isArray(payload)) {
let records = payload.map( (record) => { return _turnIntoV3Singular(type, record); } );
let pluralized = Ember.String.pluralize(type);
response = {};
response['@type'] = pluralized;
response['@href'] = `/${pluralized}`;
response[pluralized] = records;
} else {
response = _turnIntoV3Singular(type, payload);
}
return response;
};
this.get('/repos', function(schema, request) {
return turnIntoV3('repository', schema.repository.all());
});
this.get('/repo/:slug', function(schema, request) {
let repos = schema.repository.where({ slug: decodeURIComponent(request.params.slug) });
return turnIntoV3('repository', repos[0]);
});
this.get('/jobs/:id', function(schema, request) {
let job = schema.job.find(request.params.id).attrs;
return {job: job, commit: schema.commit.find(job.commit_id).attrs};
});
this.get('/jobs', function(schema, request) {
return {jobs: schema.job.all()};
});
this.get('/builds/:id', function(schema, request) {
let build = schema.build.find(request.params.id).attrs;
return {build: build, commit: schema.commit.find(build.commit_id).attrs};
});
this.get('/jobs/:id/log', function(schema, request) {
let log = schema.log.find(request.params.id);
if(log) {
return { log: { parts: [{ id: log.attrs.id, number: 1, content: log.attrs.content}] }};
} else {
return new Mirage.Response(404, {}, {});
}
});
// These comments are here to help you get started. Feel free to delete them.
/*
Config (with defaults).
Note: these only affect routes defined *after* them!
*/
// this.urlPrefix = ''; // make this `http://localhost:8080`, for example, if your API is on a different server
// this.namespace = ''; // make this `api`, for example, if your API is namespaced
// this.timing = 400; // delay for each request, automatically set to 0 during testing
/*
Route shorthand cheatsheet
*/
/*
GET shorthands
// Collections
this.get('/contacts');
this.get('/contacts', 'users');
this.get('/contacts', ['contacts', 'addresses']);
// Single objects
this.get('/contacts/:id');
this.get('/contacts/:id', 'user');
this.get('/contacts/:id', ['contact', 'addresses']);
*/
/*
POST shorthands
this.post('/contacts');
this.post('/contacts', 'user'); // specify the type of resource to be created
*/
/*
PUT shorthands
this.put('/contacts/:id');
this.put('/contacts/:id', 'user'); // specify the type of resource to be updated
*/
/*
DELETE shorthands
this.del('/contacts/:id');
this.del('/contacts/:id', 'user'); // specify the type of resource to be deleted
// Single object + related resources. Make sure parent resource is first.
this.del('/contacts/:id', ['contact', 'addresses']);
*/
/*
Function fallback. Manipulate data in the db via
- db.{collection}
- db.{collection}.find(id)
- db.{collection}.where(query)
- db.{collection}.update(target, attrs)
- db.{collection}.remove(target)
// Example: return a single object with related models
this.get('/contacts/:id', function(db, request) {
var contactId = +request.params.id;
return {
contact: db.contacts.find(contactId),
addresses: db.addresses.where({contact_id: contactId})
};
});
*/
}
/*
You can optionally export a config that is only loaded during tests
export function testConfig() {
}
*/