@opengis/admin 0.1.89 → 0.1.91

Sign up to get free protection for your applications and to get access to all the features.
Files changed (142) hide show
  1. package/README.md +29 -29
  2. package/config.js +4 -4
  3. package/dist/{IconChevronDown-KfsWe5dr.js → IconChevronDown--nil1nCv.js} +1 -1
  4. package/dist/{add-page-CGvuzR96.js → add-page-CX6beoja.js} +1 -1
  5. package/dist/{admin-interface-B_sUn17T.js → admin-interface-B60KBtCX.js} +4 -4
  6. package/dist/{admin-view-BEi_Eri_.js → admin-view-xk2cy8Wu.js} +3 -3
  7. package/dist/admin.js +1 -1
  8. package/dist/admin.umd.cjs +48 -48
  9. package/dist/assets/logo.svg +41 -41
  10. package/dist/{card-view-BvmfTwQ3.js → card-view-BVJP0k1Z.js} +1 -1
  11. package/dist/{edit-page-BkCuIo6n.js → edit-page-PYxyXpVG.js} +1 -1
  12. package/dist/{import-file-CH8kikot.js → import-file-BBuEJJur.js} +3335 -3361
  13. package/dist/style.css +1 -1
  14. package/module/settings/card/admin.roles.table/access.hbs +27 -27
  15. package/module/settings/card/admin.roles.table/general_info.hbs +16 -16
  16. package/module/settings/card/admin.roles.table/index.yml +14 -14
  17. package/module/settings/card/admin.roles.table/users.hbs +27 -27
  18. package/module/settings/card/admin.routes.table/general_info.hbs +40 -40
  19. package/module/settings/card/admin.routes.table/index.yml +8 -8
  20. package/module/settings/card/admin.routes.table/users.hbs +33 -33
  21. package/module/settings/card/admin.users.table/general_info.hbs +25 -25
  22. package/module/settings/card/admin.users.table/index.yml +12 -12
  23. package/module/settings/card/admin.users.table/logs.hbs +30 -30
  24. package/module/settings/card/admin.users.table/user_roles.hbs +24 -24
  25. package/module/settings/cls/core.actions.json +17 -17
  26. package/module/settings/cls/core.scope.json +13 -13
  27. package/module/settings/cls/properties.site_status.json +13 -13
  28. package/module/settings/cls/properties.widget_status.json +13 -13
  29. package/module/settings/cls/users.user_type.json +13 -13
  30. package/module/settings/form/admin.access.form.json +36 -36
  31. package/module/settings/form/admin.custom_column.form.json +71 -71
  32. package/module/settings/form/admin.properties.form.json +15 -15
  33. package/module/settings/form/admin.roles.form.json +19 -19
  34. package/module/settings/form/admin.routes.form.json +25 -25
  35. package/module/settings/form/admin.user_properties.form.json +15 -15
  36. package/module/settings/form/admin.user_roles.form.json +21 -21
  37. package/module/settings/form/admin.users.form.json +153 -153
  38. package/module/settings/form/user.user_roles.form.json +13 -13
  39. package/module/settings/interface/admin.properties.json +4 -4
  40. package/module/settings/interface/admin.roles.json +4 -4
  41. package/module/settings/interface/admin.routes.json +4 -4
  42. package/module/settings/interface/admin.users.json +4 -4
  43. package/module/settings/menu.json +50 -50
  44. package/module/settings/select/core.roles.json +2 -2
  45. package/module/settings/select/core.routes.sql +1 -1
  46. package/module/settings/select/core.user_mentioned.sql +1 -1
  47. package/module/settings/select/core.user_uid.sql +1 -1
  48. package/module/settings/table/admin.access.table.json +83 -83
  49. package/module/settings/table/admin.custom_column.table.json +99 -99
  50. package/module/settings/table/admin.properties.table.json +39 -39
  51. package/module/settings/table/admin.roles.table.json +64 -64
  52. package/module/settings/table/admin.routes.table.json +68 -68
  53. package/module/settings/table/admin.user_properties.table.json +34 -34
  54. package/module/settings/table/admin.user_roles.table.json +72 -72
  55. package/module/settings/table/admin.users.table.json +121 -121
  56. package/package.json +81 -81
  57. package/plugin.js +29 -29
  58. package/server/helpers/controllers/badge.js +11 -11
  59. package/server/helpers/controllers/hb.js +2 -2
  60. package/server/helpers/controllers/map.js +2 -2
  61. package/server/helpers/controllers/mls.js +2 -2
  62. package/server/helpers/controllers/token.js +16 -16
  63. package/server/helpers/controllers/vue.js +2 -2
  64. package/server/helpers/index.mjs +29 -29
  65. package/server/plugins/access/funcs/getAdminAccess.js +14 -14
  66. package/server/plugins/access/index.mjs +6 -6
  67. package/server/plugins/adminHook.js +81 -81
  68. package/server/plugins/cron.js +10 -10
  69. package/server/plugins/docs.js +28 -28
  70. package/server/plugins/hook.js +226 -226
  71. package/server/plugins/vite.js +71 -71
  72. package/server/routes/access/controllers/access.group.js +29 -29
  73. package/server/routes/access/controllers/access.group.post.js +43 -43
  74. package/server/routes/access/index.mjs +63 -63
  75. package/server/routes/calendar/controllers/calendar.data.js +87 -87
  76. package/server/routes/calendar/index.mjs +7 -7
  77. package/server/routes/calendar/schema.js +21 -21
  78. package/server/routes/data/controllers/cardData.js +89 -85
  79. package/server/routes/data/controllers/cardTabData.js +49 -49
  80. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +92 -92
  81. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +170 -170
  82. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  83. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +64 -64
  84. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  85. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  86. package/server/routes/data/controllers/tableData.js +20 -20
  87. package/server/routes/data/controllers/tableDataId.js +27 -27
  88. package/server/routes/data/controllers/tableFilter.js +67 -63
  89. package/server/routes/data/controllers/tokenInfo.js +9 -9
  90. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  91. package/server/routes/data/controllers/utils/conditions.js +21 -0
  92. package/server/routes/data/controllers/utils/getColumns.js +8 -8
  93. package/server/routes/data/index.mjs +17 -17
  94. package/server/routes/data/schema.js +54 -54
  95. package/server/routes/menu/controllers/getMenu.js +67 -67
  96. package/server/routes/menu/index.mjs +5 -5
  97. package/server/routes/notifications/controllers/readNotifications.js +27 -27
  98. package/server/routes/notifications/controllers/testEmail.js +35 -35
  99. package/server/routes/notifications/controllers/userNotifications.js +53 -53
  100. package/server/routes/notifications/funcs/addNotification.js +21 -21
  101. package/server/routes/notifications/funcs/sendNotification.js +105 -105
  102. package/server/routes/notifications/hook/onWidgetSet.js +57 -57
  103. package/server/routes/notifications/index.mjs +27 -27
  104. package/server/routes/notifications/schema.js +16 -16
  105. package/server/routes/properties/controllers/admin.properties.get.js +29 -29
  106. package/server/routes/properties/controllers/user.properties.get.js +30 -30
  107. package/server/routes/properties/controllers/user.properties.post.js +30 -30
  108. package/server/routes/properties/funcs/getSettings.js +56 -56
  109. package/server/routes/properties/funcs/setSettings.js +44 -44
  110. package/server/routes/properties/funcs/utils/dataInsert.js +26 -26
  111. package/server/routes/properties/index.mjs +14 -14
  112. package/server/routes/properties/schema.js +10 -10
  113. package/server/routes/root.mjs +3 -3
  114. package/server/routes/templates/controllers/getTemplate.js +26 -26
  115. package/server/routes/templates/index.mjs +16 -16
  116. package/server/routes/templates/schema.js +8 -8
  117. package/server/routes/user/controllers/user.cls.id.js +14 -14
  118. package/server/routes/user/controllers/user.cls.js +71 -71
  119. package/server/routes/user/controllers/user.cls.post.js +52 -52
  120. package/server/routes/user/controllers/user.info.js +17 -17
  121. package/server/routes/user/schema.js +14 -14
  122. package/server/routes/widget/controllers/utils/historyFormat.js +75 -75
  123. package/server/routes/widget/controllers/utils/obj2db.js +13 -13
  124. package/server/routes/widget/controllers/widget.del.js +41 -41
  125. package/server/routes/widget/controllers/widget.get.js +96 -96
  126. package/server/routes/widget/controllers/widget.set.js +76 -76
  127. package/server/routes/widget/index.mjs +11 -11
  128. package/server/routes/widget/schema.js +12 -12
  129. package/server/templates/cls/itree.recrzone_category.json +73 -73
  130. package/server/templates/cls/test.json +9 -9
  131. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  132. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  133. package/server/templates/form/cp_building.form.json +32 -32
  134. package/server/templates/form/form-user-pass.json +10 -10
  135. package/server/templates/form/form-user_group.json +39 -39
  136. package/server/templates/form/form-users.json +156 -156
  137. package/server/templates/form/user_group_access.form.json +22 -22
  138. package/server/templates/select/account_id.json +2 -2
  139. package/server/templates/table/gis.dataset.table.json +43 -43
  140. package/server/templates/table/management.user_group.table.json +112 -112
  141. package/server/templates/table/management.users.table.json +126 -126
  142. package/utils.js +29 -29
@@ -1,96 +1,96 @@
1
- import { getMeta, getToken } from '@opengis/fastify-table/utils.js';
2
-
3
- import historyFormat from './utils/historyFormat.js';
4
-
5
- const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
6
-
7
- /**
8
- * Дістає CRM для widget
9
- *
10
- */
11
-
12
- export default async function widgetGet({
13
- pg, session = {}, params = {}, query = {},
14
- }) {
15
- const { user = {} } = session.passport || {};
16
-
17
- const param = user?.uid ? await getToken({
18
- token: params.objectid, mode: 'w', uid: user.uid,
19
- }) : null;
20
-
21
- const objectid = param ? JSON.parse(param)?.id : params.objectid;
22
-
23
- if (!objectid) return { error: 'id required', status: 400 };
24
-
25
- const sqls = {
26
- comment: pg.pk['admin.users']
27
- ? `select communication_id, entity_id, body, subject, c.cdate, c.uid,
28
- coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username, avatar
29
- from crm.communications c left join admin.users u on u.uid=c.uid where entity_id=$1 order by cdate desc`
30
- : 'select communication_id, entity_id, body, subject, cdate, uid from crm.communications where entity_id=$1 order by cdate desc',
31
-
32
- history: `SELECT b.change_data_id, change_id, entity_id, entity_type, change_type, change_date, uid, cdate, b.entity_key, b.value_new, b.value_old FROM log.table_changes a
33
- left join lateral(
34
- select change_data_id, entity_key, value_new, value_old from log.table_changes_data where change_id=a.change_id
35
- )b on 1=1
36
- where (entity_id=$1 or entity_id in (
37
- select communication_id as comments from crm.communications where entity_id=$1
38
- union all select file_id from crm.files where entity_id=$1
39
- union all select checklist_id from crm.checklists where entity_id=$1)
40
- ) and b.change_data_id is not null order by cdate desc limit 100`,
41
-
42
- checklist: pg.pk['admin.users']
43
- ? `SELECT checklist_id, entity_id, subject, is_done, done_date, c.uid, c.cdate, coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username,
44
- avatar FROM crm.checklists c left join admin.users u on u.uid=c.uid where entity_id=$1 order by cdate desc`
45
- : 'SELECT checklist_id, entity_id, subject, is_done, done_date, uid, cdate FROM crm.checklists where entity_id=$1 order by cdate desc',
46
-
47
- file: pg.pk['admin.users']
48
- ? `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, c.uid, c.cdate, file_type, c.ismain,
49
- coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username, isverified,
50
- avatar, c.uid as author, file_status FROM crm.files c left join admin.users u on u.uid=c.uid
51
- where entity_id=$1 and file_status<>3 order by cdate desc`
52
- : `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, uid, cdate, file_type, ismain,
53
- isverified, uid as author, file_status FROM crm.files c where entity_id=$1 and file_status<>3 order by cdate desc`,
54
- gallery: pg.pk['admin.users']
55
- ? `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, c.uid, c.cdate, file_type, c.ismain,
56
- coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username, isverified,
57
- avatar, c.uid as author, file_status FROM crm.files c left join admin.users u on u.uid=c.uid
58
- where entity_id=$1 and file_status<>3 and ext = any($2) order by cdate desc`
59
- : `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, c.uid, c.cdate, file_type, ismain,
60
- isverified, uid as author, file_status FROM crm.files c where entity_id=$1 and file_status<>3 and ext = any($2) order by cdate desc`,
61
-
62
- };
63
- const sql = sqls[params.type];
64
- if (!sql) {
65
- return { error: 'param type not valid', status: 400 };
66
- }
67
-
68
-
69
- /* data */
70
- const time = [Date.now()];
71
- const { rows } = await pg.query(sql, [objectid, params.type === 'gallery' ? galleryExtList : null].filter((el) => el));
72
- time.push(Date.now());
73
-
74
- /* Object info */
75
- const { tableName } = pg.pk['log.table_changes'] ? await pg.one('select entity_type as "tableName" from log.table_changes where entity_id=$1 limit 1', [objectid]) : {};
76
- const { pk } = await getMeta({ table: tableName });
77
-
78
- const q = tableName && pg.pk['admin.users'] ? `select coalesce(b.user_name,'')||coalesce(' '||b.sur_name,'') as author, a.cdate, a.editor_date from ${tableName} a
79
- left join admin.users b on a.uid=b.uid where a.${pk}=$1 limit 1` : undefined;
80
- const data = pk && q ? await pg.one(q, [objectid]) : {};
81
-
82
- if (query.debug && user?.user_type === 'admin') {
83
- return {
84
- sql, type: params.type, q, id: objectid, data,
85
- };
86
- }
87
-
88
- time.push(Date.now());
89
- return {
90
- time: { data: time[1] - time[0], format: time[2] - time[1] },
91
- rows: params.type === 'history' ? await historyFormat(rows, tableName, pg) : rows,
92
- user: { uid: user?.uid, name: user?.user_name },
93
- data: { author: data?.author, cdate: data?.cdate, edate: data?.editor_date },
94
- objectid: params.objectid,
95
- };
96
- }
1
+ import { getMeta, getToken } from '@opengis/fastify-table/utils.js';
2
+
3
+ import historyFormat from './utils/historyFormat.js';
4
+
5
+ const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
6
+
7
+ /**
8
+ * Дістає CRM для widget
9
+ *
10
+ */
11
+
12
+ export default async function widgetGet({
13
+ pg, session = {}, params = {}, query = {},
14
+ }) {
15
+ const { user = {} } = session.passport || {};
16
+
17
+ const param = user?.uid ? await getToken({
18
+ token: params.objectid, mode: 'w', uid: user.uid,
19
+ }) : null;
20
+
21
+ const objectid = param ? JSON.parse(param)?.id : params.objectid;
22
+
23
+ if (!objectid) return { error: 'id required', status: 400 };
24
+
25
+ const sqls = {
26
+ comment: pg.pk['admin.users']
27
+ ? `select communication_id, entity_id, body, subject, c.cdate, c.uid,
28
+ coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username, avatar
29
+ from crm.communications c left join admin.users u on u.uid=c.uid where entity_id=$1 order by cdate desc`
30
+ : 'select communication_id, entity_id, body, subject, cdate, uid from crm.communications where entity_id=$1 order by cdate desc',
31
+
32
+ history: `SELECT b.change_data_id, change_id, entity_id, entity_type, change_type, change_date, uid, cdate, b.entity_key, b.value_new, b.value_old FROM log.table_changes a
33
+ left join lateral(
34
+ select change_data_id, entity_key, value_new, value_old from log.table_changes_data where change_id=a.change_id
35
+ )b on 1=1
36
+ where (entity_id=$1 or entity_id in (
37
+ select communication_id as comments from crm.communications where entity_id=$1
38
+ union all select file_id from crm.files where entity_id=$1
39
+ union all select checklist_id from crm.checklists where entity_id=$1)
40
+ ) and b.change_data_id is not null order by cdate desc limit 100`,
41
+
42
+ checklist: pg.pk['admin.users']
43
+ ? `SELECT checklist_id, entity_id, subject, is_done, done_date, c.uid, c.cdate, coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username,
44
+ avatar FROM crm.checklists c left join admin.users u on u.uid=c.uid where entity_id=$1 order by cdate desc`
45
+ : 'SELECT checklist_id, entity_id, subject, is_done, done_date, uid, cdate FROM crm.checklists where entity_id=$1 order by cdate desc',
46
+
47
+ file: pg.pk['admin.users']
48
+ ? `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, c.uid, c.cdate, file_type, c.ismain,
49
+ coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username, isverified,
50
+ avatar, c.uid as author, file_status FROM crm.files c left join admin.users u on u.uid=c.uid
51
+ where entity_id=$1 and file_status<>3 order by cdate desc`
52
+ : `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, uid, cdate, file_type, ismain,
53
+ isverified, uid as author, file_status FROM crm.files c where entity_id=$1 and file_status<>3 order by cdate desc`,
54
+ gallery: pg.pk['admin.users']
55
+ ? `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, c.uid, c.cdate, file_type, c.ismain,
56
+ coalesce(user_name,' ')||' '||coalesce(sur_name,'') as username, isverified,
57
+ avatar, c.uid as author, file_status FROM crm.files c left join admin.users u on u.uid=c.uid
58
+ where entity_id=$1 and file_status<>3 and ext = any($2) order by cdate desc`
59
+ : `SELECT file_id, entity_id, entity_type, file_path, uploaded_name, ext, size, c.uid, c.cdate, file_type, ismain,
60
+ isverified, uid as author, file_status FROM crm.files c where entity_id=$1 and file_status<>3 and ext = any($2) order by cdate desc`,
61
+
62
+ };
63
+ const sql = sqls[params.type];
64
+ if (!sql) {
65
+ return { error: 'param type not valid', status: 400 };
66
+ }
67
+
68
+
69
+ /* data */
70
+ const time = [Date.now()];
71
+ const { rows } = await pg.query(sql, [objectid, params.type === 'gallery' ? galleryExtList : null].filter((el) => el));
72
+ time.push(Date.now());
73
+
74
+ /* Object info */
75
+ const { tableName } = pg.pk['log.table_changes'] ? await pg.one('select entity_type as "tableName" from log.table_changes where entity_id=$1 limit 1', [objectid]) : {};
76
+ const { pk } = await getMeta({ table: tableName });
77
+
78
+ const q = tableName && pg.pk['admin.users'] ? `select coalesce(b.user_name,'')||coalesce(' '||b.sur_name,'') as author, a.cdate, a.editor_date from ${tableName} a
79
+ left join admin.users b on a.uid=b.uid where a.${pk}=$1 limit 1` : undefined;
80
+ const data = pk && q ? await pg.one(q, [objectid]) : {};
81
+
82
+ if (query.debug && user?.user_type === 'admin') {
83
+ return {
84
+ sql, type: params.type, q, id: objectid, data,
85
+ };
86
+ }
87
+
88
+ time.push(Date.now());
89
+ return {
90
+ time: { data: time[1] - time[0], format: time[2] - time[1] },
91
+ rows: params.type === 'history' ? await historyFormat(rows, tableName, pg) : rows,
92
+ user: { uid: user?.uid, name: user?.user_name },
93
+ data: { author: data?.author, cdate: data?.cdate, edate: data?.editor_date },
94
+ objectid: params.objectid,
95
+ };
96
+ }
@@ -1,76 +1,76 @@
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
- checklist: 'crm.checklists',
12
- };
13
- const pkList = {
14
- comment: 'communication_id',
15
- checklist: 'checklist_id',
16
- };
17
-
18
- const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
19
-
20
- export default async function widgetSet(req) {
21
- const {
22
- pg, params = {}, session = {}, body = {},
23
- } = req;
24
- const { user = {} } = session.passport || {};
25
- const { type, id, objectid } = params;
26
- if (!['comment', 'checklist', 'file', 'gallery'].includes(type)) return { message: 'param type not valid', status: 400 };
27
- if (!objectid) return { message: 'id required', status: 400 };
28
-
29
- const table = tableList[type];
30
-
31
-
32
- if (['gallery', 'file'].includes(type)) {
33
- const file = await uploadMultiPart(req);
34
- const extName = path.extname(file.filepath).slice(1).toLowerCase();
35
-
36
- const data = {
37
- uploaded_name: file?.originalFilename?.toLocaleLowerCase()?.replace(/'/g, '\'\''),
38
- file_path: file?.relativeFilepath?.replace(/\\/g, '/'),
39
- ext: extName,
40
- size: file?.size,
41
- file_status: 1,
42
- uid: user?.uid || 1,
43
- entity_id: objectid,
44
- };
45
-
46
- if (type === 'gallery' && !galleryExtList.includes(extName.toLowerCase())) {
47
- return { message: 'invalid file extension', status: 400 };
48
- }
49
-
50
- const { rows = [] } = await dataInsert({
51
- table: 'crm.files', data, uid: user?.uid,
52
- });
53
- return {
54
- rowCount: 1, data: 'ok', command: 'UPLOAD', id: rows[0]?.file_id, entity_id: rows[0]?.entity_id,
55
- };
56
- }
57
- const { pk } = await getMeta({ pg, table });
58
- if (!pk) return { message: 'table not found', status: 404 };
59
-
60
- const data = { ...body, uid: user?.uid, entity_id: objectid };
61
-
62
- await applyHook('onWidgetSet', {
63
- link: req.path, session, type, payload: data,
64
- });
65
- const result = id
66
- ? await dataUpdate({
67
- table, data, id, uid: user?.uid,
68
- })
69
- : await dataInsert({
70
- table, data, uid: user?.uid,
71
- });
72
-
73
- return {
74
- rowCount: result.rowCount, data: 'ok', command: result.command, id: result.rows?.[0]?.[pkList[type]] || result?.[pkList[type]],
75
- };
76
- }
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
+ checklist: 'crm.checklists',
12
+ };
13
+ const pkList = {
14
+ comment: 'communication_id',
15
+ checklist: 'checklist_id',
16
+ };
17
+
18
+ const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
19
+
20
+ export default async function widgetSet(req) {
21
+ const {
22
+ pg, params = {}, session = {}, body = {},
23
+ } = req;
24
+ const { user = {} } = session.passport || {};
25
+ const { type, id, objectid } = params;
26
+ if (!['comment', 'checklist', 'file', 'gallery'].includes(type)) return { message: 'param type not valid', status: 400 };
27
+ if (!objectid) return { message: 'id required', status: 400 };
28
+
29
+ const table = tableList[type];
30
+
31
+
32
+ if (['gallery', 'file'].includes(type)) {
33
+ const file = await uploadMultiPart(req);
34
+ const extName = path.extname(file.filepath).slice(1).toLowerCase();
35
+
36
+ const data = {
37
+ uploaded_name: file?.originalFilename?.toLocaleLowerCase()?.replace(/'/g, '\'\''),
38
+ file_path: file?.relativeFilepath?.replace(/\\/g, '/'),
39
+ ext: extName,
40
+ size: file?.size,
41
+ file_status: 1,
42
+ uid: user?.uid || 1,
43
+ entity_id: objectid,
44
+ };
45
+
46
+ if (type === 'gallery' && !galleryExtList.includes(extName.toLowerCase())) {
47
+ return { message: 'invalid file extension', status: 400 };
48
+ }
49
+
50
+ const { rows = [] } = await dataInsert({
51
+ table: 'crm.files', data, uid: user?.uid,
52
+ });
53
+ return {
54
+ rowCount: 1, data: 'ok', command: 'UPLOAD', id: rows[0]?.file_id, entity_id: rows[0]?.entity_id,
55
+ };
56
+ }
57
+ const { pk } = await getMeta({ pg, table });
58
+ if (!pk) return { message: 'table not found', status: 404 };
59
+
60
+ const data = { ...body, uid: user?.uid, entity_id: objectid };
61
+
62
+ await applyHook('onWidgetSet', {
63
+ link: req.path, session, type, payload: data,
64
+ });
65
+ const result = id
66
+ ? await dataUpdate({
67
+ table, data, id, uid: user?.uid,
68
+ })
69
+ : await dataInsert({
70
+ table, data, uid: user?.uid,
71
+ });
72
+
73
+ return {
74
+ rowCount: result.rowCount, data: 'ok', command: result.command, id: result.rows?.[0]?.[pkList[type]] || result?.[pkList[type]],
75
+ };
76
+ }
@@ -1,11 +1,11 @@
1
- import widgetDel from './controllers/widget.del.js';
2
- import widgetSet from './controllers/widget.set.js';
3
- import widgetGet from './controllers/widget.get.js';
4
-
5
- import {tableSchema} from './schema.js'
6
-
7
- export default async function route(fastify) {
8
- fastify.delete(`widget/:type/:objectid/:id`, { scheme: tableSchema }, widgetDel);
9
- fastify.post(`/widget/:type/:objectid/:id?`, { scheme: tableSchema }, widgetSet);
10
- fastify.get(`/widget/:type/:objectid`, { config: { policy: ['public'] }, scheme: tableSchema }, widgetGet);
11
- }
1
+ import widgetDel from './controllers/widget.del.js';
2
+ import widgetSet from './controllers/widget.set.js';
3
+ import widgetGet from './controllers/widget.get.js';
4
+
5
+ import {tableSchema} from './schema.js'
6
+
7
+ export default async function route(fastify) {
8
+ fastify.delete(`widget/:type/:objectid/:id`, { scheme: tableSchema }, widgetDel);
9
+ fastify.post(`/widget/:type/:objectid/:id?`, { scheme: tableSchema }, widgetSet);
10
+ fastify.get(`/widget/:type/:objectid`, { config: { policy: ['public'] }, scheme: tableSchema }, widgetGet);
11
+ }
@@ -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 }
@@ -1,74 +1,74 @@
1
- [
2
- {
3
- "id": "12",
4
- "text": "Розділювальна смуга",
5
- "color": "#85754e",
6
- "en": "Dividing line"
7
- },
8
- {
9
- "id": "6",
10
- "text": "Бульвар",
11
- "color": "#00703c",
12
- "en": "Boulevard"
13
- },
14
- {
15
- "id": "1",
16
- "text": "Вуличні насадження",
17
- "color": "#8fbc8f",
18
- "en": "Street plantings"
19
- },
20
- {
21
- "id": "2",
22
- "text": "Парк",
23
- "color": "#a2cd5a",
24
- "en": "Park"
25
- },
26
- {
27
- "id": "3",
28
- "text": "Сад",
29
- "color": "#5e8c31",
30
- "en": "Garden"
31
- },
32
- {
33
- "id": "4",
34
- "text": "Сквер",
35
- "color": "#00ced1",
36
- "en": "Square"
37
- },
38
- {
39
- "id": "9",
40
- "text": "Рекреаційна зона",
41
- "color": "#e1a95f",
42
- "en": "Recreational zone"
43
- },
44
- {
45
- "id": "10",
46
- "text": "Санітарно-захисна зона",
47
- "color": "#6e7b8b",
48
- "en": "Sanitary protection zone"
49
- },
50
- {
51
- "id": "11",
52
- "text": "Зелені насадження прибудинкової території",
53
- "color": "#ace1af",
54
- "en": "Green plantations in local areas"
55
- },
56
- {
57
- "id": "5",
58
- "text": "Прибережні зелені насадження",
59
- "color": "#698b69",
60
- "en": "Coastal green plantations"
61
- },
62
- {
63
- "id": "7",
64
- "text": "Лісопарк",
65
- "color": "#6e8b3d",
66
- "en": "Forest park"
67
- },
68
- {
69
- "id": "8",
70
- "text": "Міський ліс",
71
- "color": "#4a5d23",
72
- "en": "Urban forest"
73
- }
1
+ [
2
+ {
3
+ "id": "12",
4
+ "text": "Розділювальна смуга",
5
+ "color": "#85754e",
6
+ "en": "Dividing line"
7
+ },
8
+ {
9
+ "id": "6",
10
+ "text": "Бульвар",
11
+ "color": "#00703c",
12
+ "en": "Boulevard"
13
+ },
14
+ {
15
+ "id": "1",
16
+ "text": "Вуличні насадження",
17
+ "color": "#8fbc8f",
18
+ "en": "Street plantings"
19
+ },
20
+ {
21
+ "id": "2",
22
+ "text": "Парк",
23
+ "color": "#a2cd5a",
24
+ "en": "Park"
25
+ },
26
+ {
27
+ "id": "3",
28
+ "text": "Сад",
29
+ "color": "#5e8c31",
30
+ "en": "Garden"
31
+ },
32
+ {
33
+ "id": "4",
34
+ "text": "Сквер",
35
+ "color": "#00ced1",
36
+ "en": "Square"
37
+ },
38
+ {
39
+ "id": "9",
40
+ "text": "Рекреаційна зона",
41
+ "color": "#e1a95f",
42
+ "en": "Recreational zone"
43
+ },
44
+ {
45
+ "id": "10",
46
+ "text": "Санітарно-захисна зона",
47
+ "color": "#6e7b8b",
48
+ "en": "Sanitary protection zone"
49
+ },
50
+ {
51
+ "id": "11",
52
+ "text": "Зелені насадження прибудинкової території",
53
+ "color": "#ace1af",
54
+ "en": "Green plantations in local areas"
55
+ },
56
+ {
57
+ "id": "5",
58
+ "text": "Прибережні зелені насадження",
59
+ "color": "#698b69",
60
+ "en": "Coastal green plantations"
61
+ },
62
+ {
63
+ "id": "7",
64
+ "text": "Лісопарк",
65
+ "color": "#6e8b3d",
66
+ "en": "Forest park"
67
+ },
68
+ {
69
+ "id": "8",
70
+ "text": "Міський ліс",
71
+ "color": "#4a5d23",
72
+ "en": "Urban forest"
73
+ }
74
74
  ]
@@ -1,10 +1,10 @@
1
- [
2
- {
3
- "id": 1,
4
- "text": "test"
5
- },
6
- {
7
- "id": 2,
8
- "text": "test2"
9
- }
1
+ [
2
+ {
3
+ "id": 1,
4
+ "text": "test"
5
+ },
6
+ {
7
+ "id": 2,
8
+ "text": "test2"
9
+ }
10
10
  ]