2020-01-03 09:17:34 +00:00
|
|
|
import { RequestHandler } from "../entities/RequestHandler";
|
|
|
|
import { UserHelper } from "../helpers/UserHelper";
|
|
|
|
import { PostsHelper } from "../helpers/PostsHelper";
|
2020-01-04 14:07:24 +00:00
|
|
|
import { Post, PostVisibilityLevel, PostKind, PostAccessLevel, PostPageKind } from "../entities/Post";
|
2020-01-03 09:24:05 +00:00
|
|
|
import { MoviesController } from "./MoviesController";
|
|
|
|
import { MoviesHelper } from "../helpers/MoviesHelper";
|
2020-01-03 13:37:54 +00:00
|
|
|
import { SurveyHelper } from "../helpers/SurveyHelper";
|
|
|
|
import { SurveyController } from "./SurveyController";
|
2020-01-03 13:49:56 +00:00
|
|
|
import { LikesHelper, LikesType } from "../helpers/LikesHelper";
|
2020-01-03 16:31:39 +00:00
|
|
|
import { CommentsHelper } from "../helpers/CommentsHelper";
|
|
|
|
import { CommentsController } from "./CommentsController";
|
2020-01-04 09:27:54 +00:00
|
|
|
import { GroupsAccessLevel } from "../entities/Group";
|
2020-01-04 14:07:24 +00:00
|
|
|
import { GroupsHelper } from "../helpers/GroupsHelper";
|
2020-01-04 14:25:26 +00:00
|
|
|
import { time } from "../utils/DateUtils";
|
|
|
|
import { findKey } from "../utils/ArrayUtils";
|
2020-01-03 09:17:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Posts controller
|
|
|
|
*
|
|
|
|
* @author Pierre HUBERT
|
|
|
|
*/
|
|
|
|
|
|
|
|
const VISIBILITY_LEVELS_API = {};
|
|
|
|
VISIBILITY_LEVELS_API[PostVisibilityLevel.VISIBILITY_PUBLIC] = "public";
|
|
|
|
VISIBILITY_LEVELS_API[PostVisibilityLevel.VISIBILITY_FRIENDS] = "friends";
|
|
|
|
VISIBILITY_LEVELS_API[PostVisibilityLevel.VISIBILITY_USER] = "private";
|
|
|
|
VISIBILITY_LEVELS_API[PostVisibilityLevel.VISIBILITY_GROUP_MEMBERS] = "members";
|
|
|
|
|
2020-01-03 15:38:44 +00:00
|
|
|
|
|
|
|
const ACCESS_LEVELS_API = {};
|
|
|
|
ACCESS_LEVELS_API[PostAccessLevel.NO_ACCESS] = "no-access";
|
|
|
|
ACCESS_LEVELS_API[PostAccessLevel.BASIC_ACCESS] = "basic";
|
|
|
|
ACCESS_LEVELS_API[PostAccessLevel.INTERMEDIATE_ACCESS] = "intermediate";
|
|
|
|
ACCESS_LEVELS_API[PostAccessLevel.FULL_ACCESS] = "full";
|
|
|
|
|
|
|
|
|
2020-01-03 09:17:34 +00:00
|
|
|
export class PostsController {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the posts of a user
|
|
|
|
*
|
|
|
|
* @param h Request handler
|
|
|
|
*/
|
|
|
|
public static async GetListUser(h: RequestHandler) {
|
|
|
|
const userID = await h.postUserId("userID");
|
|
|
|
const startFrom = h.postInt("startFrom", 0);
|
|
|
|
|
|
|
|
if(!await UserHelper.CanSeeUserPage(h.optionnalUserID, userID))
|
|
|
|
h.error(401, "You are not allowed to access this user posts !");
|
|
|
|
|
|
|
|
const posts = await PostsHelper.GetUserPosts(h.optionnalUserID, userID, startFrom);
|
|
|
|
|
2020-01-04 09:27:54 +00:00
|
|
|
await this.SendMultiplePosts(h, posts);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the list of posts of a group
|
|
|
|
*
|
|
|
|
* @param h Request handler
|
|
|
|
*/
|
|
|
|
public static async GetListGroup(h: RequestHandler) {
|
|
|
|
const groupID = await h.postGroupIDWithAccess("groupID", GroupsAccessLevel.VIEW_ACCESS);
|
|
|
|
const startFrom = h.postInt("startFrom", 0);
|
|
|
|
|
|
|
|
const posts = await PostsHelper.GetGroupPosts(h.optionnalUserID, groupID, startFrom);
|
|
|
|
|
|
|
|
await this.SendMultiplePosts(h, posts);
|
|
|
|
}
|
|
|
|
|
2020-01-04 10:30:33 +00:00
|
|
|
/**
|
|
|
|
* Get the list of latest posts
|
|
|
|
*
|
|
|
|
* @param h Request handler
|
|
|
|
*/
|
|
|
|
public static async GetLatest(h: RequestHandler) {
|
|
|
|
const startFrom = h.postInt("startFrom", 0);
|
|
|
|
const includeGroups = h.postBool('include_groups', false);
|
|
|
|
|
|
|
|
const posts = await PostsHelper.GetLatest(h.getUserId(), startFrom, 10, includeGroups);
|
|
|
|
|
|
|
|
await this.SendMultiplePosts(h, posts);
|
|
|
|
}
|
|
|
|
|
2020-01-04 11:04:14 +00:00
|
|
|
/**
|
|
|
|
* Get information about a single post
|
|
|
|
*
|
|
|
|
* @param h Request handler
|
|
|
|
*/
|
|
|
|
public static async GetSingle(h: RequestHandler) {
|
|
|
|
const postID = await h.postPostIDWithAccess("postID");
|
|
|
|
|
|
|
|
const post = await PostsHelper.GetSingle(postID);
|
|
|
|
|
|
|
|
h.send(await this.PostToAPI(h, post));
|
|
|
|
}
|
|
|
|
|
2020-01-04 14:07:24 +00:00
|
|
|
/**
|
|
|
|
* Create a new post
|
|
|
|
*
|
|
|
|
* @param h Request handler
|
|
|
|
*/
|
|
|
|
public static async CreatePost(h: RequestHandler) {
|
|
|
|
|
|
|
|
// Determine the target for the new post
|
|
|
|
let kindPage: PostPageKind;
|
|
|
|
let pageID: number;
|
|
|
|
switch(h.postString("kind-page")) {
|
|
|
|
|
|
|
|
// If the post is targetting a user
|
|
|
|
case "user":
|
|
|
|
kindPage = PostPageKind.PAGE_KIND_USER;
|
|
|
|
pageID = await h.postUserId("kind-id");
|
|
|
|
|
|
|
|
if(!await UserHelper.CanCreatePosts(h.getUserId(), pageID))
|
|
|
|
h.error(401, "You are not allowed to create posts on this page!");
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
// For groups
|
|
|
|
case "group":
|
|
|
|
kindPage = PostPageKind.PAGE_KIND_GROUP;
|
|
|
|
pageID = await h.postGroupIDWithAccess("kind-id", GroupsAccessLevel.MEMBER_ACCESS);
|
|
|
|
|
|
|
|
// Check if the user can create posts on this group
|
|
|
|
if(!await GroupsHelper.CanUserCreatePosts(pageID, h.getUserId()))
|
|
|
|
h.error(401, "You are not allowed to create posts on this group!");
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
h.error(500, "Unsupported kind of page!");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-01-04 14:25:26 +00:00
|
|
|
// Initialize new post information
|
|
|
|
const newPost = new Post({
|
|
|
|
// Basic information about the post
|
|
|
|
id: -1,
|
|
|
|
userID: h.getUserId(),
|
|
|
|
timeCreate: time(),
|
|
|
|
kind: <PostKind>h.postString("kind"),
|
|
|
|
content: h.postContent("content"),
|
|
|
|
visibilityLevel: this.PostVisibilityLevel(h, "visibility"),
|
|
|
|
|
|
|
|
// Post target
|
|
|
|
kindPage: kindPage,
|
|
|
|
pageID: pageID,
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
console.info(newPost);
|
2020-01-04 14:07:24 +00:00
|
|
|
h.success("Go on.");
|
|
|
|
}
|
|
|
|
|
2020-01-04 09:27:54 +00:00
|
|
|
/**
|
|
|
|
* Send multiple posts to the API
|
|
|
|
*
|
|
|
|
* @param h Request handler
|
|
|
|
* @param posts The list of post to send
|
|
|
|
*/
|
|
|
|
private static async SendMultiplePosts(h: RequestHandler, posts: Array<Post>) {
|
2020-01-03 09:17:34 +00:00
|
|
|
let list = [];
|
|
|
|
for (const p of posts) {
|
2020-01-03 13:37:54 +00:00
|
|
|
list.push(await this.PostToAPI(h, p));
|
2020-01-03 09:17:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
h.send(list);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Turn a post object into an API entry
|
|
|
|
*
|
2020-01-03 13:37:54 +00:00
|
|
|
* @param h Request handler
|
2020-01-03 09:17:34 +00:00
|
|
|
* @param p The post
|
|
|
|
*/
|
2020-01-03 13:37:54 +00:00
|
|
|
public static async PostToAPI(h: RequestHandler, p: Post) : Promise<any> {
|
2020-01-03 09:17:34 +00:00
|
|
|
let data : any = {
|
|
|
|
ID: p.id,
|
2020-01-03 09:32:44 +00:00
|
|
|
userID: p.userID,
|
2020-01-03 09:17:34 +00:00
|
|
|
user_page_id: p.userPageID,
|
|
|
|
group_id: p.groupID,
|
|
|
|
post_time: p.timeCreate,
|
|
|
|
content: p.hasContent ? p.content : null,
|
|
|
|
visibility_level: VISIBILITY_LEVELS_API[p.visibilityLevel],
|
|
|
|
kind: p.kind,
|
|
|
|
|
2020-01-03 09:30:37 +00:00
|
|
|
|
2020-01-03 09:17:34 +00:00
|
|
|
// File specific
|
|
|
|
file_size: !p.hasFile ? null : p.file.size,
|
|
|
|
file_type: !p.hasFile ? null : p.file.type,
|
|
|
|
file_path: !p.hasFile ? null : p.file.path,
|
2020-01-03 16:32:14 +00:00
|
|
|
file_path_url: !p.hasFile ? null : p.file.url,
|
2020-01-03 09:24:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Movie specific
|
2020-01-03 09:30:37 +00:00
|
|
|
video_id: p.hasMovie ? p.movieID : null,
|
|
|
|
video_info: p.hasMovie ?
|
|
|
|
MoviesController.MovieToAPI(await MoviesHelper.GetInfo(p.movieID)) : null,
|
|
|
|
|
|
|
|
|
|
|
|
// Countdown timer specific
|
|
|
|
time_end: p.hasTimeEnd ? p.timeEnd : null,
|
|
|
|
|
|
|
|
// Weblink specific
|
|
|
|
link_url: !p.hasLink ? null : p.link.url,
|
|
|
|
link_title: !p.hasLink ? null : p.link.title,
|
|
|
|
link_description: !p.hasLink ? null : p.link.description,
|
2020-01-03 13:37:54 +00:00
|
|
|
link_image: !p.hasLink ? null : p.link.image,
|
|
|
|
|
|
|
|
|
|
|
|
// Survey specific
|
|
|
|
data_survey: !p.hasSurvey ? null : await SurveyController.SurveyToAPI(h, await SurveyHelper.GetInfo(p.id)),
|
2020-01-03 13:49:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Likes information
|
|
|
|
likes: await LikesHelper.Count(p.id, LikesType.POST),
|
|
|
|
userlike: h.signedIn ? await LikesHelper.IsLiking(h.getUserId(), p.id, LikesType.POST) : false,
|
2020-01-03 15:38:44 +00:00
|
|
|
|
|
|
|
// Determine user access level
|
|
|
|
user_access: ACCESS_LEVELS_API[await PostsHelper.GetAccessLevel(h.optionnalUserID, p)],
|
|
|
|
|
2020-01-03 16:01:09 +00:00
|
|
|
// Load comments (if possible)
|
2020-01-03 16:31:39 +00:00
|
|
|
comments: await PostsHelper.AllowCommentsOnPost(p) ? await CommentsController.CommentsToAPI(h, await CommentsHelper.Get(p.id)) : null,
|
2020-01-03 09:17:34 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
return data;
|
|
|
|
}
|
2020-01-04 14:25:26 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the visibility level for a POST included in a request
|
|
|
|
*
|
|
|
|
* @param h Request handler
|
|
|
|
* @param name The name of the POST field containing the visibility level of the user
|
|
|
|
*/
|
|
|
|
private static PostVisibilityLevel(h: RequestHandler, name: string) : PostVisibilityLevel {
|
|
|
|
const levelKey = findKey(VISIBILITY_LEVELS_API, h.postString(name, 3));
|
|
|
|
if(levelKey == null)
|
|
|
|
h.error(400, "Post visibility level level not recognized!");
|
|
|
|
return <PostVisibilityLevel>Number(levelKey);
|
|
|
|
}
|
2020-01-03 09:17:34 +00:00
|
|
|
}
|