const url = require('url'); const _ = require('lodash'); const testUtils = require('../../utils'); const schema = require('../../../core/server/data/schema').tables; const API_URL = '/ghost/api/v3/content/'; const expectedProperties = { // API top level posts: ['posts', 'meta'], tags: ['tags', 'meta'], authors: ['authors', 'meta'], pagination: ['page', 'limit', 'pages', 'total', 'next', 'prev'], post: _(schema.posts) .keys() // by default we only return html .without('mobiledoc', 'plaintext') // v2 doesn't return author_id OR author .without('author_id', 'author') // and always returns computed properties: url .concat('url') // v2 API doesn't return unused fields .without('locale') // These fields aren't useful as they always have known values .without('status') // v2 API doesn't return new type field .without('type') // @TODO: https://github.com/TryGhost/Ghost/issues/10335 // .without('page') // v2 returns a calculated excerpt field .concat('excerpt') // Access is a calculated property in >= v3 .concat('access') // returns meta fields from `posts_meta` schema .concat( ..._(schema.posts_meta).keys().without('post_id', 'id') ) .concat('reading_time') .concat('send_email_when_published') , author: _(schema.users) .keys() .without( 'password', 'email', 'created_at', 'created_by', 'updated_at', 'updated_by', 'last_seen', 'status' ) // v2 API doesn't return unused fields .without('accessibility', 'locale', 'tour', 'visibility') , tag: _(schema.tags) .keys() // v2 Tag API doesn't return parent_id or parent .without('parent_id', 'parent') // v2 Tag API doesn't return date fields .without('created_at', 'updated_at') }; _.each(expectedProperties, (value, key) => { if (!value.__wrapped__) { return; } /** * @deprecated: x_by */ expectedProperties[key] = value .without( 'created_by', 'updated_by', 'published_by' ) .value(); }); module.exports = { API: { getApiQuery(route) { return url.resolve(API_URL, route); }, checkResponse(...args) { this.expectedProperties = expectedProperties; return testUtils.API.checkResponse.call(this, ...args); } }, getValidKey() { return testUtils.DataGenerator.Content.api_keys[1].secret; } };