0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Wired up adding post to collections to API

This commit is contained in:
Fabien "egg" O'Carroll 2023-06-01 00:17:00 -04:00 committed by naz
parent b48a1d0a57
commit 93bad82a24
5 changed files with 148 additions and 35 deletions

View file

@ -116,9 +116,9 @@ module.exports = {
// @NOTE: should have permissions when moving out of Alpha
permissions: false,
async query(frame) {
const collectionPost = await collectionsService.api.addPost(Object.assign(frame.data.collections[0], {
collection_id: frame.options.id
}), frame.options);
const collectionPost = await collectionsService.api.addPost(frame.options.id, {
id: frame.data.posts[0].id
});
if (!collectionPost) {
throw new errors.NotFoundError({

View file

@ -1,27 +1,41 @@
/**
*
* @param {import('@tryghost/collections').Collection} collection
* @param {import('@tryghost/collections').Collection | object} collection
*
* @returns {SerializedCollection}
*/
const mapper = (collection) => {
const json = collection.toJSON();
let json;
let posts;
if (collection.toJSON) {
json = collection.toJSON();
posts = json.posts.map((postId, index) => {
return {
id: postId,
sort_order: index
};
});
} else {
json = collection;
posts = json.posts.map((post) => {
return {
id: post.id,
sort_order: post.sort_order
};
});
}
const serialized = {
id: json.id,
title: json.title,
title: json.title || null,
slug: json.slug,
description: json.description,
description: json.description || null,
type: json.type,
filter: json.filter,
feature_image: json.featureImage,
created_at: json.createdAt.toISOString().replace(/\d{3}Z$/, '000Z'),
updated_at: json.updatedAt.toISOString().replace(/\d{3}Z$/, '000Z'),
posts: json.posts.map(post => ({
id: post.id,
title: post.title,
slug: post.slug
}))
feature_image: json.feature_image || json.featureImage || null,
created_at: (json.created_at || json.createdAt).toISOString().replace(/\d{3}Z$/, '000Z'),
updated_at: (json.updated_at || json.updatedAt).toISOString().replace(/\d{3}Z$/, '000Z'),
posts
};
return serialized;

View file

@ -1,30 +1,24 @@
const models = require('../../models');
const {
CollectionsService,
CollectionsRepositoryInMemory
} = require('@tryghost/collections');
const PostsDataRepositoryBookshelf = require('./PostsDataRepositoryBookshelf');
class CollectionsServiceWrapper {
api;
constructor() {
const collectionsRepositoryInMemory = new CollectionsRepositoryInMemory();
const postsDataRepositoryBookshelf = new PostsDataRepositoryBookshelf({
Post: models.Post
});
const collectionsService = new CollectionsService({
collectionsRepository: collectionsRepositoryInMemory,
postsRepository: postsDataRepositoryBookshelf
collectionsRepository: collectionsRepositoryInMemory
});
this.api = {
browse: collectionsService.getAll.bind(collectionsService),
read: collectionsService.getById.bind(collectionsService),
add: collectionsService.save.bind(collectionsService),
add: collectionsService.createCollection.bind(collectionsService),
edit: collectionsService.edit.bind(collectionsService),
addPost: collectionsService.addPost.bind(collectionsService),
addPost: collectionsService.addPostToCollection.bind(collectionsService),
destroy: collectionsService.destroy.bind(collectionsService)
};
}

View file

@ -322,12 +322,15 @@ Object {
"posts": Array [
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": 0,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": 1,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": 2,
},
],
"title": "Test Collection Edited",
@ -342,7 +345,7 @@ exports[`Collections API edit Can add Posts and append Post to a Collection 2: [
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"content-length": "346",
"content-length": "391",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
@ -364,12 +367,15 @@ Object {
"posts": Array [
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": 0,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": 1,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": 2,
},
],
"title": "Test Collection Edited",
@ -384,7 +390,103 @@ exports[`Collections API edit Can add Posts and append Post to a Collection 4: [
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"content-length": "346",
"content-length": "391",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
"vary": "Accept-Version, Origin, Accept-Encoding",
"x-powered-by": "Express",
}
`;
exports[`Collections API edit Can add Posts and append Post to a Collection 5: [body] 1`] = `
Object {
"collections": Array [
Object {
"created_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
"description": null,
"feature_image": null,
"filter": null,
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"posts": Array [
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
],
"title": "Test Collection Edited",
"type": "manual",
"updated_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
},
],
}
`;
exports[`Collections API edit Can add Posts and append Post to a Collection 6: [headers] 1`] = `
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"content-length": "440",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
"vary": "Accept-Version, Origin, Accept-Encoding",
"x-powered-by": "Express",
}
`;
exports[`Collections API edit Can add Posts and append Post to a Collection 7: [body] 1`] = `
Object {
"collections": Array [
Object {
"created_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
"description": null,
"feature_image": null,
"filter": null,
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"posts": Array [
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
Object {
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
"sort_order": Any<Number>,
},
],
"title": "Test Collection Edited",
"type": "manual",
"updated_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
},
],
}
`;
exports[`Collections API edit Can add Posts and append Post to a Collection 8: [headers] 1`] = `
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"content-length": "440",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,

View file

@ -11,7 +11,8 @@ const {
anyErrorId,
anyLocationFor,
anyObjectId,
anyISODateTime
anyISODateTime,
anyNumber
} = matchers;
const matchCollection = {
@ -24,12 +25,16 @@ const matchCollection = {
*
* @param {number} postCount
*/
const buildMatcher = (postCount) => {
const buildMatcher = (postCount, opts = {}) => {
let obj = {
id: anyObjectId
};
if (opts.withSortOrder) {
obj.sort_order = anyNumber;
}
return {
...matchCollection,
posts: Array(postCount).fill({
id: anyObjectId
})
posts: Array(postCount).fill(obj)
};
};
@ -234,9 +239,7 @@ describe('Collections API', function () {
etag: anyEtag
})
.matchBodySnapshot({
posts: [{
id: anyObjectId
}]
collections: [buildMatcher(4, {withSortOrder: true})]
});
// verify the posts are persisted across requests
@ -248,7 +251,7 @@ describe('Collections API', function () {
etag: anyEtag
})
.matchBodySnapshot({
collections: [buildMatcher(3)]
collections: [buildMatcher(4, {withSortOrder: true})]
});
assert.equal(readResponse.body.collections[0].posts.length, 4, 'Post should have been added to a Collection');