Merge pull request #309 from shancds/upstreame-release-v2.1.4
Origin release v2.1.4
This commit is contained in:
@@ -5,7 +5,7 @@ import db from "../config/db";
|
||||
import {ServerResponse} from "../models/server-response";
|
||||
import WorklenzControllerBase from "./worklenz-controller-base";
|
||||
import HandleExceptions from "../decorators/handle-exceptions";
|
||||
import {TASK_PRIORITY_COLOR_ALPHA, WorklenzColorCodes} from "../shared/constants";
|
||||
import {TASK_PRIORITY_COLOR_ALPHA, WorklenzColorCodes, WorklenzColorShades} from "../shared/constants";
|
||||
|
||||
export default class LabelsController extends WorklenzControllerBase {
|
||||
@HandleExceptions()
|
||||
@@ -73,7 +73,7 @@ export default class LabelsController extends WorklenzControllerBase {
|
||||
WHERE id = $1
|
||||
AND team_id = $2;`;
|
||||
|
||||
if (!WorklenzColorCodes.includes(req.body.color))
|
||||
if (!Object.values(WorklenzColorShades).flat().includes(req.body.color))
|
||||
return res.status(400).send(new ServerResponse(false, null));
|
||||
|
||||
const result = await db.query(q, [req.params.id, req.user?.team_id, req.body.color]);
|
||||
@@ -92,7 +92,7 @@ export default class LabelsController extends WorklenzControllerBase {
|
||||
}
|
||||
|
||||
if (req.body.color) {
|
||||
if (!WorklenzColorCodes.includes(req.body.color))
|
||||
if (!Object.values(WorklenzColorShades).flat().includes(req.body.color))
|
||||
return res.status(400).send(new ServerResponse(false, null));
|
||||
updates.push(`color_code = $${paramIndex++}`);
|
||||
values.push(req.body.color);
|
||||
|
||||
@@ -124,7 +124,7 @@ export default class TaskCommentsController extends WorklenzControllerBase {
|
||||
const q = `
|
||||
INSERT INTO task_comment_attachments (name, type, size, task_id, comment_id, team_id, project_id)
|
||||
VALUES ($1, $2, $3, $4, $5, $6, $7)
|
||||
RETURNING id, name, type, task_id, comment_id, created_at,
|
||||
RETURNING id, name, type, task_id, comment_id, created_at,
|
||||
CONCAT($8::TEXT, '/', team_id, '/', project_id, '/', task_id, '/', comment_id, '/', id, '.', type) AS url;
|
||||
`;
|
||||
|
||||
@@ -217,7 +217,43 @@ export default class TaskCommentsController extends WorklenzControllerBase {
|
||||
}
|
||||
}
|
||||
|
||||
return res.status(200).send(new ServerResponse(true, data.comment));
|
||||
// Get user avatar URL from database
|
||||
const avatarQuery = `SELECT avatar_url FROM users WHERE id = $1`;
|
||||
const avatarResult = await db.query(avatarQuery, [req.user?.id]);
|
||||
const avatarUrl = avatarResult.rows[0]?.avatar_url || "";
|
||||
|
||||
// Get comment details including created_at
|
||||
const commentQuery = `SELECT created_at FROM task_comments WHERE id = $1`;
|
||||
const commentResult = await db.query(commentQuery, [response.id]);
|
||||
const commentData = commentResult.rows[0];
|
||||
|
||||
// Get attachments if any
|
||||
const attachmentsQuery = `SELECT id, name, type, size FROM task_comment_attachments WHERE comment_id = $1`;
|
||||
const attachmentsResult = await db.query(attachmentsQuery, [response.id]);
|
||||
const commentAttachments = attachmentsResult.rows.map(att => ({
|
||||
id: att.id,
|
||||
name: att.name,
|
||||
type: att.type,
|
||||
size: att.size
|
||||
}));
|
||||
|
||||
|
||||
const commentdata = {
|
||||
attachments: commentAttachments,
|
||||
avatar_url: avatarUrl,
|
||||
content: req.body.content,
|
||||
created_at: commentData?.created_at || new Date().toISOString(),
|
||||
edit: false,
|
||||
id: response.id,
|
||||
member_name: req.user?.name || "",
|
||||
mentions: mentions || [],
|
||||
rawContent: req.body.content,
|
||||
reactions: { likes: {} },
|
||||
team_member_id: req.user?.team_member_id || "",
|
||||
user_id: req.user?.id || ""
|
||||
};
|
||||
|
||||
return res.status(200).send(new ServerResponse(true, commentdata));
|
||||
}
|
||||
|
||||
@HandleExceptions()
|
||||
@@ -530,17 +566,17 @@ export default class TaskCommentsController extends WorklenzControllerBase {
|
||||
for (const attachment of attachments) {
|
||||
if (req.user?.subscription_status === "free" && req.user?.owner_id) {
|
||||
const limits = await getFreePlanSettings();
|
||||
|
||||
|
||||
const usedStorage = await getUsedStorage(req.user?.owner_id);
|
||||
if ((parseInt(usedStorage) + attachment.size) > megabytesToBytes(parseInt(limits.free_tier_storage))) {
|
||||
return res.status(200).send(new ServerResponse(false, [], `Sorry, the free plan cannot exceed ${limits.free_tier_storage}MB of storage.`));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
const q = `
|
||||
INSERT INTO task_comment_attachments (name, type, size, task_id, comment_id, team_id, project_id)
|
||||
VALUES ($1, $2, $3, $4, $5, $6, $7)
|
||||
RETURNING id, name, type, task_id, comment_id, created_at,
|
||||
RETURNING id, name, type, task_id, comment_id, created_at,
|
||||
CONCAT($8::TEXT, '/', team_id, '/', project_id, '/', task_id, '/', comment_id, '/', id, '.', type) AS url;
|
||||
`;
|
||||
|
||||
|
||||
@@ -8,7 +8,7 @@ import {PASSWORD_POLICY} from "../../shared/constants";
|
||||
function isStrongPassword(password: string) {
|
||||
if (!isProduction()) return true;
|
||||
const strength = PasswordStrengthChecker.validate(password);
|
||||
return strength.value >= 2 && strength.length < 32;
|
||||
return strength.value >= 2 && strength.length <= 32;
|
||||
}
|
||||
|
||||
export default function (req: Request, res: Response, next: NextFunction) {
|
||||
|
||||
Reference in New Issue
Block a user