@opengis/admin 0.2.130 → 0.2.132

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (128) hide show
  1. package/README.md +97 -97
  2. package/config.js +4 -4
  3. package/dist/add-page-DQ70Si9f.js +104 -0
  4. package/dist/{admin-interface-DZ_JAuHP.js → admin-interface-CgXFerXl.js} +348 -323
  5. package/dist/{admin-view-CHq_9aht.js → admin-view-t-gzhVnl.js} +231 -291
  6. package/dist/admin.js +1 -1
  7. package/dist/admin.umd.cjs +81 -81
  8. package/dist/assets/logo.svg +41 -41
  9. package/dist/{card-view-DHcY64lQ.js → card-view-Dtf6Ap9G.js} +1 -1
  10. package/dist/edit-page-BWRXfML4.js +125 -0
  11. package/dist/{import-file-BWQ2bV93.js → import-file-CztGvKRc.js} +25619 -26786
  12. package/dist/style.css +1 -1
  13. package/module/settings/card/admin.accounts.table/index.yml +7 -7
  14. package/module/settings/card/admin.accounts.table/rules.hbs +18 -18
  15. package/module/settings/card/admin.accounts.table/users.hbs +13 -13
  16. package/module/settings/card/admin.routes.table/groups.hbs +11 -11
  17. package/module/settings/card/admin.routes.table/users.hbs +16 -16
  18. package/module/settings/cls/core.actions.json +17 -17
  19. package/module/settings/cls/core.scope.json +13 -13
  20. package/module/settings/cls/properties.site_status.json +13 -13
  21. package/module/settings/cls/properties.widget_status.json +13 -13
  22. package/module/settings/cls/users.user_type.json +13 -13
  23. package/module/settings/cls/yes_no.json +11 -11
  24. package/module/settings/form/admin.accounts.form.json +13 -13
  25. package/module/settings/form/admin.properties.form.json +15 -15
  26. package/module/settings/form/admin.roles.form.json +21 -21
  27. package/module/settings/form/admin.user_properties.form.json +15 -15
  28. package/module/settings/form/admin.user_roles_card.form.json +13 -13
  29. package/module/settings/interface/admin.properties.json +4 -4
  30. package/module/settings/interface/admin.roles.json +4 -4
  31. package/module/settings/interface/admin.routes.json +4 -4
  32. package/module/settings/interface/admin.users.json +4 -4
  33. package/module/settings/select/core.routes.sql +1 -1
  34. package/module/settings/select/core.user_mentioned.sql +1 -1
  35. package/module/settings/select/core.user_uid.sql +1 -1
  36. package/module/settings/table/admin.properties.table.json +39 -39
  37. package/module/settings/table/admin.user_properties.table.json +34 -34
  38. package/package.json +5 -5
  39. package/plugin.js +29 -29
  40. package/server/helpers/core/badge.js +16 -16
  41. package/server/helpers/core/buttonHelper.js +21 -21
  42. package/server/helpers/core/coalesce.js +7 -7
  43. package/server/helpers/core/select.js +48 -48
  44. package/server/helpers/core/token.js +18 -18
  45. package/server/helpers/index.js +36 -35
  46. package/server/helpers/list/buttonHelper.js +21 -21
  47. package/server/helpers/temp/contentList.js +58 -58
  48. package/server/helpers/temp/ifCond.js +101 -101
  49. package/server/helpers/utils/button.js +5 -5
  50. package/server/helpers/utils/mdToHTML.js +17 -17
  51. package/server/plugins/access/index.mjs +6 -6
  52. package/server/plugins/adminHook.js +81 -81
  53. package/server/plugins/cron.js +10 -10
  54. package/server/plugins/docs.js +28 -28
  55. package/server/routes/access/controllers/access.group.js +29 -29
  56. package/server/routes/access/controllers/access.group.post.js +54 -54
  57. package/server/routes/access/index.mjs +11 -11
  58. package/server/routes/access/schema.mjs +67 -67
  59. package/server/routes/calendar/controllers/calendar.data.js +125 -125
  60. package/server/routes/calendar/index.mjs +7 -7
  61. package/server/routes/calendar/schema.js +21 -21
  62. package/server/routes/data/controllers/cardTabData.js +49 -49
  63. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +92 -92
  64. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +170 -170
  65. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  66. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +64 -64
  67. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  68. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  69. package/server/routes/data/controllers/tableData.js +31 -31
  70. package/server/routes/data/controllers/tableDataId.js +27 -27
  71. package/server/routes/data/controllers/tableFilter.js +108 -108
  72. package/server/routes/data/controllers/tokenInfo.js +9 -9
  73. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  74. package/server/routes/data/controllers/utils/getColumns.js +8 -8
  75. package/server/routes/data/index.mjs +20 -20
  76. package/server/routes/data/schema.js +54 -54
  77. package/server/routes/menu/controllers/getMenu.js +11 -3
  78. package/server/routes/menu/controllers/interfaces.js +19 -0
  79. package/server/routes/menu/index.mjs +7 -5
  80. package/server/routes/notifications/controllers/readNotifications.js +27 -27
  81. package/server/routes/notifications/controllers/testEmail.js +35 -35
  82. package/server/routes/notifications/controllers/userNotifications.js +53 -53
  83. package/server/routes/notifications/funcs/addNotification.js +21 -21
  84. package/server/routes/notifications/funcs/sendNotification.js +92 -92
  85. package/server/routes/notifications/hook/onWidgetSet.js +56 -56
  86. package/server/routes/notifications/index.mjs +26 -26
  87. package/server/routes/notifications/schema.js +16 -16
  88. package/server/routes/print/controllers/cardPrint.js +134 -134
  89. package/server/routes/print/controllers/printTemplate.js +4 -3
  90. package/server/routes/print/controllers/printTemplatePreview.js +15 -9
  91. package/server/routes/properties/funcs/getSettings.js +56 -56
  92. package/server/routes/properties/schema.js +10 -10
  93. package/server/routes/properties/utils/refreshData.js +4 -4
  94. package/server/routes/report/controllers/data.js +76 -76
  95. package/server/routes/report/controllers/list.js +18 -18
  96. package/server/routes/report/index.mjs +7 -7
  97. package/server/routes/report/utils/formatValue.js +179 -179
  98. package/server/routes/root.mjs +3 -3
  99. package/server/routes/templates/controllers/getTemplate.js +49 -49
  100. package/server/routes/templates/index.mjs +16 -16
  101. package/server/routes/templates/schema.js +8 -8
  102. package/server/routes/user/controllers/user.cls.id.js +14 -14
  103. package/server/routes/user/controllers/user.cls.js +71 -71
  104. package/server/routes/user/controllers/user.info.js +17 -17
  105. package/server/routes/user/schema.js +14 -14
  106. package/server/routes/widget/controllers/widget.del.js +47 -47
  107. package/server/routes/widget/controllers/widget.set.js +84 -84
  108. package/server/routes/widget/hook/onWidgetSet.js +12 -12
  109. package/server/routes/widget/index.mjs +16 -16
  110. package/server/routes/widget/schema.js +12 -12
  111. package/server/templates/cls/itree.recrzone_category.json +73 -73
  112. package/server/templates/cls/test.json +9 -9
  113. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  114. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  115. package/server/templates/form/form-user-pass.json +10 -10
  116. package/server/templates/form/form-user_group.json +39 -39
  117. package/server/templates/form/form-users.json +156 -156
  118. package/server/templates/form/user_group_access.form.json +22 -22
  119. package/server/templates/select/account_id.json +2 -2
  120. package/server/templates/table/gis.dataset.table.json +43 -43
  121. package/server/templates/table/management.user_group.table.json +112 -112
  122. package/server/templates/table/management.users.table.json +126 -126
  123. package/utils.js +29 -29
  124. package/dist/add-page-B9j1X71R.js +0 -119
  125. package/dist/edit-page-DPeBqCDl.js +0 -138
  126. package/dist/profile-page-vqy75jEB.js +0 -78
  127. package/dist/user-B_2kh6ic.js +0 -5
  128. package/module/settings/setting/test.json +0 -6
@@ -1,31 +1,31 @@
1
- import { config, setToken } from "@opengis/fastify-table/utils.js";
2
-
3
- export default function assignTokens({
4
- rows = [], ispublic, uid, loadTable = {},
5
- }) {
6
- if (config?.security?.disableToken) return;
7
-
8
- if (!config?.auth?.disable && !ispublic && !uid) throw new Error('empty user');
9
- if (!loadTable?.table || !(loadTable?.form || loadTable?.add_form)) return null;
10
-
11
- const form = loadTable?.form || loadTable?.add_form;
12
- const addTokens = setToken({
13
- ids: [JSON.stringify({ add: loadTable.table, form })],
14
- mode: 'a',
15
- uid: config?.auth?.disable || ispublic ? '1' : uid,
16
- array: 1,
17
- });
18
- if (!rows.length) return addTokens[0];
19
-
20
- rows.forEach((row) => {
21
- const editTokens = setToken({
22
- ids: [JSON.stringify({ id: row.id, table: loadTable.table, form })],
23
- mode: 'w',
24
- uid: config?.auth?.disable || ispublic ? '1' : uid,
25
- array: 1,
26
- });
27
- Object.assign(row, { token: editTokens[0] });
28
- });
29
- return addTokens[0];
30
-
1
+ import { config, setToken } from "@opengis/fastify-table/utils.js";
2
+
3
+ export default function assignTokens({
4
+ rows = [], ispublic, uid, loadTable = {},
5
+ }) {
6
+ if (config?.security?.disableToken) return;
7
+
8
+ if (!config?.auth?.disable && !ispublic && !uid) throw new Error('empty user');
9
+ if (!loadTable?.table || !(loadTable?.form || loadTable?.add_form)) return null;
10
+
11
+ const form = loadTable?.form || loadTable?.add_form;
12
+ const addTokens = setToken({
13
+ ids: [JSON.stringify({ add: loadTable.table, form })],
14
+ mode: 'a',
15
+ uid: config?.auth?.disable || ispublic ? '1' : uid,
16
+ array: 1,
17
+ });
18
+ if (!rows.length) return addTokens[0];
19
+
20
+ rows.forEach((row) => {
21
+ const editTokens = setToken({
22
+ ids: [JSON.stringify({ id: row.id, table: loadTable.table, form })],
23
+ mode: 'w',
24
+ uid: config?.auth?.disable || ispublic ? '1' : uid,
25
+ array: 1,
26
+ });
27
+ Object.assign(row, { token: editTokens[0] });
28
+ });
29
+ return addTokens[0];
30
+
31
31
  }
@@ -1,9 +1,9 @@
1
- import { getTemplate } from "@opengis/fastify-table/utils.js";
2
-
3
- export default async function getColumns({
4
- columns = [], params = {}, opt = {}, loadTable = {}, form, table, dbColumns = [], mode = 'table',
5
- }) {
6
- const columnList = dbColumns.map((el) => el.name || el).join(',');
7
- const cols = columns.filter((el) => columnList.includes(el?.name) && el?.name !== 'geom').map((el) => el?.name || el).join(',');
8
- return { cols, columnList };
1
+ import { getTemplate } from "@opengis/fastify-table/utils.js";
2
+
3
+ export default async function getColumns({
4
+ columns = [], params = {}, opt = {}, loadTable = {}, form, table, dbColumns = [], mode = 'table',
5
+ }) {
6
+ const columnList = dbColumns.map((el) => el.name || el).join(',');
7
+ const cols = columns.filter((el) => columnList.includes(el?.name) && el?.name !== 'geom').map((el) => el?.name || el).join(',');
8
+ return { cols, columnList };
9
9
  }
@@ -1,20 +1,20 @@
1
-
2
- import tableData from "./controllers/tableData.js";
3
- import tokenInfo from "./controllers/tokenInfo.js";
4
- // import tableDataId from "./controllers/tableDataId.js";
5
- import cardData from "./controllers/cardData.js";
6
- import cardTabData from './controllers/cardTabData.js';
7
- import tableFilter from "./controllers/tableFilter.js";
8
-
9
- import { tableDataSchema, tableDataIdSchema, tableFilterSchema, cardTabDataSchema } from './schema.js';
10
- import tableInfo from "./controllers/tableInfo.js";
11
-
12
- export default async function route(fastify) {
13
- const policy = ['user'];
14
- fastify.get(`/token-info/:token`, { config: { policy: ['admin'] } }, tokenInfo);
15
- fastify.get(`/table-data/:table`, { config: { policy }, schema: tableDataSchema }, tableData);
16
- fastify.get(`/card-data/:token`, { config: { policy }, scheme: cardTabDataSchema }, cardTabData);
17
- fastify.get(`/table-data/:table/:id`, { config: { policy }, schema: tableDataIdSchema }, cardData);
18
- fastify.get(`/table-filter/:name`, { config: { policy }, schema: tableFilterSchema }, tableFilter);
19
- fastify.get(`/table-info/:table/:id?`, { config: { policy }, schema: tableDataSchema }, tableInfo);
20
- }
1
+
2
+ import tableData from "./controllers/tableData.js";
3
+ import tokenInfo from "./controllers/tokenInfo.js";
4
+ // import tableDataId from "./controllers/tableDataId.js";
5
+ import cardData from "./controllers/cardData.js";
6
+ import cardTabData from './controllers/cardTabData.js';
7
+ import tableFilter from "./controllers/tableFilter.js";
8
+
9
+ import { tableDataSchema, tableDataIdSchema, tableFilterSchema, cardTabDataSchema } from './schema.js';
10
+ import tableInfo from "./controllers/tableInfo.js";
11
+
12
+ export default async function route(fastify) {
13
+ const policy = ['user'];
14
+ fastify.get(`/token-info/:token`, { config: { policy: ['admin'] } }, tokenInfo);
15
+ fastify.get(`/table-data/:table`, { config: { policy }, schema: tableDataSchema }, tableData);
16
+ fastify.get(`/card-data/:token`, { config: { policy }, scheme: cardTabDataSchema }, cardTabData);
17
+ fastify.get(`/table-data/:table/:id`, { config: { policy }, schema: tableDataIdSchema }, cardData);
18
+ fastify.get(`/table-filter/:name`, { config: { policy }, schema: tableFilterSchema }, tableFilter);
19
+ fastify.get(`/table-info/:table/:id?`, { config: { policy }, schema: tableDataSchema }, tableInfo);
20
+ }
@@ -1,54 +1,54 @@
1
- const tableDataSchema = {
2
- querystring: {
3
- limit: { type: 'string', pattern: '^(\\d+)$' },
4
- page: { type: 'string', pattern: '^(\\d+)$' },
5
- // filter: { type: 'string', pattern: '^([\\w\\d_-]+)=([А-Яа-яҐґЄєІіЇї\\d\\w\\s\\/\\[\\]\\(\\)\\{\\}\\|,.!?;:—_=-@%#$&^*+=`~]+)$' },
6
- // search: { type: 'string', pattern: '^([А-Яа-яҐґЄєІіЇї\\d\\w\\s\\/\\[\\]\\(\\)\\{\\}\\|,.!?;:—_=-@%#$&^*+=`~]+)$' },
7
- order: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
8
- desc: { type: 'string', pattern: '^(\\d+)$' },
9
- state: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
10
- custom: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
11
- bbox: { type: 'string', pattern: '^([\\d\\s,.-]+)$' },
12
- polyline: { type: 'string', pattern: '^([\\d\\w|@{}~_`]+)$' },
13
- // key: { type: 'string', pattern: '^([\\d\\w_]+)$' },
14
- sql: { type: 'string', pattern: '^(\\d)$' },
15
- },
16
- params: {
17
- id: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
18
- table: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
19
- }
20
- };
21
-
22
- const tableDataIdSchema = {
23
- params: {
24
- id: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
25
- name: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
26
- }
27
- };
28
-
29
- const tableFilterSchema = {
30
- params: {
31
- name: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
32
- }
33
- };
34
-
35
- const cardDataSchema = {
36
- params: {
37
- id: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
38
- table: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
39
- }
40
- };
41
-
42
- const cardTabDataSchema = {
43
- querystring: {
44
- sql: { type: 'string', pattern: '^(\\d)$' }
45
- },
46
- params: {
47
- token: { type: 'string', pattern: '^([\\d\\w]+)$' },
48
- }
49
- };
50
- export {
51
- tableDataSchema, tableDataIdSchema, tableFilterSchema,
52
- cardDataSchema, cardTabDataSchema
53
- }
54
- export default null;
1
+ const tableDataSchema = {
2
+ querystring: {
3
+ limit: { type: 'string', pattern: '^(\\d+)$' },
4
+ page: { type: 'string', pattern: '^(\\d+)$' },
5
+ // filter: { type: 'string', pattern: '^([\\w\\d_-]+)=([А-Яа-яҐґЄєІіЇї\\d\\w\\s\\/\\[\\]\\(\\)\\{\\}\\|,.!?;:—_=-@%#$&^*+=`~]+)$' },
6
+ // search: { type: 'string', pattern: '^([А-Яа-яҐґЄєІіЇї\\d\\w\\s\\/\\[\\]\\(\\)\\{\\}\\|,.!?;:—_=-@%#$&^*+=`~]+)$' },
7
+ order: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
8
+ desc: { type: 'string', pattern: '^(\\d+)$' },
9
+ state: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
10
+ custom: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
11
+ bbox: { type: 'string', pattern: '^([\\d\\s,.-]+)$' },
12
+ polyline: { type: 'string', pattern: '^([\\d\\w|@{}~_`]+)$' },
13
+ // key: { type: 'string', pattern: '^([\\d\\w_]+)$' },
14
+ sql: { type: 'string', pattern: '^(\\d)$' },
15
+ },
16
+ params: {
17
+ id: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
18
+ table: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
19
+ }
20
+ };
21
+
22
+ const tableDataIdSchema = {
23
+ params: {
24
+ id: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
25
+ name: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
26
+ }
27
+ };
28
+
29
+ const tableFilterSchema = {
30
+ params: {
31
+ name: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
32
+ }
33
+ };
34
+
35
+ const cardDataSchema = {
36
+ params: {
37
+ id: { type: 'string', pattern: '^([\\d\\w_.-]+)$' },
38
+ table: { type: 'string', pattern: '^([\\d\\w._-]+)$' },
39
+ }
40
+ };
41
+
42
+ const cardTabDataSchema = {
43
+ querystring: {
44
+ sql: { type: 'string', pattern: '^(\\d)$' }
45
+ },
46
+ params: {
47
+ token: { type: 'string', pattern: '^([\\d\\w]+)$' },
48
+ }
49
+ };
50
+ export {
51
+ tableDataSchema, tableDataIdSchema, tableFilterSchema,
52
+ cardDataSchema, cardTabDataSchema
53
+ }
54
+ export default null;
@@ -1,6 +1,6 @@
1
1
 
2
2
  import { join } from 'path';
3
- import { userTemplateDir, config, pgClients } from '@opengis/fastify-table/utils.js';
3
+ import { userTemplateDir, pgClients, applyHook, config } from '@opengis/fastify-table/utils.js';
4
4
 
5
5
  import { existsSync, readdirSync, readFileSync } from 'fs';
6
6
  const menuCache = [];
@@ -30,11 +30,17 @@ async function readMenu() {
30
30
  return menus;
31
31
  }
32
32
  export default async function adminMenu({ user = {}, session, pg = pgClients.client }) {
33
+ const time = Date.now();
33
34
  if (!user.uid) return { status: 403, message: 'access restricted' }
34
35
 
35
36
  const menus = isProduction && menuCache.length ? menuCache : await readMenu();
36
37
 
38
+ const { rows } = await pgClients.client.query(`select property_key as key,property_text as val from admin.properties where property_key~'^(${config.settingKeys || 'site|map|admin'})'`);
39
+ const settings = rows.reduce((p, { key, val }) => { const [k1, k2] = key.split('.'); p[k1] = p[k1] || {}; p[k1][k2] = val; return p }, {});
37
40
  // update user access
41
+ const { user_name, sur_name, father_name, email, phone, uid } = user;
42
+ const result = { settings, user: { uid, user_name, sur_name, father_name, email, phone } };
43
+ await applyHook('userMenu', result);
38
44
 
39
45
  if (session && user?.uid && !user.user_type?.includes?.('admin') && !user.type?.includes?.('admin') && pg.pk['admin.role_access']) {
40
46
  const { type, gl = [], routes = [] } = await pg.query(`select user_type as type, b.gl,routes from admin.users a
@@ -54,13 +60,15 @@ export default async function adminMenu({ user = {}, session, pg = pgClients.cli
54
60
  session?.set?.('passport', { user });
55
61
  if (type === 'admin') return menus;
56
62
  const userMenus = menus.map(el => (el.menu ? { ...el, menu: el.menu.filter(item => routes?.includes(item.path)) } : el))
57
- return userMenus.filter(el => el.menu?.length || routes?.includes(el.path));
63
+ const menus = userMenus.filter(el => el.menu?.length || routes?.includes(el.path));
64
+ return { time: Date.now() - time, menus, ...result }
58
65
  // .filter((el, idx, arr) => arr.map((el) => el?.ua || el?.en || el?.name).indexOf(el?.ua || el?.en || el?.name) === idx)
59
66
  }
60
67
 
61
68
  // skip dupes?
62
69
  // .filter((el, idx, arr) => arr.map((el) => el?.ua || el?.en || el?.name).indexOf(el?.ua || el?.en || el?.name) === idx)
63
- return menus;
70
+
71
+ return { time: Date.now() - time, menus, ...result };
64
72
 
65
73
 
66
74
  }
@@ -0,0 +1,19 @@
1
+ import { pgClients } from '@opengis/fastify-table/utils.js';
2
+
3
+ export default async function adminMenu({ pg = pgClients.client }) {
4
+ const { rows = [] } = await pg.query(`select route_id, alias, table_name, title, enabled from admin.routes`);
5
+
6
+ const interfaces = rows
7
+ .filter((el, idx, arr) => el.table_name && arr.findIndex(item => item.route_id === el.route_id) === idx)
8
+ .filter(el => pg.pk?.[el.table_name || ''])
9
+ .filter(el => !['log.', 'admin.', 'setting.'].find(item => el.table_name.startsWith(item) ))
10
+ .map(el => ({
11
+ title: el.title,
12
+ alias: el.alias,
13
+ table: el.table_name,
14
+ route: el.route_id,
15
+ enabled: el.enabled,
16
+ }));
17
+
18
+ return interfaces;
19
+ }
@@ -1,5 +1,7 @@
1
- import getMenu from './controllers/getMenu.js';
2
-
3
- export default async function (fastify, opts) {
4
- fastify.get(`/user-menu`, getMenu);
5
- }
1
+ import getMenu from './controllers/getMenu.js';
2
+ import interfaces from './controllers/interfaces.js';
3
+
4
+ export default async function (fastify, opts) {
5
+ fastify.get(`/user-menu`, getMenu);
6
+ fastify.get(`/interfaces`, { config: { policy: ['admin'] } }, interfaces);
7
+ }
@@ -1,27 +1,27 @@
1
- export default async function readNotifications({
2
- pg, params = {}, query = {}, session = {},
3
- }) {
4
- const { uid } = session.passport?.user || {};
5
-
6
- if (!uid) {
7
- return { message: 'access restricted', status: 403 };
8
- }
9
-
10
-
11
- const { userId } = await pg.query('select uid as "userId" from admin.users where $1 in (uid,login) limit 1', [uid])
12
- .then((res) => res.rows?.[0] || {});
13
-
14
- if (!userId) {
15
- return { message: 'access restricted: 2', status: 403 };
16
- }
17
-
18
- const q = `update crm.notifications set read=true where read is not true
19
- and ${params?.id ? 'notification_id=$2' : '1=1'} and addressee_id=$1`;
20
-
21
- if (query.sql) return q;
22
-
23
- const { rowCount = 0 } = await pg.query(q, [userId, params?.id].filter((el) => el));
24
-
25
- return { message: `${rowCount} unread notifications marked as read`, status: 200 };
26
-
27
- }
1
+ export default async function readNotifications({
2
+ pg, params = {}, query = {}, session = {},
3
+ }) {
4
+ const { uid } = session.passport?.user || {};
5
+
6
+ if (!uid) {
7
+ return { message: 'access restricted', status: 403 };
8
+ }
9
+
10
+
11
+ const { userId } = await pg.query('select uid as "userId" from admin.users where $1 in (uid,login) limit 1', [uid])
12
+ .then((res) => res.rows?.[0] || {});
13
+
14
+ if (!userId) {
15
+ return { message: 'access restricted: 2', status: 403 };
16
+ }
17
+
18
+ const q = `update crm.notifications set read=true where read is not true
19
+ and ${params?.id ? 'notification_id=$2' : '1=1'} and addressee_id=$1`;
20
+
21
+ if (query.sql) return q;
22
+
23
+ const { rowCount = 0 } = await pg.query(q, [userId, params?.id].filter((el) => el));
24
+
25
+ return { message: `${rowCount} unread notifications marked as read`, status: 200 };
26
+
27
+ }
@@ -1,35 +1,35 @@
1
- import config from '../../../../config.js';
2
-
3
- import sendNotification from '../funcs/sendNotification.js';
4
-
5
- export default async function testNotification({
6
- pg, query = {}, session = {},
7
- }) {
8
- const { local } = config || {};
9
-
10
- if (!session?.passport?.user?.user_type?.includes('admin') && !local) {
11
- return { message: 'Forbidden', status: 403 };
12
- }
13
-
14
- const date = new Date().toISOString().split('T')[0];
15
- if (!query.to) {
16
- return { message: 'param to is required', status: 400 };
17
- }
18
-
19
- const {
20
- to, template, table, id, nocache,
21
- } = query;
22
-
23
- const data = await sendNotification({
24
- pg,
25
- to,
26
- template,
27
- title: `Test Softpro ${date}`,
28
- table,
29
- nocache,
30
- id,
31
- message: `Test mail Softpro ${date} Lorem Ipsum Lorem Ipsum`,
32
- });
33
-
34
- return { message: data || 'ok' };
35
- }
1
+ import config from '../../../../config.js';
2
+
3
+ import sendNotification from '../funcs/sendNotification.js';
4
+
5
+ export default async function testNotification({
6
+ pg, query = {}, session = {},
7
+ }) {
8
+ const { local } = config || {};
9
+
10
+ if (!session?.passport?.user?.user_type?.includes('admin') && !local) {
11
+ return { message: 'Forbidden', status: 403 };
12
+ }
13
+
14
+ const date = new Date().toISOString().split('T')[0];
15
+ if (!query.to) {
16
+ return { message: 'param to is required', status: 400 };
17
+ }
18
+
19
+ const {
20
+ to, template, table, id, nocache,
21
+ } = query;
22
+
23
+ const data = await sendNotification({
24
+ pg,
25
+ to,
26
+ template,
27
+ title: `Test Softpro ${date}`,
28
+ table,
29
+ nocache,
30
+ id,
31
+ message: `Test mail Softpro ${date} Lorem Ipsum Lorem Ipsum`,
32
+ });
33
+
34
+ return { message: data || 'ok' };
35
+ }
@@ -1,53 +1,53 @@
1
- // for example only
2
- /*
3
- const res = await dataInsert({
4
- pg,
5
- table: 'crm.notifications',
6
- data: {
7
- subject: 'notif title',
8
- body: 'notif body',
9
- link: 'http://localhost:3000/api/notification',
10
- addressee_id: userId,
11
- author_id: userId,
12
- },
13
- });
14
- */
15
-
16
- import { getSelectVal } from '@opengis/fastify-table/utils.js';
17
-
18
- const maxLimit = 100;
19
-
20
- export default async function userNotifications({
21
- pg, query = {}, session = {},
22
- }) {
23
- const time = Date.now();
24
-
25
- const { uid } = session.passport?.user || {};
26
-
27
- if (!uid) {
28
- return { message: 'access restricted', status: 403 };
29
- }
30
-
31
- const limit = Math.min(maxLimit, +(query.limit || 5));
32
- const offset = query.page && query.page > 0 ? (query.page - 1) * limit : 0;
33
-
34
- const q = `select notification_id as id, subject, body, cdate,
35
- author_id, read, link, entity_id, (select avatar from admin.users where uid=a.author_id limit 1) as avatar from crm.notifications a where addressee_id=$1 order by cdate desc limit $2 offset $3`;
36
-
37
- if (query.sql) return q;
38
-
39
- const { rows = [] } = await pg.query(q, [uid, limit, offset]);
40
-
41
- const values = rows.map((el) => el.author_id)
42
- ?.filter((el, idx, arr) => el && arr.indexOf(el) === idx);
43
-
44
- if (values?.length) {
45
- const vals = await getSelectVal({ name: 'core.user_mentioned', values });
46
- rows.forEach((row) => {
47
- Object.assign(row, { author: vals?.[row.author_id] });
48
- });
49
- }
50
-
51
- return { time: Date.now() - time, total: rows?.length, rows };
52
-
53
- }
1
+ // for example only
2
+ /*
3
+ const res = await dataInsert({
4
+ pg,
5
+ table: 'crm.notifications',
6
+ data: {
7
+ subject: 'notif title',
8
+ body: 'notif body',
9
+ link: 'http://localhost:3000/api/notification',
10
+ addressee_id: userId,
11
+ author_id: userId,
12
+ },
13
+ });
14
+ */
15
+
16
+ import { getSelectVal } from '@opengis/fastify-table/utils.js';
17
+
18
+ const maxLimit = 100;
19
+
20
+ export default async function userNotifications({
21
+ pg, query = {}, session = {},
22
+ }) {
23
+ const time = Date.now();
24
+
25
+ const { uid } = session.passport?.user || {};
26
+
27
+ if (!uid) {
28
+ return { message: 'access restricted', status: 403 };
29
+ }
30
+
31
+ const limit = Math.min(maxLimit, +(query.limit || 5));
32
+ const offset = query.page && query.page > 0 ? (query.page - 1) * limit : 0;
33
+
34
+ const q = `select notification_id as id, subject, body, cdate,
35
+ author_id, read, link, entity_id, (select avatar from admin.users where uid=a.author_id limit 1) as avatar from crm.notifications a where addressee_id=$1 order by cdate desc limit $2 offset $3`;
36
+
37
+ if (query.sql) return q;
38
+
39
+ const { rows = [] } = await pg.query(q, [uid, limit, offset]);
40
+
41
+ const values = rows.map((el) => el.author_id)
42
+ ?.filter((el, idx, arr) => el && arr.indexOf(el) === idx);
43
+
44
+ if (values?.length) {
45
+ const vals = await getSelectVal({ name: 'core.user_mentioned', values });
46
+ rows.forEach((row) => {
47
+ Object.assign(row, { author: vals?.[row.author_id] });
48
+ });
49
+ }
50
+
51
+ return { time: Date.now() - time, total: rows?.length, rows };
52
+
53
+ }
@@ -1,21 +1,21 @@
1
- import { dataInsert } from '@opengis/fastify-table/utils.js';
2
-
3
- export default async function addNotification({
4
- pg, session = {}, subject, body, link, uid, entity,
5
- }) {
6
- const { uid: author } = session.passport?.user || {};
7
- const res = await dataInsert({
8
- pg,
9
- table: 'crm.notifications',
10
- data: {
11
- subject,
12
- body,
13
- link,
14
- addressee_id: uid,
15
- author_id: author,
16
- entity_id: entity,
17
- uid: author,
18
- },
19
- });
20
- return res?.rows?.[0] || {};
21
- }
1
+ import { dataInsert } from '@opengis/fastify-table/utils.js';
2
+
3
+ export default async function addNotification({
4
+ pg, session = {}, subject, body, link, uid, entity,
5
+ }) {
6
+ const { uid: author } = session.passport?.user || {};
7
+ const res = await dataInsert({
8
+ pg,
9
+ table: 'crm.notifications',
10
+ data: {
11
+ subject,
12
+ body,
13
+ link,
14
+ addressee_id: uid,
15
+ author_id: author,
16
+ entity_id: entity,
17
+ uid: author,
18
+ },
19
+ });
20
+ return res?.rows?.[0] || {};
21
+ }