@opengis/admin 0.2.129 → 0.2.130

Sign up to get free protection for your applications and to get access to all the features.
Files changed (122) hide show
  1. package/README.md +97 -97
  2. package/config.js +4 -4
  3. package/dist/{add-page-l7Ssdd2k.js → add-page-B9j1X71R.js} +1 -1
  4. package/dist/{admin-interface-gN7lGeoz.js → admin-interface-DZ_JAuHP.js} +2 -2
  5. package/dist/{admin-view-BmxE02FG.js → admin-view-CHq_9aht.js} +2 -2
  6. package/dist/admin.js +1 -1
  7. package/dist/admin.umd.cjs +75 -75
  8. package/dist/assets/logo.svg +41 -41
  9. package/dist/{card-view-Dj5OFVzG.js → card-view-DHcY64lQ.js} +1 -1
  10. package/dist/{edit-page-DEjYfNP6.js → edit-page-DPeBqCDl.js} +1 -1
  11. package/dist/{import-file-BMB-tu-Z.js → import-file-BWQ2bV93.js} +13044 -13055
  12. package/dist/{profile-page-C97qFx1c.js → profile-page-vqy75jEB.js} +1 -1
  13. package/dist/style.css +1 -1
  14. package/module/settings/card/admin.accounts.table/index.yml +7 -7
  15. package/module/settings/card/admin.accounts.table/rules.hbs +18 -18
  16. package/module/settings/card/admin.accounts.table/users.hbs +13 -13
  17. package/module/settings/card/admin.routes.table/groups.hbs +11 -11
  18. package/module/settings/card/admin.routes.table/users.hbs +16 -16
  19. package/module/settings/cls/core.actions.json +17 -17
  20. package/module/settings/cls/core.scope.json +13 -13
  21. package/module/settings/cls/properties.site_status.json +13 -13
  22. package/module/settings/cls/properties.widget_status.json +13 -13
  23. package/module/settings/cls/users.user_type.json +13 -13
  24. package/module/settings/cls/yes_no.json +11 -11
  25. package/module/settings/form/admin.accounts.form.json +13 -13
  26. package/module/settings/form/admin.properties.form.json +15 -15
  27. package/module/settings/form/admin.roles.form.json +21 -21
  28. package/module/settings/form/admin.user_properties.form.json +15 -15
  29. package/module/settings/form/admin.user_roles_card.form.json +13 -13
  30. package/module/settings/interface/admin.properties.json +4 -4
  31. package/module/settings/interface/admin.roles.json +4 -4
  32. package/module/settings/interface/admin.routes.json +4 -4
  33. package/module/settings/interface/admin.users.json +4 -4
  34. package/module/settings/select/core.routes.sql +1 -1
  35. package/module/settings/select/core.user_mentioned.sql +1 -1
  36. package/module/settings/select/core.user_uid.sql +1 -1
  37. package/module/settings/table/admin.properties.table.json +39 -39
  38. package/module/settings/table/admin.user_properties.table.json +34 -34
  39. package/package.json +3 -2
  40. package/plugin.js +29 -29
  41. package/server/helpers/core/badge.js +16 -16
  42. package/server/helpers/core/buttonHelper.js +21 -21
  43. package/server/helpers/core/coalesce.js +8 -0
  44. package/server/helpers/core/select.js +48 -48
  45. package/server/helpers/core/token.js +18 -18
  46. package/server/helpers/index.js +35 -31
  47. package/server/helpers/list/buttonHelper.js +21 -21
  48. package/server/helpers/list/descriptionList.js +12 -9
  49. package/server/helpers/list/utils/button.js +5 -5
  50. package/server/helpers/temp/contentList.js +58 -58
  51. package/server/helpers/temp/ifCond.js +101 -101
  52. package/server/helpers/utils/button.js +5 -5
  53. package/server/helpers/utils/mdToHTML.js +17 -0
  54. package/server/plugins/access/index.mjs +6 -6
  55. package/server/plugins/adminHook.js +81 -81
  56. package/server/plugins/cron.js +10 -10
  57. package/server/plugins/docs.js +28 -28
  58. package/server/routes/access/controllers/access.group.js +29 -29
  59. package/server/routes/access/controllers/access.group.post.js +54 -54
  60. package/server/routes/access/index.mjs +11 -11
  61. package/server/routes/access/schema.mjs +67 -67
  62. package/server/routes/calendar/controllers/calendar.data.js +125 -125
  63. package/server/routes/calendar/index.mjs +7 -7
  64. package/server/routes/calendar/schema.js +21 -21
  65. package/server/routes/data/controllers/cardTabData.js +49 -49
  66. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +92 -92
  67. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +170 -170
  68. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  69. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +64 -64
  70. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  71. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  72. package/server/routes/data/controllers/tableData.js +31 -31
  73. package/server/routes/data/controllers/tableDataId.js +27 -27
  74. package/server/routes/data/controllers/tableFilter.js +108 -108
  75. package/server/routes/data/controllers/tokenInfo.js +9 -9
  76. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  77. package/server/routes/data/controllers/utils/conditions.js +20 -20
  78. package/server/routes/data/controllers/utils/getColumns.js +8 -8
  79. package/server/routes/data/index.mjs +20 -20
  80. package/server/routes/data/schema.js +54 -54
  81. package/server/routes/menu/index.mjs +5 -5
  82. package/server/routes/notifications/controllers/readNotifications.js +27 -27
  83. package/server/routes/notifications/controllers/testEmail.js +35 -35
  84. package/server/routes/notifications/controllers/userNotifications.js +53 -53
  85. package/server/routes/notifications/funcs/addNotification.js +21 -21
  86. package/server/routes/notifications/funcs/sendNotification.js +92 -92
  87. package/server/routes/notifications/hook/onWidgetSet.js +56 -56
  88. package/server/routes/notifications/index.mjs +26 -26
  89. package/server/routes/notifications/schema.js +16 -16
  90. package/server/routes/print/controllers/cardPrint.js +134 -134
  91. package/server/routes/properties/funcs/getSettings.js +56 -56
  92. package/server/routes/properties/schema.js +10 -10
  93. package/server/routes/report/controllers/data.js +76 -76
  94. package/server/routes/report/controllers/list.js +18 -18
  95. package/server/routes/report/index.mjs +7 -7
  96. package/server/routes/report/utils/formatValue.js +179 -179
  97. package/server/routes/root.mjs +3 -3
  98. package/server/routes/templates/controllers/getTemplate.js +49 -49
  99. package/server/routes/templates/index.mjs +16 -16
  100. package/server/routes/templates/schema.js +8 -8
  101. package/server/routes/user/controllers/user.cls.id.js +14 -14
  102. package/server/routes/user/controllers/user.cls.js +71 -71
  103. package/server/routes/user/controllers/user.info.js +17 -17
  104. package/server/routes/user/schema.js +14 -14
  105. package/server/routes/widget/controllers/widget.del.js +47 -47
  106. package/server/routes/widget/controllers/widget.set.js +84 -84
  107. package/server/routes/widget/hook/onWidgetSet.js +12 -12
  108. package/server/routes/widget/index.mjs +16 -16
  109. package/server/routes/widget/schema.js +12 -12
  110. package/server/templates/cls/itree.recrzone_category.json +73 -73
  111. package/server/templates/cls/test.json +9 -9
  112. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  113. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  114. package/server/templates/form/form-user-pass.json +10 -10
  115. package/server/templates/form/form-user_group.json +39 -39
  116. package/server/templates/form/form-users.json +156 -156
  117. package/server/templates/form/user_group_access.form.json +22 -22
  118. package/server/templates/select/account_id.json +2 -2
  119. package/server/templates/table/gis.dataset.table.json +43 -43
  120. package/server/templates/table/management.user_group.table.json +112 -112
  121. package/server/templates/table/management.users.table.json +126 -126
  122. package/utils.js +29 -29
@@ -1,71 +1,71 @@
1
- import { readFile } from 'fs/promises';
2
- import { getTemplatePath } from '@opengis/fastify-table/utils.js';
3
-
4
- export default async function userCls(req) {
5
- const {
6
- pg, params = {}, query = {}, session = {},
7
- } = req;
8
- const { uid } = session.passport?.user || {};
9
-
10
- if (!uid) {
11
- return { message: 'access restricted', status: 403 };
12
- }
13
-
14
- if (query.type && !['json', 'sql'].includes(query.type)) {
15
- return { message: 'param type is invalid', status: 400 };
16
- }
17
-
18
- const q = `select user_clsid as id, name, type,
19
- case when type='json' then (
20
- ${params?.id
21
- ? `(with recursive rows as (
22
- select user_clsid, code as id, name as text, icon, color, parent
23
- from admin.user_cls a
24
- where name=u.name
25
- union all
26
- select a.user_clsid, a.code, a.name, a.icon, a.color, a.parent
27
- from admin.user_cls a
28
- join rows b on a.parent=b.text
29
- ) select json_agg(row_to_json(q)) from rows q where text<>u.name
30
- )`
31
- : 'select count(*)::int from admin.user_cls where parent=u.name'} ) else null end as children,
32
- case when type='sql' then data else null end as sql from admin.user_cls u
33
- where (case when type='json' then parent is null else true end)
34
- and uid=(select uid from admin.users where $1 in (login,uid) limit 1)
35
- and parent is null and ${query.type ? `type='${query.type}'` : '1=1'} and ${params?.id ? 'u.name=$2' : '1=1'}`;
36
-
37
- if (query?.sql) return q;
38
-
39
-
40
- const { rows = [] } = await pg.query(q, [uid, params.id].filter((el) => el));
41
-
42
- rows.forEach((row) => {
43
- if (row.type === 'sql') delete row.children;
44
- if (row.type === 'json') { delete row.sql; Object.assign(row, { children: row.children || (params?.id ? [] : 0) }); }
45
- });
46
-
47
- const clsList = query.type === 'sql' ? [] : getTemplatePath('cls'); // skip cls if type sql
48
- const selectList = query.type === 'json' ? [] : getTemplatePath('select'); // skip sql if type json
49
-
50
- const userClsNames = rows.map((el) => el.name);
51
- const selectNames = selectList.map((el) => el[0]);
52
-
53
- const arr = (clsList || []).concat(selectList || []).map((el) => ({ name: el[0], path: el[1], type: el[2] }))
54
- ?.filter((el) => (params?.id ? el.name === params?.id : true))
55
- ?.filter((el) => ['sql', 'json'].includes(el?.type) && !userClsNames.includes(el.name))
56
- ?.filter((el) => (el?.type === 'json' ? !selectNames?.includes(el?.name) : true));
57
-
58
- const res = await Promise.all(arr?.map(async (el) => {
59
- const type = { json: 'cls', sql: 'select' }[el.type] || el.type;
60
- // const clsData = await getSelect(type, el.name);
61
- const str = await readFile(el.path, 'utf-8');
62
- const clsData = type === 'cls' ? JSON.parse(str) : str;
63
- if (type === 'cls') {
64
- const children = params?.id ? clsData : clsData?.length || 0;
65
- return { name: el.name, type: el.type, children };
66
- }
67
- return { name: el.name, type: el.type, sql: clsData?.sql || clsData };
68
- }));
69
-
70
- return { message: { rows: rows.concat(res) }, status: 200 };
71
- }
1
+ import { readFile } from 'fs/promises';
2
+ import { getTemplatePath } from '@opengis/fastify-table/utils.js';
3
+
4
+ export default async function userCls(req) {
5
+ const {
6
+ pg, params = {}, query = {}, session = {},
7
+ } = req;
8
+ const { uid } = session.passport?.user || {};
9
+
10
+ if (!uid) {
11
+ return { message: 'access restricted', status: 403 };
12
+ }
13
+
14
+ if (query.type && !['json', 'sql'].includes(query.type)) {
15
+ return { message: 'param type is invalid', status: 400 };
16
+ }
17
+
18
+ const q = `select user_clsid as id, name, type,
19
+ case when type='json' then (
20
+ ${params?.id
21
+ ? `(with recursive rows as (
22
+ select user_clsid, code as id, name as text, icon, color, parent
23
+ from admin.user_cls a
24
+ where name=u.name
25
+ union all
26
+ select a.user_clsid, a.code, a.name, a.icon, a.color, a.parent
27
+ from admin.user_cls a
28
+ join rows b on a.parent=b.text
29
+ ) select json_agg(row_to_json(q)) from rows q where text<>u.name
30
+ )`
31
+ : 'select count(*)::int from admin.user_cls where parent=u.name'} ) else null end as children,
32
+ case when type='sql' then data else null end as sql from admin.user_cls u
33
+ where (case when type='json' then parent is null else true end)
34
+ and uid=(select uid from admin.users where $1 in (login,uid) limit 1)
35
+ and parent is null and ${query.type ? `type='${query.type}'` : '1=1'} and ${params?.id ? 'u.name=$2' : '1=1'}`;
36
+
37
+ if (query?.sql) return q;
38
+
39
+
40
+ const { rows = [] } = await pg.query(q, [uid, params.id].filter((el) => el));
41
+
42
+ rows.forEach((row) => {
43
+ if (row.type === 'sql') delete row.children;
44
+ if (row.type === 'json') { delete row.sql; Object.assign(row, { children: row.children || (params?.id ? [] : 0) }); }
45
+ });
46
+
47
+ const clsList = query.type === 'sql' ? [] : getTemplatePath('cls'); // skip cls if type sql
48
+ const selectList = query.type === 'json' ? [] : getTemplatePath('select'); // skip sql if type json
49
+
50
+ const userClsNames = rows.map((el) => el.name);
51
+ const selectNames = selectList.map((el) => el[0]);
52
+
53
+ const arr = (clsList || []).concat(selectList || []).map((el) => ({ name: el[0], path: el[1], type: el[2] }))
54
+ ?.filter((el) => (params?.id ? el.name === params?.id : true))
55
+ ?.filter((el) => ['sql', 'json'].includes(el?.type) && !userClsNames.includes(el.name))
56
+ ?.filter((el) => (el?.type === 'json' ? !selectNames?.includes(el?.name) : true));
57
+
58
+ const res = await Promise.all(arr?.map(async (el) => {
59
+ const type = { json: 'cls', sql: 'select' }[el.type] || el.type;
60
+ // const clsData = await getSelect(type, el.name);
61
+ const str = await readFile(el.path, 'utf-8');
62
+ const clsData = type === 'cls' ? JSON.parse(str) : str;
63
+ if (type === 'cls') {
64
+ const children = params?.id ? clsData : clsData?.length || 0;
65
+ return { name: el.name, type: el.type, children };
66
+ }
67
+ return { name: el.name, type: el.type, sql: clsData?.sql || clsData };
68
+ }));
69
+
70
+ return { message: { rows: rows.concat(res) }, status: 200 };
71
+ }
@@ -1,17 +1,17 @@
1
- export default async function userInfo({
2
- pg, session = {},
3
- }) {
4
- const { uid } = session.passport?.user || {};
5
-
6
- if (!uid) {
7
- return { message: 'access restricted', status: 403 };
8
- }
9
-
10
- const data = await pg.query(`select user_name, sur_name, father_name, user_rnokpp, user_type, email, login from admin.users
11
- where uid=$1`, [uid]).then((res) => res.rows?.[0] || {});
12
-
13
- const { notifications = 0 } = await pg.query(`select count(*)::int as notifications from crm.notifications
14
- where addressee_id=$1 and read is not true`, [uid]).then((res) => res.rows?.[0] || {});
15
- return { uid, ...data, notifications };
16
-
17
- }
1
+ export default async function userInfo({
2
+ pg, session = {},
3
+ }) {
4
+ const { uid } = session.passport?.user || {};
5
+
6
+ if (!uid) {
7
+ return { message: 'access restricted', status: 403 };
8
+ }
9
+
10
+ const data = await pg.query(`select user_name, sur_name, father_name, user_rnokpp, user_type, email, login from admin.users
11
+ where uid=$1`, [uid]).then((res) => res.rows?.[0] || {});
12
+
13
+ const { notifications = 0 } = await pg.query(`select count(*)::int as notifications from crm.notifications
14
+ where addressee_id=$1 and read is not true`, [uid]).then((res) => res.rows?.[0] || {});
15
+ return { uid, ...data, notifications };
16
+
17
+ }
@@ -1,14 +1,14 @@
1
- const userClsSchema = {
2
- quertstring: {
3
- sql: { type: 'string', pattern: '^(\\d)$' },
4
- },
5
- };
6
-
7
- const userClsIdSchema = {
8
- params: {
9
- id: { type: 'string', pattern: '^([\\d\\w\\.]+)$' },
10
- },
11
- };
12
-
13
- export { userClsSchema, userClsIdSchema };
14
- export default null;
1
+ const userClsSchema = {
2
+ quertstring: {
3
+ sql: { type: 'string', pattern: '^(\\d)$' },
4
+ },
5
+ };
6
+
7
+ const userClsIdSchema = {
8
+ params: {
9
+ id: { type: 'string', pattern: '^([\\d\\w\\.]+)$' },
10
+ },
11
+ };
12
+
13
+ export { userClsSchema, userClsIdSchema };
14
+ export default null;
@@ -1,47 +1,47 @@
1
- /**
2
- * Дістає CRM дані для vue хешує ідентифікатори, підтягує селекти
3
- *
4
- * @method DELETE
5
- * @summary CRM дані для обраного віджета.
6
- * @priority 2
7
- * @tag table
8
- * @type api
9
- * @requires setTokenById
10
- * @requires getSelect
11
- * @param {String} id Ідентифікатор для хешування
12
- * @param {Any} sql Використовується для повернення sql запиту
13
- * @param {String} type Тип для хешування даних
14
- * @errors 400, 500
15
- * @returns {Number} status Номер помилки
16
- * @returns {String|Object} error Опис помилки
17
- * @returns {String|Object} message Повідомлення про успішне виконання або об'єкт з параметрами
18
- */
19
-
20
- import { pgClients, logChanges } from "@opengis/fastify-table/utils.js";
21
-
22
- export default async function widgetDel({
23
- pg = pgClients.client, params = {}, session = {},
24
- }) {
25
- const { user = {} } = session.passport || {};
26
- if (!user.uid) return { error: 'access restricted', status: 403 };
27
- const { type, objectid, id } = params;
28
-
29
- if (!objectid) return { error: 'id required', status: 400 };
30
-
31
- const sqls = {
32
- comment: 'delete from crm.communications where entity_id=$1 and uid=$2 and communication_id=$3',
33
- checklist: 'delete from crm.checklists where entity_id=$1 and uid=$2 and checklist_id=$3',
34
- file: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3 returning uploaded_name',
35
- gallery: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3 returning uploaded_name',
36
- };
37
- const sql = sqls[type];
38
- if (!sql) return { error: 'type not valid', status: 401 };
39
-
40
- const { rows = [] } = await pg.query(sql, [objectid, user.uid, id]);
41
- const table = { comment: 'crm.communications', checklist: 'crm.checklists', file: 'crm.files', gallery: 'crm.files' }[type];
42
- await logChanges({
43
- pg, table, id, data: rows[0], uid: user?.uid, type: 'DELETE',
44
- });
45
- return { data: { id }, user: { uid: user.uid, name: user.user_name } };
46
-
47
- }
1
+ /**
2
+ * Дістає CRM дані для vue хешує ідентифікатори, підтягує селекти
3
+ *
4
+ * @method DELETE
5
+ * @summary CRM дані для обраного віджета.
6
+ * @priority 2
7
+ * @tag table
8
+ * @type api
9
+ * @requires setTokenById
10
+ * @requires getSelect
11
+ * @param {String} id Ідентифікатор для хешування
12
+ * @param {Any} sql Використовується для повернення sql запиту
13
+ * @param {String} type Тип для хешування даних
14
+ * @errors 400, 500
15
+ * @returns {Number} status Номер помилки
16
+ * @returns {String|Object} error Опис помилки
17
+ * @returns {String|Object} message Повідомлення про успішне виконання або об'єкт з параметрами
18
+ */
19
+
20
+ import { pgClients, logChanges } from "@opengis/fastify-table/utils.js";
21
+
22
+ export default async function widgetDel({
23
+ pg = pgClients.client, params = {}, session = {},
24
+ }) {
25
+ const { user = {} } = session.passport || {};
26
+ if (!user.uid) return { error: 'access restricted', status: 403 };
27
+ const { type, objectid, id } = params;
28
+
29
+ if (!objectid) return { error: 'id required', status: 400 };
30
+
31
+ const sqls = {
32
+ comment: 'delete from crm.communications where entity_id=$1 and uid=$2 and communication_id=$3',
33
+ checklist: 'delete from crm.checklists where entity_id=$1 and uid=$2 and checklist_id=$3',
34
+ file: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3 returning uploaded_name',
35
+ gallery: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3 returning uploaded_name',
36
+ };
37
+ const sql = sqls[type];
38
+ if (!sql) return { error: 'type not valid', status: 401 };
39
+
40
+ const { rows = [] } = await pg.query(sql, [objectid, user.uid, id]);
41
+ const table = { comment: 'crm.communications', checklist: 'crm.checklists', file: 'crm.files', gallery: 'crm.files' }[type];
42
+ await logChanges({
43
+ pg, table, id, data: rows[0], uid: user?.uid, type: 'DELETE',
44
+ });
45
+ return { data: { id }, user: { uid: user.uid, name: user.user_name } };
46
+
47
+ }
@@ -1,84 +1,84 @@
1
- import path from 'path';
2
-
3
- import {
4
- getMeta, dataInsert, dataUpdate, applyHook,
5
- } from '@opengis/fastify-table/utils.js';
6
-
7
- import { uploadMultiPart } from '@opengis/fastify-file/utils.js';
8
-
9
- const tableList = {
10
- comment: 'crm.communications',
11
- gallery: 'crm.files',
12
- checklist: 'crm.checklists',
13
- };
14
- const pkList = {
15
- comment: 'communication_id',
16
- checklist: 'checklist_id',
17
- gallery: 'file_id',
18
- };
19
-
20
- const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
21
-
22
- export default async function widgetSet(req) {
23
- const {
24
- pg, params = {}, session = {}, body = {},
25
- } = req;
26
- const { user = {} } = session.passport || {};
27
- const { type, id, objectid } = params;
28
- if (!['comment', 'checklist', 'file', 'gallery'].includes(type)) return { message: 'param type not valid', status: 400 };
29
- if (!objectid) return { message: 'id required', status: 400 };
30
-
31
- const table = tableList[type];
32
-
33
- // dsadasdad
34
- if (['gallery', 'file'].includes(type) && req.headers['content-type'].split(';').shift() === "multipart/form-data") {
35
- const file = await uploadMultiPart(req);
36
- const extName = path.extname(file.filepath).slice(1).toLowerCase();
37
-
38
- const data = {
39
- uploaded_name: file?.originalFilename?.toLocaleLowerCase()?.replace(/'/g, '\'\''),
40
- file_path: file?.relativeFilepath?.replace(/\\/g, '/'),
41
- ext: extName,
42
- size: file?.size,
43
- file_status: 1,
44
- uid: user?.uid || 1,
45
- entity_id: objectid,
46
- };
47
-
48
- if (type === 'gallery' && !galleryExtList.includes(extName.toLowerCase())) {
49
- return { message: 'invalid file extension', status: 400 };
50
- }
51
-
52
- const { rows = [] } = await dataInsert({
53
- table: 'crm.files', data, uid: user?.uid,
54
- });
55
- return {
56
- rowCount: 1, data: 'ok', command: 'UPLOAD', id: rows[0]?.file_id, entity_id: rows[0]?.entity_id,
57
- };
58
- }
59
- const { pk } = await getMeta({ pg, table });
60
- if (!pk) return { message: 'table not found', status: 404 };
61
-
62
- const data = { ...body, uid: user?.uid, entity_id: objectid };
63
-
64
- await applyHook('onWidgetSet', {
65
- link: req.path,
66
- id,
67
- objectid,
68
- session,
69
- type,
70
- payload: data,
71
- });
72
-
73
- const result = id
74
- ? await dataUpdate({
75
- table, data, id, uid: user?.uid,
76
- })
77
- : await dataInsert({
78
- table, data, uid: user?.uid,
79
- });
80
-
81
- return {
82
- rowCount: result.rowCount, data: 'ok', command: result.command, id: result.rows?.[0]?.[pkList[type]] || result?.[pkList[type]],
83
- };
84
- }
1
+ import path from 'path';
2
+
3
+ import {
4
+ getMeta, dataInsert, dataUpdate, applyHook,
5
+ } from '@opengis/fastify-table/utils.js';
6
+
7
+ import { uploadMultiPart } from '@opengis/fastify-file/utils.js';
8
+
9
+ const tableList = {
10
+ comment: 'crm.communications',
11
+ gallery: 'crm.files',
12
+ checklist: 'crm.checklists',
13
+ };
14
+ const pkList = {
15
+ comment: 'communication_id',
16
+ checklist: 'checklist_id',
17
+ gallery: 'file_id',
18
+ };
19
+
20
+ const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
21
+
22
+ export default async function widgetSet(req) {
23
+ const {
24
+ pg, params = {}, session = {}, body = {},
25
+ } = req;
26
+ const { user = {} } = session.passport || {};
27
+ const { type, id, objectid } = params;
28
+ if (!['comment', 'checklist', 'file', 'gallery'].includes(type)) return { message: 'param type not valid', status: 400 };
29
+ if (!objectid) return { message: 'id required', status: 400 };
30
+
31
+ const table = tableList[type];
32
+
33
+ // dsadasdad
34
+ if (['gallery', 'file'].includes(type) && req.headers['content-type'].split(';').shift() === "multipart/form-data") {
35
+ const file = await uploadMultiPart(req);
36
+ const extName = path.extname(file.filepath).slice(1).toLowerCase();
37
+
38
+ const data = {
39
+ uploaded_name: file?.originalFilename?.toLocaleLowerCase()?.replace(/'/g, '\'\''),
40
+ file_path: file?.relativeFilepath?.replace(/\\/g, '/'),
41
+ ext: extName,
42
+ size: file?.size,
43
+ file_status: 1,
44
+ uid: user?.uid || 1,
45
+ entity_id: objectid,
46
+ };
47
+
48
+ if (type === 'gallery' && !galleryExtList.includes(extName.toLowerCase())) {
49
+ return { message: 'invalid file extension', status: 400 };
50
+ }
51
+
52
+ const { rows = [] } = await dataInsert({
53
+ table: 'crm.files', data, uid: user?.uid,
54
+ });
55
+ return {
56
+ rowCount: 1, data: 'ok', command: 'UPLOAD', id: rows[0]?.file_id, entity_id: rows[0]?.entity_id,
57
+ };
58
+ }
59
+ const { pk } = await getMeta({ pg, table });
60
+ if (!pk) return { message: 'table not found', status: 404 };
61
+
62
+ const data = { ...body, uid: user?.uid, entity_id: objectid };
63
+
64
+ await applyHook('onWidgetSet', {
65
+ link: req.path,
66
+ id,
67
+ objectid,
68
+ session,
69
+ type,
70
+ payload: data,
71
+ });
72
+
73
+ const result = id
74
+ ? await dataUpdate({
75
+ table, data, id, uid: user?.uid,
76
+ })
77
+ : await dataInsert({
78
+ table, data, uid: user?.uid,
79
+ });
80
+
81
+ return {
82
+ rowCount: result.rowCount, data: 'ok', command: result.command, id: result.rows?.[0]?.[pkList[type]] || result?.[pkList[type]],
83
+ };
84
+ }
@@ -1,12 +1,12 @@
1
- import { pgClients } from '@opengis/fastify-table/utils.js';
2
-
3
- export default async function onWidgetSet({
4
- pg = pgClients.client, id, objectid, type, payload = {},
5
- }) {
6
- if (!id || !objectid || type !== 'gallery') {
7
- return null;
8
- }
9
- if (payload?.ismain) {
10
- await pg.query('update crm.files set ismain=false where entity_id=$1 and file_id<>$2', [objectid, id]);
11
- }
12
- }
1
+ import { pgClients } from '@opengis/fastify-table/utils.js';
2
+
3
+ export default async function onWidgetSet({
4
+ pg = pgClients.client, id, objectid, type, payload = {},
5
+ }) {
6
+ if (!id || !objectid || type !== 'gallery') {
7
+ return null;
8
+ }
9
+ if (payload?.ismain) {
10
+ await pg.query('update crm.files set ismain=false where entity_id=$1 and file_id<>$2', [objectid, id]);
11
+ }
12
+ }
@@ -1,16 +1,16 @@
1
- import { addHook } from '@opengis/fastify-table/utils.js';
2
-
3
- import widgetDel from './controllers/widget.del.js';
4
- import widgetSet from './controllers/widget.set.js';
5
- import widgetGet from './controllers/widget.get.js';
6
-
7
- import onWidgetSet from './hook/onWidgetSet.js';
8
-
9
- import { tableSchema } from './schema.js';
10
-
11
- export default async function route(fastify) {
12
- fastify.delete(`/widget/:type/:objectid/:id`, { scheme: tableSchema }, widgetDel);
13
- fastify.post(`/widget/:type/:objectid/:id?`, { scheme: tableSchema }, widgetSet);
14
- fastify.get(`/widget/:type/:objectid`, { config: { policy: ['public'] }, scheme: tableSchema }, widgetGet);
15
- addHook('onWidgetSet', onWidgetSet);
16
- }
1
+ import { addHook } from '@opengis/fastify-table/utils.js';
2
+
3
+ import widgetDel from './controllers/widget.del.js';
4
+ import widgetSet from './controllers/widget.set.js';
5
+ import widgetGet from './controllers/widget.get.js';
6
+
7
+ import onWidgetSet from './hook/onWidgetSet.js';
8
+
9
+ import { tableSchema } from './schema.js';
10
+
11
+ export default async function route(fastify) {
12
+ fastify.delete(`/widget/:type/:objectid/:id`, { scheme: tableSchema }, widgetDel);
13
+ fastify.post(`/widget/:type/:objectid/:id?`, { scheme: tableSchema }, widgetSet);
14
+ fastify.get(`/widget/:type/:objectid`, { config: { policy: ['public'] }, scheme: tableSchema }, widgetGet);
15
+ addHook('onWidgetSet', onWidgetSet);
16
+ }
@@ -1,13 +1,13 @@
1
- const tableSchema = {
2
- params: {
3
- // type: { type: 'string', pattern: '^([\\d\\w]+)$' },
4
- objectid: { type: 'string', pattern: '^([\\d\\w]+)$' },
5
- id: { type: 'string', pattern: '^([\\d\\w]+)$' },
6
- },
7
- querystring: {
8
- debug: { type: 'string', pattern: '^(\\d+)$' },
9
- },
10
- };
11
-
12
- export default null;
1
+ const tableSchema = {
2
+ params: {
3
+ // type: { type: 'string', pattern: '^([\\d\\w]+)$' },
4
+ objectid: { type: 'string', pattern: '^([\\d\\w]+)$' },
5
+ id: { type: 'string', pattern: '^([\\d\\w]+)$' },
6
+ },
7
+ querystring: {
8
+ debug: { type: 'string', pattern: '^(\\d+)$' },
9
+ },
10
+ };
11
+
12
+ export default null;
13
13
  export { tableSchema }