@opengis/admin 0.1.85 → 0.1.87

Sign up to get free protection for your applications and to get access to all the features.
Files changed (147) hide show
  1. package/README.md +29 -29
  2. package/config.js +4 -4
  3. package/dist/{IconChevronDown-IrRpX-i0.js → IconChevronDown-7fRR2Xlu.js} +1 -1
  4. package/dist/{add-page-DRXx4iOi.js → add-page-HDC8_rFS.js} +1 -1
  5. package/dist/{admin-interface-BY-D9Jvu.js → admin-interface-BAhPvohd.js} +4 -4
  6. package/dist/{admin-view-BZ75rygK.js → admin-view-DbvhgbGK.js} +101 -95
  7. package/dist/admin.js +1 -1
  8. package/dist/admin.umd.cjs +34 -34
  9. package/dist/assets/logo.svg +41 -41
  10. package/dist/{card-page-BAeSkHUO.js → card-page-CpvUoIWB.js} +144 -141
  11. package/dist/{card-view-p73B3Gbl.js → card-view-Bxl61faa.js} +1 -1
  12. package/dist/{edit-page-CZ8SDvjo.js → edit-page-BfCFDhcy.js} +1 -1
  13. package/dist/{import-file-f46xrNIz.js → import-file-_QpFvb1W.js} +851 -842
  14. package/dist/style.css +1 -1
  15. package/module/settings/card/admin.roles.table/access.hbs +27 -27
  16. package/module/settings/card/admin.roles.table/general_info.hbs +16 -16
  17. package/module/settings/card/admin.roles.table/index.yml +14 -14
  18. package/module/settings/card/admin.roles.table/users.hbs +27 -27
  19. package/module/settings/card/admin.routes.table/general_info.hbs +40 -40
  20. package/module/settings/card/admin.routes.table/index.yml +8 -8
  21. package/module/settings/card/admin.routes.table/users.hbs +33 -33
  22. package/module/settings/card/admin.users.table/general_info.hbs +25 -25
  23. package/module/settings/card/admin.users.table/index.yml +12 -12
  24. package/module/settings/card/admin.users.table/logs.hbs +30 -30
  25. package/module/settings/card/admin.users.table/user_roles.hbs +24 -24
  26. package/module/settings/cls/core.actions.json +17 -17
  27. package/module/settings/cls/core.scope.json +13 -13
  28. package/module/settings/cls/properties.site_status.json +13 -13
  29. package/module/settings/cls/properties.widget_status.json +13 -13
  30. package/module/settings/cls/users.user_type.json +13 -13
  31. package/module/settings/form/admin.access.form.json +36 -36
  32. package/module/settings/form/admin.custom_column.form.json +71 -71
  33. package/module/settings/form/admin.properties.form.json +15 -15
  34. package/module/settings/form/admin.roles.form.json +19 -19
  35. package/module/settings/form/admin.routes.form.json +25 -25
  36. package/module/settings/form/admin.user_properties.form.json +15 -15
  37. package/module/settings/form/admin.user_roles.form.json +21 -21
  38. package/module/settings/form/admin.users.form.json +153 -153
  39. package/module/settings/form/user.user_roles.form.json +13 -13
  40. package/module/settings/interface/admin.properties.json +4 -4
  41. package/module/settings/interface/admin.roles.json +4 -4
  42. package/module/settings/interface/admin.routes.json +4 -4
  43. package/module/settings/interface/admin.users.json +4 -4
  44. package/module/settings/menu.json +50 -50
  45. package/module/settings/select/core.roles.json +2 -2
  46. package/module/settings/select/core.routes.sql +1 -1
  47. package/module/settings/select/core.user_mentioned.sql +1 -1
  48. package/module/settings/select/core.user_uid.sql +1 -1
  49. package/module/settings/table/admin.access.table.json +83 -83
  50. package/module/settings/table/admin.custom_column.table.json +99 -99
  51. package/module/settings/table/admin.properties.table.json +39 -39
  52. package/module/settings/table/admin.roles.table.json +64 -64
  53. package/module/settings/table/admin.routes.table.json +68 -68
  54. package/module/settings/table/admin.user_properties.table.json +34 -34
  55. package/module/settings/table/admin.user_roles.table.json +72 -72
  56. package/module/settings/table/admin.users.table.json +121 -121
  57. package/package.json +82 -82
  58. package/plugin.js +29 -29
  59. package/server/helpers/controllers/badge.js +11 -11
  60. package/server/helpers/controllers/hb.js +2 -2
  61. package/server/helpers/controllers/map.js +2 -2
  62. package/server/helpers/controllers/mls.js +2 -2
  63. package/server/helpers/controllers/token.js +16 -16
  64. package/server/helpers/controllers/vue.js +2 -2
  65. package/server/helpers/index.mjs +29 -29
  66. package/server/helpers/list/buttonHelper.js +10 -10
  67. package/server/helpers/list/descriptionList.js +34 -33
  68. package/server/helpers/list/tableList.js +65 -65
  69. package/server/helpers/list/utils/button.js +5 -5
  70. package/server/plugins/access/funcs/getAdminAccess.js +14 -14
  71. package/server/plugins/access/index.mjs +6 -6
  72. package/server/plugins/adminHook.js +81 -81
  73. package/server/plugins/cron.js +10 -10
  74. package/server/plugins/docs.js +28 -28
  75. package/server/plugins/hook.js +226 -223
  76. package/server/plugins/vite.js +71 -71
  77. package/server/routes/access/controllers/access.group.js +29 -29
  78. package/server/routes/access/controllers/access.group.post.js +43 -43
  79. package/server/routes/access/index.mjs +63 -63
  80. package/server/routes/calendar/controllers/calendar.data.js +87 -87
  81. package/server/routes/calendar/index.mjs +7 -7
  82. package/server/routes/calendar/schema.js +21 -21
  83. package/server/routes/data/controllers/cardData.js +81 -81
  84. package/server/routes/data/controllers/cardTabData.js +49 -49
  85. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +92 -92
  86. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +170 -170
  87. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  88. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +64 -64
  89. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  90. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  91. package/server/routes/data/controllers/tableData.js +20 -20
  92. package/server/routes/data/controllers/tableDataId.js +27 -27
  93. package/server/routes/data/controllers/tableFilter.js +63 -63
  94. package/server/routes/data/controllers/tokenInfo.js +9 -9
  95. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  96. package/server/routes/data/controllers/utils/getColumns.js +8 -8
  97. package/server/routes/data/index.mjs +17 -17
  98. package/server/routes/data/schema.js +54 -54
  99. package/server/routes/menu/controllers/getMenu.js +67 -67
  100. package/server/routes/menu/index.mjs +5 -5
  101. package/server/routes/notifications/controllers/readNotifications.js +27 -27
  102. package/server/routes/notifications/controllers/testEmail.js +35 -35
  103. package/server/routes/notifications/controllers/userNotifications.js +53 -53
  104. package/server/routes/notifications/funcs/addNotification.js +21 -21
  105. package/server/routes/notifications/funcs/sendNotification.js +105 -105
  106. package/server/routes/notifications/hook/onWidgetSet.js +57 -57
  107. package/server/routes/notifications/index.mjs +27 -27
  108. package/server/routes/notifications/schema.js +16 -16
  109. package/server/routes/properties/controllers/admin.properties.get.js +29 -29
  110. package/server/routes/properties/controllers/admin.properties.post.js +2 -2
  111. package/server/routes/properties/controllers/user.properties.get.js +30 -30
  112. package/server/routes/properties/controllers/user.properties.post.js +30 -30
  113. package/server/routes/properties/funcs/getSettings.js +56 -56
  114. package/server/routes/properties/funcs/setSettings.js +44 -44
  115. package/server/routes/properties/funcs/utils/dataInsert.js +26 -26
  116. package/server/routes/properties/index.mjs +14 -14
  117. package/server/routes/properties/schema.js +10 -10
  118. package/server/routes/root.mjs +3 -3
  119. package/server/routes/templates/controllers/getTemplate.js +26 -26
  120. package/server/routes/templates/index.mjs +16 -16
  121. package/server/routes/templates/schema.js +8 -8
  122. package/server/routes/user/controllers/user.cls.id.js +14 -14
  123. package/server/routes/user/controllers/user.cls.js +71 -71
  124. package/server/routes/user/controllers/user.cls.post.js +52 -52
  125. package/server/routes/user/controllers/user.info.js +17 -17
  126. package/server/routes/user/schema.js +14 -14
  127. package/server/routes/widget/controllers/utils/historyFormat.js +75 -75
  128. package/server/routes/widget/controllers/utils/obj2db.js +13 -13
  129. package/server/routes/widget/controllers/widget.del.js +41 -41
  130. package/server/routes/widget/controllers/widget.get.js +96 -96
  131. package/server/routes/widget/controllers/widget.set.js +76 -76
  132. package/server/routes/widget/index.mjs +11 -11
  133. package/server/routes/widget/schema.js +12 -12
  134. package/server/templates/cls/itree.recrzone_category.json +73 -73
  135. package/server/templates/cls/test.json +9 -9
  136. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  137. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  138. package/server/templates/form/cp_building.form.json +32 -32
  139. package/server/templates/form/form-user-pass.json +10 -10
  140. package/server/templates/form/form-user_group.json +39 -39
  141. package/server/templates/form/form-users.json +156 -156
  142. package/server/templates/form/user_group_access.form.json +22 -22
  143. package/server/templates/select/account_id.json +2 -2
  144. package/server/templates/table/gis.dataset.table.json +43 -43
  145. package/server/templates/table/management.user_group.table.json +112 -112
  146. package/server/templates/table/management.users.table.json +126 -126
  147. 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,52 +1,52 @@
1
- export default async function userClsPost({
2
- pg, body = {}, session = {},
3
- }) {
4
- const { uid } = session.passport?.user || {};
5
- const {
6
- name, type = 'json', children = [], sql,
7
- } = body;
8
-
9
- if (!uid) {
10
- return { message: 'access restricted', status: 403 };
11
- }
12
-
13
- if (!name) {
14
- return { message: 'not enough params: name', status: 400 };
15
- }
16
-
17
- if (type === 'json' && (!Array.isArray(children) || !children.length || !children?.[0]?.id)) {
18
- return { message: 'invalid params: children (array of objects)', status: 400 };
19
- }
20
-
21
- if (type === 'sql' && (!sql || typeof sql !== 'string')) {
22
- return { message: 'invalid params: sql (string)', status: 400 };
23
- }
24
-
25
-
26
- const { rowCount = 0 } = await pg.query(`with recursive rows as (
27
- select user_clsid, name, code, icon, color, parent
28
- from admin.user_cls a
29
- where name=$1
30
- union all
31
- select a.user_clsid, a.name, a.code, a.icon, a.color, a.parent
32
- from admin.user_cls a
33
- join rows b on a.parent=b.name
34
- ) delete from admin.user_cls where user_clsid in (select user_clsid from rows )`, [name]);
35
- console.log('delete old user cls', name, rowCount);
36
-
37
- const { id, data } = await pg.query('insert into admin.user_cls(name,type,data,uid) values($1,$2,$3,$4) returning user_clsid as id, data', [name, type, sql, uid])
38
- .then((res) => res.rows?.[0] || {});
39
- if (type === 'json') {
40
- if (!id) { return { error: 'insert user cls error', status: 500 }; }
41
- const q1 = `insert into admin.user_cls(code,name,color,icon,parent,uid)
42
-
43
- select value->>'id',value->>'text',value->>'color',value->>'icon', '${name.replace(/'/g, "''")}', '${uid}'
44
- from json_array_elements('${JSON.stringify(children).replace(/'/g, "''")}'::json)
45
-
46
- returning user_clsid as id, code, name, parent`;
47
- const { rows = [] } = await pg.query(q1);
48
- return { id, children: rows };
49
- }
50
- return { id, data };
51
-
52
- }
1
+ export default async function userClsPost({
2
+ pg, body = {}, session = {},
3
+ }) {
4
+ const { uid } = session.passport?.user || {};
5
+ const {
6
+ name, type = 'json', children = [], sql,
7
+ } = body;
8
+
9
+ if (!uid) {
10
+ return { message: 'access restricted', status: 403 };
11
+ }
12
+
13
+ if (!name) {
14
+ return { message: 'not enough params: name', status: 400 };
15
+ }
16
+
17
+ if (type === 'json' && (!Array.isArray(children) || !children.length || !children?.[0]?.id)) {
18
+ return { message: 'invalid params: children (array of objects)', status: 400 };
19
+ }
20
+
21
+ if (type === 'sql' && (!sql || typeof sql !== 'string')) {
22
+ return { message: 'invalid params: sql (string)', status: 400 };
23
+ }
24
+
25
+
26
+ const { rowCount = 0 } = await pg.query(`with recursive rows as (
27
+ select user_clsid, name, code, icon, color, parent
28
+ from admin.user_cls a
29
+ where name=$1
30
+ union all
31
+ select a.user_clsid, a.name, a.code, a.icon, a.color, a.parent
32
+ from admin.user_cls a
33
+ join rows b on a.parent=b.name
34
+ ) delete from admin.user_cls where user_clsid in (select user_clsid from rows )`, [name]);
35
+ console.log('delete old user cls', name, rowCount);
36
+
37
+ const { id, data } = await pg.query('insert into admin.user_cls(name,type,data,uid) values($1,$2,$3,$4) returning user_clsid as id, data', [name, type, sql, uid])
38
+ .then((res) => res.rows?.[0] || {});
39
+ if (type === 'json') {
40
+ if (!id) { return { error: 'insert user cls error', status: 500 }; }
41
+ const q1 = `insert into admin.user_cls(code,name,color,icon,parent,uid)
42
+
43
+ select value->>'id',value->>'text',value->>'color',value->>'icon', '${name.replace(/'/g, "''")}', '${uid}'
44
+ from json_array_elements('${JSON.stringify(children).replace(/'/g, "''")}'::json)
45
+
46
+ returning user_clsid as id, code, name, parent`;
47
+ const { rows = [] } = await pg.query(q1);
48
+ return { id, children: rows };
49
+ }
50
+ return { id, data };
51
+
52
+ }
@@ -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,75 +1,75 @@
1
- import { readdir } from 'fs/promises';
2
- import { existsSync, readFileSync } from 'fs';
3
-
4
- import { getSelect } from '@opengis/fastify-table/utils.js';
5
-
6
- const dbData = {};
7
-
8
- // from config??
9
- const allTemplates = { table: {} };
10
-
11
- const historyQ = `select nspname||'.'||relname as table_name, json_agg(json_build_object('name',attname, 'title',coalesce(col_description(attrelid, attnum),attname))) as columns
12
- from pg_attribute a
13
- left join pg_catalog.pg_attrdef d ON (a.attrelid, a.attnum) = (d.adrelid, d.adnum)
14
- JOIN pg_class AS i
15
- ON i.oid = a.attrelid
16
- JOIN pg_namespace AS NS ON i.relnamespace = NS.OID
17
- where a.attnum > 0
18
- and not a.attisdropped
19
- group by nspname||'.'||relname`;
20
-
21
- export default async function historyFormat(rows, table, pg) {
22
- if (!rows?.[0]?.changes) return rows; // old structure
23
- // on startup
24
- if (!allTemplates.table.length) {
25
- const templateDir = './server/templates/table';
26
- const templates = existsSync(templateDir) ? await readdir(templateDir) : [];
27
- templates.forEach((template) => {
28
- const body = JSON.parse(readFileSync(`${templateDir}/${template}`) || '{}');
29
- Object.assign(allTemplates.table, { [template]: body });
30
- });
31
- }
32
-
33
- const progrid = Object.keys(allTemplates.table).find((key) => key.replace('.json', '') === table);
34
- if (!progrid) return rows;
35
- // const body = await getTemplate('table', progrid);
36
- const body = allTemplates.table[progrid];
37
- const tableName = body?.table || table;
38
- if (!tableName) return rows;
39
-
40
- // get DB column description
41
- if (!dbData?.[body.table]?.length) {
42
- const { rows: rows1 } = await pg.query(historyQ);
43
- rows1.forEach((row) => {
44
- dbData[row.table_name] = row.columns;
45
- });
46
- }
47
-
48
- // rewrite!!!
49
- await Promise.all(rows?.map(async (op) => {
50
- op.changes?.map(async (el) => {
51
- const col = body.colModel.filter((col1) => col1.name === el.attr)[0] || dbData[body?.table]?.find((col1) => col1.name === el.attr);
52
- if (el.attr === 'geom') {
53
- el.title = 'Геометрія';
54
- }
55
- el.title = col?.ua || col?.title || el.attr;
56
- if (!col) return;
57
- el.type = col.type;
58
- el.format = col.format;
59
- const select = col.data || col.option || col.select;
60
-
61
- // getSelect not equals to node
62
- if (select && false) {
63
- el.select = select;
64
- const cls = await getSelect(select, {
65
- val: [el.old, el.new],
66
- });
67
-
68
- el.oldf = cls[0] || el.old;
69
- el.newf = cls[1] || el.new;
70
- }
71
- });
72
- }));
73
-
74
- return rows;
75
- }
1
+ import { readdir } from 'fs/promises';
2
+ import { existsSync, readFileSync } from 'fs';
3
+
4
+ import { getSelect } from '@opengis/fastify-table/utils.js';
5
+
6
+ const dbData = {};
7
+
8
+ // from config??
9
+ const allTemplates = { table: {} };
10
+
11
+ const historyQ = `select nspname||'.'||relname as table_name, json_agg(json_build_object('name',attname, 'title',coalesce(col_description(attrelid, attnum),attname))) as columns
12
+ from pg_attribute a
13
+ left join pg_catalog.pg_attrdef d ON (a.attrelid, a.attnum) = (d.adrelid, d.adnum)
14
+ JOIN pg_class AS i
15
+ ON i.oid = a.attrelid
16
+ JOIN pg_namespace AS NS ON i.relnamespace = NS.OID
17
+ where a.attnum > 0
18
+ and not a.attisdropped
19
+ group by nspname||'.'||relname`;
20
+
21
+ export default async function historyFormat(rows, table, pg) {
22
+ if (!rows?.[0]?.changes) return rows; // old structure
23
+ // on startup
24
+ if (!allTemplates.table.length) {
25
+ const templateDir = './server/templates/table';
26
+ const templates = existsSync(templateDir) ? await readdir(templateDir) : [];
27
+ templates.forEach((template) => {
28
+ const body = JSON.parse(readFileSync(`${templateDir}/${template}`) || '{}');
29
+ Object.assign(allTemplates.table, { [template]: body });
30
+ });
31
+ }
32
+
33
+ const progrid = Object.keys(allTemplates.table).find((key) => key.replace('.json', '') === table);
34
+ if (!progrid) return rows;
35
+ // const body = await getTemplate('table', progrid);
36
+ const body = allTemplates.table[progrid];
37
+ const tableName = body?.table || table;
38
+ if (!tableName) return rows;
39
+
40
+ // get DB column description
41
+ if (!dbData?.[body.table]?.length) {
42
+ const { rows: rows1 } = await pg.query(historyQ);
43
+ rows1.forEach((row) => {
44
+ dbData[row.table_name] = row.columns;
45
+ });
46
+ }
47
+
48
+ // rewrite!!!
49
+ await Promise.all(rows?.map(async (op) => {
50
+ op.changes?.map(async (el) => {
51
+ const col = body.colModel.filter((col1) => col1.name === el.attr)[0] || dbData[body?.table]?.find((col1) => col1.name === el.attr);
52
+ if (el.attr === 'geom') {
53
+ el.title = 'Геометрія';
54
+ }
55
+ el.title = col?.ua || col?.title || el.attr;
56
+ if (!col) return;
57
+ el.type = col.type;
58
+ el.format = col.format;
59
+ const select = col.data || col.option || col.select;
60
+
61
+ // getSelect not equals to node
62
+ if (select && false) {
63
+ el.select = select;
64
+ const cls = await getSelect(select, {
65
+ val: [el.old, el.new],
66
+ });
67
+
68
+ el.oldf = cls[0] || el.old;
69
+ el.newf = cls[1] || el.new;
70
+ }
71
+ });
72
+ }));
73
+
74
+ return rows;
75
+ }
@@ -1,13 +1,13 @@
1
- export default function obj2db(data, nonexistCol) {
2
- if (
3
- typeof data !== 'object'
4
- || Array.isArray(data)
5
- || !Object.keys(data || {}).length
6
- ) return { error: 'invalid data type' };
7
-
8
- const columns = Object.keys(data)?.filter((key) => !nonexistCol.includes(key));
9
- // const columns = existColumns?.filter((col) => data[col] || data?.[col] === 0);
10
- const args = columns?.map((col) => data[col]);
11
-
12
- return { columns, args, error: !columns?.length ? 'nothing to process' : undefined };
13
- }
1
+ export default function obj2db(data, nonexistCol) {
2
+ if (
3
+ typeof data !== 'object'
4
+ || Array.isArray(data)
5
+ || !Object.keys(data || {}).length
6
+ ) return { error: 'invalid data type' };
7
+
8
+ const columns = Object.keys(data)?.filter((key) => !nonexistCol.includes(key));
9
+ // const columns = existColumns?.filter((col) => data[col] || data?.[col] === 0);
10
+ const args = columns?.map((col) => data[col]);
11
+
12
+ return { columns, args, error: !columns?.length ? 'nothing to process' : undefined };
13
+ }
@@ -1,41 +1,41 @@
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
- export default async function widgetDel({
21
- pg, params = {}, session = {},
22
- }) {
23
- const { user = {} } = session.passport || {};
24
- if (!user.uid) return { error: 'access restricted', status: 403 };
25
- const { type, objectid, id } = params;
26
-
27
- if (!objectid) return { error: 'id required', status: 400 };
28
-
29
- const sqls = {
30
- comment: 'delete from crm.communications where entity_id=$1 and uid=$2 and communication_id=$3',
31
- checklist: 'delete from crm.checklists where entity_id=$1 and uid=$2 and checklist_id=$3',
32
- file: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3',
33
- gallery: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3',
34
- };
35
- const sql = sqls[type];
36
- if (!sql) return { error: 'type not valid', status: 401 };
37
-
38
- await pg.query(sql, [objectid, user.uid, id]);
39
- return { data: { id }, user: { uid: user.uid, name: user.user_name } };
40
-
41
- }
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
+ export default async function widgetDel({
21
+ pg, params = {}, session = {},
22
+ }) {
23
+ const { user = {} } = session.passport || {};
24
+ if (!user.uid) return { error: 'access restricted', status: 403 };
25
+ const { type, objectid, id } = params;
26
+
27
+ if (!objectid) return { error: 'id required', status: 400 };
28
+
29
+ const sqls = {
30
+ comment: 'delete from crm.communications where entity_id=$1 and uid=$2 and communication_id=$3',
31
+ checklist: 'delete from crm.checklists where entity_id=$1 and uid=$2 and checklist_id=$3',
32
+ file: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3',
33
+ gallery: 'update crm.files set file_status=3 where entity_id=$1 and uid=$2 and file_id=$3',
34
+ };
35
+ const sql = sqls[type];
36
+ if (!sql) return { error: 'type not valid', status: 401 };
37
+
38
+ await pg.query(sql, [objectid, user.uid, id]);
39
+ return { data: { id }, user: { uid: user.uid, name: user.user_name } };
40
+
41
+ }