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

Removed formats from private posts in content api (#10154)

closes #10118

All behind a members labs switch for now

* Added filter for member only content

* Updated frame context

* Cleaned up members content check

* Cleanup

* Cleanup

* Ensured members filtering works without include=tags

* Protected against missing query

* Fixed usage of include vs withRelated

* Moved includeTags logic for members behind members flag to use tags

* Cleanup

* Update input serializer dependency

Co-Authored-By: rishabhgrg <zrishabhgarg@gmail.com>

* Added some explanations
This commit is contained in:
Rishabh Garg 2018-11-14 13:02:14 +05:30 committed by Fabien O'Carroll
parent 2f4b2151b3
commit b2201d4179
3 changed files with 52 additions and 0 deletions

View file

@ -2,6 +2,7 @@ const _ = require('lodash');
const debug = require('ghost-ignition').debug('api:v2:utils:serializers:input:posts'); const debug = require('ghost-ignition').debug('api:v2:utils:serializers:input:posts');
const url = require('./utils/url'); const url = require('./utils/url');
const utils = require('../../index'); const utils = require('../../index');
const labs = require('../../../../../services/labs');
function removeMobiledocFormat(frame) { function removeMobiledocFormat(frame) {
if (frame.options.formats && frame.options.formats.includes('mobiledoc')) { if (frame.options.formats && frame.options.formats.includes('mobiledoc')) {
@ -11,6 +12,14 @@ function removeMobiledocFormat(frame) {
} }
} }
function includeTags(frame) {
if (!frame.options.withRelated) {
frame.options.withRelated = ['tags'];
} else if (!frame.options.withRelated.includes('tags')) {
frame.options.withRelated.push('tags');
}
}
module.exports = { module.exports = {
browse(apiConfig, frame) { browse(apiConfig, frame) {
debug('browse'); debug('browse');
@ -39,6 +48,10 @@ module.exports = {
} }
// CASE: the content api endpoint for posts should not return mobiledoc // CASE: the content api endpoint for posts should not return mobiledoc
removeMobiledocFormat(frame); removeMobiledocFormat(frame);
if (labs.isSet('members')) {
// CASE: Members needs to have the tags to check if its allowed access
includeTags(frame);
}
} }
debug(frame.options); debug(frame.options);
@ -58,6 +71,10 @@ module.exports = {
frame.data.page = false; frame.data.page = false;
// CASE: the content api endpoint for posts should not return mobiledoc // CASE: the content api endpoint for posts should not return mobiledoc
removeMobiledocFormat(frame); removeMobiledocFormat(frame);
if (labs.isSet('members')) {
// CASE: Members needs to have the tags to check if its allowed access
includeTags(frame);
}
} }
debug(frame.options); debug(frame.options);

View file

@ -1,6 +1,7 @@
const utils = require('../../../index'); const utils = require('../../../index');
const url = require('./url'); const url = require('./url');
const date = require('./date'); const date = require('./date');
const members = require('./members');
const mapPost = (model, frame) => { const mapPost = (model, frame) => {
const jsonModel = model.toJSON(frame.options); const jsonModel = model.toJSON(frame.options);
@ -9,6 +10,7 @@ const mapPost = (model, frame) => {
if (utils.isContentAPI(frame)) { if (utils.isContentAPI(frame)) {
date.forPost(jsonModel); date.forPost(jsonModel);
members.forPost(jsonModel, frame);
} }
if (frame.options && frame.options.withRelated) { if (frame.options && frame.options.withRelated) {

View file

@ -0,0 +1,33 @@
const labs = require('../../../../../../services/labs');
const MEMBER_TAG = '#members';
// Checks if request should hide memnbers only content
function hideMembersOnlyContent(attrs, frame) {
let hasMemberTag = false;
if (labs.isSet('members') && !frame.original.context.member && attrs.tags) {
hasMemberTag = attrs.tags.find((tag) => {
return (tag.name === MEMBER_TAG);
});
}
return hasMemberTag;
}
const forPost = (attrs, frame) => {
const hideFormatsData = hideMembersOnlyContent(attrs, frame);
if (hideFormatsData) {
['plaintext', 'html'].forEach((field) => {
attrs[field] = '';
});
}
if (labs.isSet('members')) {
// CASE: Members always adds tags, remove if the user didn't originally ask for them
const origQuery = frame.original.query || {};
if (!origQuery.include || !origQuery.include.includes('tags')) {
delete attrs.tags;
}
}
return attrs;
};
module.exports.forPost = forPost;