v6
This commit is contained in:
@@ -19,9 +19,9 @@ function hasAccess(project_id, user_id) {
|
||||
return !!db
|
||||
.prepare(`
|
||||
select 1
|
||||
from group_users
|
||||
from chat_users
|
||||
where user_id = :user_id and
|
||||
group_id in (select id from groups where project_id = :project_id) and
|
||||
chat_id in (select id from chats where project_id = :project_id) and
|
||||
not exists(select 1 from user_details where user_id = :user_id and project_id = :project_id and is_blocked = 1) and
|
||||
not exists(select 1 from projects where id = :project_id and is_deleted = 1)
|
||||
`)
|
||||
@@ -70,13 +70,13 @@ app.get('/project', (req, res, next) => {
|
||||
const rows = db
|
||||
.prepare(`
|
||||
select p.id, p.name, p.description, p.logo,
|
||||
c.name customer_name, c.upload_group_id <> 0 has_upload
|
||||
c.name customer_name, c.upload_chat_id <> 0 has_upload
|
||||
from projects p
|
||||
inner join customers c on p.customer_id = c.id
|
||||
where p.id in (
|
||||
select project_id
|
||||
from groups
|
||||
where id in (select group_id from group_users where user_id = :user_id)
|
||||
from chats
|
||||
where id in (select chat_id from chat_users where user_id = :user_id)
|
||||
) and not exists(select 1 from user_details where user_id = :user_id and project_id = p.id and is_blocked = 1)
|
||||
${where} and is_deleted <> 1
|
||||
`)
|
||||
@@ -114,9 +114,9 @@ app.get('/project/:pid(\\d+)/user', (req, res, next) => {
|
||||
.prepare(`
|
||||
with actuals (user_id) as (
|
||||
select distinct user_id
|
||||
from group_users
|
||||
where group_id in (select id from groups where project_id = :project_id)
|
||||
and group_id in (select group_id from group_users where user_id = :user_id)
|
||||
from chat_users
|
||||
where chat_id in (select id from chats where project_id = :project_id)
|
||||
and chat_id in (select chat_id from chat_users where user_id = :user_id)
|
||||
),
|
||||
contributors (user_id) as (
|
||||
select created_by from tasks where project_id = :project_id
|
||||
@@ -193,29 +193,29 @@ app.get('/project/:pid(\\d+)/user', (req, res, next) => {
|
||||
})
|
||||
|
||||
app.get('/project/:pid(\\d+)/user/reload', async (req, res, next) => {
|
||||
const groupIds = db
|
||||
.prepare(`select id from groups where project_id = :project_id`)
|
||||
const chatIds = db
|
||||
.prepare(`select id from chats where project_id = :project_id`)
|
||||
.all(res.locals)
|
||||
.map(e => e.id)
|
||||
|
||||
const sleep = ms => new Promise(resolve => setTimeout(resolve, ms))
|
||||
|
||||
for (const groupId of groupIds) {
|
||||
await bot.reloadGroupUsers(groupId)
|
||||
for (const chatId of chatIds) {
|
||||
await bot.reloadGroupUsers(chatId)
|
||||
await sleep(1000)
|
||||
}
|
||||
|
||||
res.status(200).json({success: true})
|
||||
})
|
||||
|
||||
app.get('/project/:pid(\\d+)/group', (req, res, next) => {
|
||||
app.get('/project/:pid(\\d+)/chat', (req, res, next) => {
|
||||
const where = req.query.id ? ' and id = ' + parseInt(req.query.id) : ''
|
||||
|
||||
const rows = db
|
||||
.prepare(`
|
||||
select id, name, telegram_id
|
||||
from groups
|
||||
where project_id = :project_id and id in (select group_id from group_users where user_id = :user_id)
|
||||
from chats
|
||||
where project_id = :project_id and id in (select chat_id from chat_users where user_id = :user_id)
|
||||
${where}
|
||||
`)
|
||||
.all(res.locals)
|
||||
@@ -226,8 +226,8 @@ app.get('/project/:pid(\\d+)/group', (req, res, next) => {
|
||||
res.status(200).json({success: true, data: where ? rows[0] : rows})
|
||||
})
|
||||
|
||||
app.get('/project/:pid(\\d+)/group/:gid(\\d+)', (req, res, next) => {
|
||||
res.redirect(req.baseUrl + `/project/${req.params.pid}/group?id=${req.params.gid}`)
|
||||
app.get('/project/:pid(\\d+)/chat/:gid(\\d+)', (req, res, next) => {
|
||||
res.redirect(req.baseUrl + `/project/${req.params.pid}/chat?id=${req.params.gid}`)
|
||||
})
|
||||
|
||||
// TASK
|
||||
@@ -237,8 +237,8 @@ app.get('/project/:pid(\\d+)/task', (req, res, next) => {
|
||||
const rows = db
|
||||
.prepare(`
|
||||
select id, name, created_by, assigned_to, priority, status, time_spent, create_date, plan_date, close_date,
|
||||
(select json_group_array(user_id) from task_users where task_id = t.id) observers,
|
||||
(select json_group_array(id) from documents where parent_type = 1 and parent_id = t.id) attachments
|
||||
(select json_chat_array(user_id) from task_users where task_id = t.id) observers,
|
||||
(select json_chat_array(id) from documents where parent_type = 1 and parent_id = t.id) attachments
|
||||
from tasks t
|
||||
where project_id = :project_id and
|
||||
(created_by = :user_id or assigned_to = :user_id or exists(select 1 from task_users where task_id = t.id and user_id = :user_id))
|
||||
@@ -351,8 +351,8 @@ app.put('/project/:pid(\\d+)/task/:tid(\\d+)/observer', (req, res, next) => {
|
||||
let rows = db
|
||||
.prepare(`
|
||||
select user_id
|
||||
from group_users
|
||||
where group_id in (select id from groups where project_id = :project_id)
|
||||
from chat_users
|
||||
where chat_id in (select id from chats where project_id = :project_id)
|
||||
`)
|
||||
.pluck(true)
|
||||
.all(res.locals)
|
||||
@@ -379,8 +379,8 @@ app.get('/project/:pid(\\d+)/meeting', (req, res, next) => {
|
||||
const rows = db
|
||||
.prepare(`
|
||||
select id, name, description, created_by, meet_date,
|
||||
(select json_group_array(user_id) from meeting_users where meeting_id = m.id) participants,
|
||||
(select json_group_array(id) from documents where parent_type = 2 and parent_id = m.id) attachments
|
||||
(select json_chat_array(user_id) from meeting_users where meeting_id = m.id) participants,
|
||||
(select json_chat_array(id) from documents where parent_type = 2 and parent_id = m.id) attachments
|
||||
from meetings m
|
||||
where project_id = :project_id and
|
||||
(created_by = :user_id or exists(select 1 from meeting_users where meeting_id = m.id and user_id = :user_id))
|
||||
@@ -483,8 +483,8 @@ app.put('/project/:pid(\\d+)/meeting/:mid(\\d+)/participants', (req, res, next)
|
||||
let rows = db
|
||||
.prepare(`
|
||||
select user_id
|
||||
from group_users
|
||||
where group_id in (select id from groups where project_id = :project_id)
|
||||
from chat_users
|
||||
where chat_id in (select id from chats where project_id = :project_id)
|
||||
`)
|
||||
.pluck(true) // .raw?
|
||||
.all(res.locals)
|
||||
@@ -516,10 +516,10 @@ app.get('/project/:pid(\\d+)/document', (req, res, next) => {
|
||||
// To-Do: отдавать готовую ссылку --> как минимум GROUP_ID надо заменить на tgGroupId
|
||||
const rows = db
|
||||
.prepare(`
|
||||
select id, origin_group_id, origin_message_id, filename, mime, caption, size, published_by, parent_id, parent_type
|
||||
select id, origin_chat_id, origin_message_id, filename, mime, caption, size, published_by, parent_id, parent_type
|
||||
from documents d
|
||||
where project_id = :project_id ${where} and (
|
||||
origin_group_id in (select group_id from group_users where user_id = :user_id)
|
||||
origin_chat_id in (select chat_id from chat_users where user_id = :user_id)
|
||||
or
|
||||
parent_type = 1 and parent_id in (
|
||||
select id
|
||||
@@ -566,9 +566,9 @@ app.use('/project/:pid(\\d+)/document/:did(\\d+)', (req, res, next) => {
|
||||
throw Error('NOT_FOUND::404')
|
||||
|
||||
if (doc.parent_type == 0) {
|
||||
res.locals.group_id = doc.group_id
|
||||
res.locals.chat_id = doc.chat_id
|
||||
const row = db
|
||||
.prepare(`select 1 from group_users where group_id = :group_id and user_id = :user_id`)
|
||||
.prepare(`select 1 from chat_users where chat_id = :chat_id and user_id = :user_id`)
|
||||
.get(res.locals)
|
||||
|
||||
if (row) {
|
||||
|
||||
Reference in New Issue
Block a user