@opengis/admin 0.1.38 → 0.1.39

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 (103) hide show
  1. package/README.md +29 -29
  2. package/config.js +4 -4
  3. package/dist/{add-page-C5g2yN5N.js → add-page-CYAz9FdO.js} +1 -1
  4. package/dist/{admin-interface-zpEN5ODZ.js → admin-interface-BfY0EPQi.js} +1 -1
  5. package/dist/{admin-view-DD8_bEjC.js → admin-view-CcyuPjSQ.js} +2 -2
  6. package/dist/admin.js +1 -1
  7. package/dist/admin.umd.cjs +5 -5
  8. package/dist/{card-page-BpMHxKbw.js → card-page-DV3pe4fv.js} +21 -21
  9. package/dist/{card-view-Ddro0nc4.js → card-view-pwoN8ZHo.js} +1 -1
  10. package/dist/{edit-page-BL9SogVY.js → edit-page-PNY_GQBC.js} +1 -1
  11. package/dist/{import-file-DBSDU17c.js → import-file-aqrl_bc7.js} +20 -13
  12. package/dist/style.css +1 -1
  13. package/module/settings/card/admin.roles.table/access.hbs +27 -27
  14. package/module/settings/card/admin.roles.table/general_info.hbs +16 -16
  15. package/module/settings/card/admin.roles.table/index.yml +14 -14
  16. package/module/settings/card/admin.roles.table/users.hbs +27 -27
  17. package/module/settings/card/admin.routes.table/general_info.hbs +40 -40
  18. package/module/settings/card/admin.routes.table/index.yml +8 -8
  19. package/module/settings/card/admin.routes.table/users.hbs +33 -33
  20. package/module/settings/card/admin.users.table/general_info.hbs +25 -25
  21. package/module/settings/card/admin.users.table/index.yml +12 -12
  22. package/module/settings/card/admin.users.table/logs.hbs +30 -30
  23. package/module/settings/card/admin.users.table/user_roles.hbs +24 -24
  24. package/module/settings/cls/core.actions.json +13 -13
  25. package/module/settings/cls/core.scope.json +13 -13
  26. package/module/settings/cls/properties.site_status.json +13 -13
  27. package/module/settings/cls/properties.widget_status.json +13 -13
  28. package/module/settings/cls/users.user_type.json +13 -13
  29. package/module/settings/form/admin.access.form.json +36 -36
  30. package/module/settings/form/admin.properties.form.json +15 -15
  31. package/module/settings/form/admin.roles.form.json +19 -19
  32. package/module/settings/form/admin.routes.form.json +25 -25
  33. package/module/settings/form/admin.table_properties.form.json +70 -70
  34. package/module/settings/form/admin.user_properties.form.json +15 -15
  35. package/module/settings/form/admin.user_roles.form.json +21 -21
  36. package/module/settings/form/admin.users.form.json +150 -150
  37. package/module/settings/form/user.user_roles.form.json +13 -13
  38. package/module/settings/interface/admin.properties.json +4 -4
  39. package/module/settings/interface/admin.roles.json +4 -4
  40. package/module/settings/interface/admin.routes.json +4 -4
  41. package/module/settings/interface/admin.users.json +4 -4
  42. package/module/settings/menu.json +50 -50
  43. package/module/settings/select/core.roles.json +2 -2
  44. package/module/settings/select/core.user_uid.sql +1 -1
  45. package/module/settings/table/admin.access.table.json +77 -77
  46. package/module/settings/table/admin.properties.table.json +33 -33
  47. package/module/settings/table/admin.roles.table.json +58 -58
  48. package/module/settings/table/admin.routes.table.json +55 -55
  49. package/module/settings/table/admin.table_properties.table.json +81 -81
  50. package/module/settings/table/admin.user_properties.table.json +28 -28
  51. package/module/settings/table/admin.user_roles.table.json +66 -66
  52. package/module/settings/table/admin.users.table.json +119 -119
  53. package/package.json +74 -74
  54. package/plugin.js +101 -101
  55. package/server/helpers/controllers/badge.js +11 -11
  56. package/server/helpers/controllers/hb.js +2 -2
  57. package/server/helpers/controllers/map.js +2 -2
  58. package/server/helpers/controllers/mls.js +2 -2
  59. package/server/helpers/controllers/vue.js +2 -2
  60. package/server/helpers/index.mjs +13 -13
  61. package/server/plugins/docs.js +28 -28
  62. package/server/plugins/hook.js +166 -166
  63. package/server/plugins/vite.js +69 -69
  64. package/server/routes/data/controllers/cardData.js +56 -56
  65. package/server/routes/data/controllers/cardTabData.js +39 -39
  66. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +85 -85
  67. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +145 -142
  68. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  69. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +67 -67
  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 +121 -121
  73. package/server/routes/data/controllers/tableDataId.js +27 -27
  74. package/server/routes/data/controllers/tableFilter.js +55 -55
  75. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  76. package/server/routes/data/controllers/utils/getColumns.js +21 -21
  77. package/server/routes/data/index.mjs +12 -12
  78. package/server/routes/menu/controllers/getMenu.js +33 -33
  79. package/server/routes/menu/index.mjs +5 -5
  80. package/server/routes/properties/controllers/admin.properties.get.js +29 -29
  81. package/server/routes/properties/controllers/user.properties.get.js +34 -34
  82. package/server/routes/properties/controllers/user.properties.post.js +30 -30
  83. package/server/routes/properties/funcs/getSettings.js +56 -56
  84. package/server/routes/properties/funcs/setSettings.js +44 -44
  85. package/server/routes/properties/funcs/utils/dataInsert.js +26 -26
  86. package/server/routes/properties/index.mjs +26 -26
  87. package/server/routes/root.mjs +3 -3
  88. package/server/routes/templates/controllers/getTemplate.js +14 -14
  89. package/server/routes/templates/index.mjs +14 -14
  90. package/server/templates/cls/itree.recrzone_category.json +73 -73
  91. package/server/templates/cls/test.json +9 -9
  92. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  93. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  94. package/server/templates/form/cp_building.form.json +32 -32
  95. package/server/templates/form/form-user-pass.json +10 -10
  96. package/server/templates/form/form-user_group.json +39 -39
  97. package/server/templates/form/form-users.json +156 -156
  98. package/server/templates/form/user_group_access.form.json +22 -22
  99. package/server/templates/select/account_id.json +2 -2
  100. package/server/templates/table/gis.dataset.table.json +43 -43
  101. package/server/templates/table/management.user_group.table.json +112 -112
  102. package/server/templates/table/management.users.table.json +126 -126
  103. package/utils.js +8 -8
@@ -1,31 +1,31 @@
1
- import setToken from "@opengis/fastify-table/crud/funcs/setToken.js";
2
-
3
- export default function assignTokens({
4
- rows = [], funcs = {}, ispublic, uid, loadTable = {},
5
- }) {
6
- if (funcs.config?.security?.disableToken) return;
7
-
8
- if (!funcs.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: funcs.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: funcs.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 setToken from "@opengis/fastify-table/crud/funcs/setToken.js";
2
+
3
+ export default function assignTokens({
4
+ rows = [], funcs = {}, ispublic, uid, loadTable = {},
5
+ }) {
6
+ if (funcs.config?.security?.disableToken) return;
7
+
8
+ if (!funcs.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: funcs.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: funcs.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,22 +1,22 @@
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
- if (mode === 'table') {
8
- const cols = columns.filter((el) => el?.name !== 'geom').map((el) => el?.name || el).join(',');
9
- return { cols, columnList };
10
- }
11
- // card / edit form
12
- const schema = await getTemplate('form', opt?.form || form) || {};
13
- // skip DataTable from another table
14
- const extraKeys = Object.keys(schema)?.filter((key) => schema[key]?.type === 'DataTable' && schema[key]?.table && schema[key]?.parent_id && schema[key]?.colModel?.length);
15
- // skip non-existing columns
16
- const { fields = [] } = !loadTable?.table ? await pg.query(`select * from ${table || opt?.table || params.table} limit 0`) : {};
17
- const cols = loadTable?.table
18
- ? Object.keys(schema || {}).filter((col) => columnList.includes(col) && !extraKeys.includes(col))?.join(',')
19
- : fields.map((el) => (el?.name?.includes('geom') ? `st_asgeojson(${el.name})::json as "${el.name}"` : `"${el?.name}"`)).join(',');
20
-
21
- return { cols, columnList, extraKeys, schema };
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
+ if (mode === 'table') {
8
+ const cols = columns.filter((el) => el?.name !== 'geom').map((el) => el?.name || el).join(',');
9
+ return { cols, columnList };
10
+ }
11
+ // card / edit form
12
+ const schema = await getTemplate('form', opt?.form || form) || {};
13
+ // skip DataTable from another table
14
+ const extraKeys = Object.keys(schema)?.filter((key) => schema[key]?.type === 'DataTable' && schema[key]?.table && schema[key]?.parent_id && schema[key]?.colModel?.length);
15
+ // skip non-existing columns
16
+ const { fields = [] } = !loadTable?.table ? await pg.query(`select * from ${table || opt?.table || params.table} limit 0`) : {};
17
+ const cols = loadTable?.table
18
+ ? Object.keys(schema || {}).filter((col) => columnList.includes(col) && !extraKeys.includes(col))?.join(',')
19
+ : fields.map((el) => (el?.name?.includes('geom') ? `st_asgeojson(${el.name})::json as "${el.name}"` : `"${el?.name}"`)).join(',');
20
+
21
+ return { cols, columnList, extraKeys, schema };
22
22
  }
@@ -1,12 +1,12 @@
1
- import tableData from "./controllers/tableData.js";
2
- // import tableDataId from "./controllers/tableDataId.js";
3
- import cardData from "./controllers/cardData.js";
4
- import cardTabData from './controllers/cardTabData.js';
5
- import tableFilter from "./controllers/tableFilter.js";
6
-
7
- export default async function route(fastify) {
8
- fastify.get(`/table-data/:table`, tableData);
9
- fastify.get(`/card-data/:token`, cardTabData);
10
- fastify.get(`/table-data/:table/:id`, cardData);
11
- fastify.get(`/table-filter/:name`, tableFilter);
12
- }
1
+ import tableData from "./controllers/tableData.js";
2
+ // import tableDataId from "./controllers/tableDataId.js";
3
+ import cardData from "./controllers/cardData.js";
4
+ import cardTabData from './controllers/cardTabData.js';
5
+ import tableFilter from "./controllers/tableFilter.js";
6
+
7
+ export default async function route(fastify) {
8
+ fastify.get(`/table-data/:table`, tableData);
9
+ fastify.get(`/card-data/:token`, cardTabData);
10
+ fastify.get(`/table-data/:table/:id`, cardData);
11
+ fastify.get(`/table-filter/:name`, tableFilter);
12
+ }
@@ -1,34 +1,34 @@
1
-
2
- import { join } from 'path';
3
- import { userTemplateDir } from '@opengis/fastify-table/utils.js';
4
-
5
- import { existsSync, readdirSync, readFileSync } from 'fs';
6
- const menuCache = [];
7
- // check module dir
8
- const moduleDir = join(process.cwd(), 'module');
9
- const dirs = existsSync(moduleDir) ?
10
- readdirSync(moduleDir).map(el => join(moduleDir, el)) : [];
11
-
12
- // all menu files module + user
13
- const menuList = dirs.concat(userTemplateDir)
14
- .map(el => join(el, 'menu.json'))
15
- .filter(el => existsSync(el))
16
-
17
-
18
- const isProduction = process.env.NODE_ENV === 'production';
19
- readMenu();
20
-
21
- async function readMenu() {
22
- // const list = menuList.map(el => readFileSync(el, 'utf-8')); // sync
23
- const list = await Promise.all(menuList.map(el => readFileSync(el, 'utf-8'))); // sync
24
- const menus = list.reduce((p, el) => p.concat(JSON.parse(el)), [])
25
- .map(el => ({ order: 0, ...el }))
26
- .sort((a, b) => (a.order > b.order) ? 1 : ((b.order > a.order) ? -1 : 0))
27
-
28
- if (!menuCache.length) menus.forEach(el => menuCache.push(el))
29
- return menus;
30
- }
31
- export default async function adminMenu() {
32
- const menus = isProduction && menuCache.length ? menuCache : await readMenu();
33
- return menus;
1
+
2
+ import { join } from 'path';
3
+ import { userTemplateDir } from '@opengis/fastify-table/utils.js';
4
+
5
+ import { existsSync, readdirSync, readFileSync } from 'fs';
6
+ const menuCache = [];
7
+ // check module dir
8
+ const moduleDir = join(process.cwd(), 'module');
9
+ const dirs = existsSync(moduleDir) ?
10
+ readdirSync(moduleDir).map(el => join(moduleDir, el)) : [];
11
+
12
+ // all menu files module + user
13
+ const menuList = dirs.concat(userTemplateDir)
14
+ .map(el => join(el, 'menu.json'))
15
+ .filter(el => existsSync(el))
16
+
17
+
18
+ const isProduction = process.env.NODE_ENV === 'production';
19
+ readMenu();
20
+
21
+ async function readMenu() {
22
+ // const list = menuList.map(el => readFileSync(el, 'utf-8')); // sync
23
+ const list = await Promise.all(menuList.map(el => readFileSync(el, 'utf-8'))); // sync
24
+ const menus = list.reduce((p, el) => p.concat(JSON.parse(el)), [])
25
+ .map(el => ({ order: 0, ...el }))
26
+ .sort((a, b) => (a.order > b.order) ? 1 : ((b.order > a.order) ? -1 : 0))
27
+
28
+ if (!menuCache.length) menus.forEach(el => menuCache.push(el))
29
+ return menus;
30
+ }
31
+ export default async function adminMenu() {
32
+ const menus = isProduction && menuCache.length ? menuCache : await readMenu();
33
+ return menus;
34
34
  }
@@ -1,5 +1,5 @@
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
+
3
+ export default async function (fastify, opts) {
4
+ fastify.get(`/user-menu`, getMenu);
5
+ }
@@ -1,29 +1,29 @@
1
- const table = 'admin.properties';
2
-
3
- import { getRedis } from '@opengis/fastify-table/utils.js';
4
-
5
- import { getSettings } from '../../../../utils.js';
6
-
7
- export default async function getSettingsAPI({
8
- pg = {}, funcs = {}, params = {}, query = {},
9
- }) {
10
- if (!pg.pk?.[table]) {
11
- return { message: 'table not found', status: 404 };
12
- }
13
-
14
- const redis = getRedis();
15
- const keyCache = `${pg.options?.database}:settings:${params?.key || 'all'}:${query?.json ? 'json' : 'plain'}:${table}`;
16
-
17
- const cache = await redis.get(keyCache);
18
- if (cache && !funcs.config?.local) return JSON.parse(cache);
19
-
20
- try {
21
- const res = await getSettings({
22
- pg, key: params.key, json: query.json, redis, table,
23
- });
24
- return { message: res, status: 200 };
25
- }
26
- catch (err) {
27
- return { error: err.toString(), status: 500 };
28
- }
29
- }
1
+ const table = 'admin.properties';
2
+
3
+ import { getRedis } from '@opengis/fastify-table/utils.js';
4
+
5
+ import { getSettings } from '../../../../utils.js';
6
+
7
+ export default async function getSettingsAPI({
8
+ pg = {}, funcs = {}, params = {}, query = {},
9
+ }) {
10
+ if (!pg.pk?.[table]) {
11
+ return { message: 'table not found', status: 404 };
12
+ }
13
+
14
+ const redis = getRedis();
15
+ const keyCache = `${pg.options?.database}:settings:${params?.key || 'all'}:${query?.json ? 'json' : 'plain'}:${table}`;
16
+
17
+ const cache = await redis.get(keyCache);
18
+ if (cache && !funcs.config?.local) return JSON.parse(cache);
19
+
20
+ try {
21
+ const res = await getSettings({
22
+ pg, key: params.key, json: query.json, redis, table,
23
+ });
24
+ return { message: res, status: 200 };
25
+ }
26
+ catch (err) {
27
+ return { error: err.toString(), status: 500 };
28
+ }
29
+ }
@@ -1,34 +1,34 @@
1
- const table = 'admin.user_properties';
2
-
3
- import { getRedis } from '@opengis/fastify-table/utils.js';
4
-
5
- import { getSettings } from '../../../../utils.js';
6
-
7
- export default async function getUserProperties({
8
- pg = {}, params = {}, query = {}, session = {},
9
- }) {
10
- const { uid } = session.passport?.user || {};
11
- if (!uid) {
12
- return { message: 'access restreicted', status: 403 };
13
- }
14
-
15
- if (!pg.pk?.[table]) {
16
- return { message: 'table not found', status: 404 };
17
- }
18
-
19
- const redis = getRedis();
20
- const keyCache = `${pg.options?.database}:settings:${params?.key || 'all'}:${query?.json ? 'json' : 'plain'}:user`;
21
-
22
- const cache = await redis.get(keyCache);
23
- if (cache) return JSON.parse(cache);
24
-
25
- try {
26
- const res = await getSettings({
27
- pg, key: params.key, json: query.json, redis, table, uid,
28
- });
29
- return { message: res, status: 200 };
30
- }
31
- catch (err) {
32
- return { error: err.toString(), status: 500 };
33
- }
34
- }
1
+ const table = 'admin.user_properties';
2
+
3
+ import { getRedis } from '@opengis/fastify-table/utils.js';
4
+
5
+ import { getSettings } from '../../../../utils.js';
6
+
7
+ export default async function getUserProperties({
8
+ pg = {}, params = {}, query = {}, session = {},
9
+ }) {
10
+ const { uid } = session.passport?.user || {};
11
+ if (!uid) {
12
+ return { message: 'access restreicted', status: 403 };
13
+ }
14
+
15
+ if (!pg.pk?.[table]) {
16
+ return { message: 'table not found', status: 404 };
17
+ }
18
+
19
+ const redis = getRedis();
20
+ const keyCache = `${pg.options?.database}:settings:${params?.key || 'all'}:${query?.json ? 'json' : 'plain'}:user`;
21
+
22
+ const cache = await redis.get(keyCache);
23
+ if (cache) return JSON.parse(cache);
24
+
25
+ try {
26
+ const res = await getSettings({
27
+ pg, key: params.key, json: query.json, redis, table, uid,
28
+ });
29
+ return { message: res, status: 200 };
30
+ }
31
+ catch (err) {
32
+ return { error: err.toString(), status: 500 };
33
+ }
34
+ }
@@ -1,30 +1,30 @@
1
- const table = 'admin.user_properties';
2
-
3
- import { setSettings } from '../../../../utils.js';
4
-
5
- export default async function postUserProperties({
6
- pg, session = {}, body = {},
7
- }) {
8
- const { uid } = session.passport?.user || {};
9
-
10
- if (!uid) {
11
- return { message: 'access restricted', status: 403 };
12
- }
13
-
14
- const { key, val } = body;
15
-
16
- if ((!key || !val) && !Object.keys(body).length) {
17
- return { message: 'not enough params', status: 400 };
18
- }
19
-
20
- if (!pg?.pk?.[table]) {
21
- return { message: 'table not found', status: 404 };
22
- }
23
-
24
- const res = await setSettings({
25
- pg, key, val, body, table, uid,
26
- });
27
- if (res?.error) return res;
28
-
29
- return { message: res, status: 200 };
30
- }
1
+ const table = 'admin.user_properties';
2
+
3
+ import { setSettings } from '../../../../utils.js';
4
+
5
+ export default async function postUserProperties({
6
+ pg, session = {}, body = {},
7
+ }) {
8
+ const { uid } = session.passport?.user || {};
9
+
10
+ if (!uid) {
11
+ return { message: 'access restricted', status: 403 };
12
+ }
13
+
14
+ const { key, val } = body;
15
+
16
+ if ((!key || !val) && !Object.keys(body).length) {
17
+ return { message: 'not enough params', status: 400 };
18
+ }
19
+
20
+ if (!pg?.pk?.[table]) {
21
+ return { message: 'table not found', status: 404 };
22
+ }
23
+
24
+ const res = await setSettings({
25
+ pg, key, val, body, table, uid,
26
+ });
27
+ if (res?.error) return res;
28
+
29
+ return { message: res, status: 200 };
30
+ }
@@ -1,56 +1,56 @@
1
- import { getMeta } from '@opengis/fastify-table/utils.js';
2
-
3
- const match = {
4
- property_key: 'key',
5
- property_json: 'json',
6
- property_int: 'int',
7
- property_text: 'text',
8
- };
9
-
10
- function getQuery({
11
- table, columns = [], key, uid,
12
- }) {
13
- const columnList = columns?.filter((el) => match[el?.name]).map((el) => el?.name).map((el) => `${el} as ${match[el]}`);
14
- const sql = `select ${columnList.join(',')} from ${table} where 1=1`;
15
-
16
- if (table === 'admin.user_properties') {
17
- const args = [uid, key].filter((el) => el);
18
- const q = sql + (uid ? ' and uid=$1' : '') + (key ? ` and property_key=$${args.indexOf(key) + 1}` : '');
19
- return { q, args };
20
- }
21
- const args = [key].filter((el) => el);
22
- const q = sql + (key ? ` and property_key=$${args.indexOf(key) + 1}` : '');
23
- return { q, args };
24
- }
25
-
26
- export default async function getSettings({
27
- pg, redis, json, key, table = 'admin.properties', uid,
28
- }) {
29
- const { columns = [] } = await getMeta({ table });
30
-
31
- const { q, args } = getQuery({
32
- table, columns, key, uid,
33
- });
34
-
35
- const { rows } = await pg.query(q, args);
36
- const data = rows?.reduce((acc, curr) => Object.assign(acc, { [curr.key]: curr.json || curr.int || curr.text }), {});
37
-
38
- const jsonData = Object.keys(data || {}).reduce((acc, curr) => {
39
- const [ckey, csubkey] = curr.split('.');
40
- if (!csubkey) return Object.assign(acc, { [curr]: data[curr] });
41
- if (!acc[ckey]) Object.assign(acc, { [ckey]: {} });
42
- Object.assign(acc[ckey], { [csubkey]: data[curr] });
43
- return acc;
44
- }, {});
45
-
46
- // save both
47
- if (redis) {
48
- const keyCacheJSON = `${pg.options?.database}:settings:${key || 'all'}:json:${table}`;
49
- await redis.set(keyCacheJSON, JSON.stringify(jsonData));
50
-
51
- const keyCachePlain = `${pg.options?.database}:settings:${key || 'all'}:plain:${table}`;
52
- await redis.set(keyCachePlain, JSON.stringify(data));
53
- }
54
-
55
- return json ? jsonData : data;
56
- }
1
+ import { getMeta } from '@opengis/fastify-table/utils.js';
2
+
3
+ const match = {
4
+ property_key: 'key',
5
+ property_json: 'json',
6
+ property_int: 'int',
7
+ property_text: 'text',
8
+ };
9
+
10
+ function getQuery({
11
+ table, columns = [], key, uid,
12
+ }) {
13
+ const columnList = columns?.filter((el) => match[el?.name]).map((el) => el?.name).map((el) => `${el} as ${match[el]}`);
14
+ const sql = `select ${columnList.join(',')} from ${table} where 1=1`;
15
+
16
+ if (table === 'admin.user_properties') {
17
+ const args = [uid, key].filter((el) => el);
18
+ const q = sql + (uid ? ' and uid=$1' : '') + (key ? ` and property_key=$${args.indexOf(key) + 1}` : '');
19
+ return { q, args };
20
+ }
21
+ const args = [key].filter((el) => el);
22
+ const q = sql + (key ? ` and property_key=$${args.indexOf(key) + 1}` : '');
23
+ return { q, args };
24
+ }
25
+
26
+ export default async function getSettings({
27
+ pg, redis, json, key, table = 'admin.properties', uid,
28
+ }) {
29
+ const { columns = [] } = await getMeta({ table });
30
+
31
+ const { q, args } = getQuery({
32
+ table, columns, key, uid,
33
+ });
34
+
35
+ const { rows } = await pg.query(q, args);
36
+ const data = rows?.reduce((acc, curr) => Object.assign(acc, { [curr.key]: curr.json || curr.int || curr.text }), {});
37
+
38
+ const jsonData = Object.keys(data || {}).reduce((acc, curr) => {
39
+ const [ckey, csubkey] = curr.split('.');
40
+ if (!csubkey) return Object.assign(acc, { [curr]: data[curr] });
41
+ if (!acc[ckey]) Object.assign(acc, { [ckey]: {} });
42
+ Object.assign(acc[ckey], { [csubkey]: data[curr] });
43
+ return acc;
44
+ }, {});
45
+
46
+ // save both
47
+ if (redis) {
48
+ const keyCacheJSON = `${pg.options?.database}:settings:${key || 'all'}:json:${table}`;
49
+ await redis.set(keyCacheJSON, JSON.stringify(jsonData));
50
+
51
+ const keyCachePlain = `${pg.options?.database}:settings:${key || 'all'}:plain:${table}`;
52
+ await redis.set(keyCachePlain, JSON.stringify(data));
53
+ }
54
+
55
+ return json ? jsonData : data;
56
+ }
@@ -1,44 +1,44 @@
1
- import { getRedis } from '@opengis/fastify-table/utils.js';
2
-
3
- import { getSettings } from '../../../../utils.js';
4
- import dataInsert from './utils/dataInsert.js';
5
-
6
- function checkValueType(val) {
7
- if (val) {
8
- if (typeof val === 'object') {
9
- return 'property_json';
10
- }
11
- if (typeof val === 'number' && (!/\D/.test(val.toString()) && val.toString().length < 10)) {
12
- return 'property_int';
13
- }
14
- }
15
- return 'property_text';
16
- }
17
-
18
- export default async function setSettings({
19
- pg, key, val, body = {}, table = 'admin.properties', uid,
20
- }) {
21
- const body1 = key && val ? { [key]: val } : body;
22
- const keys = Object.keys(body1);
23
- try {
24
- const redis = getRedis();
25
- await pg.query(`delete from ${table} where property_key=any($1)`, [keys]);
26
-
27
- await Promise.all(keys.map(async (el) => {
28
- const columnType = table === 'admin.user_properties' ? 'property_json' : checkValueType(body1[el]);
29
- const data = { property_key: el, [columnType]: body1[el], uid };
30
- const { rows } = await dataInsert({
31
- pg, table, data, uid,
32
- });
33
- return { key: el, rows: { val: body[el], data: rows?.[0] } };
34
- }));
35
-
36
- const res = await getSettings({
37
- pg, redis, table, uid,
38
- });
39
- return res;
40
- }
41
- catch (err) {
42
- return { error: err.toString(), status: 500 };
43
- }
44
- }
1
+ import { getRedis } from '@opengis/fastify-table/utils.js';
2
+
3
+ import { getSettings } from '../../../../utils.js';
4
+ import dataInsert from './utils/dataInsert.js';
5
+
6
+ function checkValueType(val) {
7
+ if (val) {
8
+ if (typeof val === 'object') {
9
+ return 'property_json';
10
+ }
11
+ if (typeof val === 'number' && (!/\D/.test(val.toString()) && val.toString().length < 10)) {
12
+ return 'property_int';
13
+ }
14
+ }
15
+ return 'property_text';
16
+ }
17
+
18
+ export default async function setSettings({
19
+ pg, key, val, body = {}, table = 'admin.properties', uid,
20
+ }) {
21
+ const body1 = key && val ? { [key]: val } : body;
22
+ const keys = Object.keys(body1);
23
+ try {
24
+ const redis = getRedis();
25
+ await pg.query(`delete from ${table} where property_key=any($1)`, [keys]);
26
+
27
+ await Promise.all(keys.map(async (el) => {
28
+ const columnType = table === 'admin.user_properties' ? 'property_json' : checkValueType(body1[el]);
29
+ const data = { property_key: el, [columnType]: body1[el], uid };
30
+ const { rows } = await dataInsert({
31
+ pg, table, data, uid,
32
+ });
33
+ return { key: el, rows: { val: body[el], data: rows?.[0] } };
34
+ }));
35
+
36
+ const res = await getSettings({
37
+ pg, redis, table, uid,
38
+ });
39
+ return res;
40
+ }
41
+ catch (err) {
42
+ return { error: err.toString(), status: 500 };
43
+ }
44
+ }
@@ -1,26 +1,26 @@
1
- import { getMeta, getPG } from '@opengis/fastify-table/utils.js';
2
-
3
- export default async function dataInsert({
4
- table, data, pg: pg1,
5
- }) {
6
- const pg = pg1 || getPG({ name: 'client' });
7
- if (!data) return null;
8
- const { columns } = await getMeta(table);
9
- if (!columns) return null;
10
-
11
- const names = columns.map((el) => el.name);
12
- const filterData = Object.keys(data)
13
- .filter((el) => data[el] && names.includes(el)).map((el) => [el, data[el]]);
14
-
15
- const insertQuery = `insert into ${table}
16
-
17
- ( ${filterData?.map((key) => `"${key[0]}"`).join(',')})
18
-
19
- values (${filterData?.map((key, i) => (key[0] === 'property_json' ? `to_json($${i + 1}::${key[1] && typeof key[1] === 'object' ? 'json' : 'text'})` : `$${i + 1}`)).join(',')})
20
-
21
- returning *`;
22
-
23
- const res = await pg.query(insertQuery, [...filterData.map((el) => (typeof el[1] === 'object' && (!Array.isArray(el[1]) || typeof el[1]?.[0] === 'object') ? JSON.stringify(el[1]) : el[1]))]) || {};
24
-
25
- return res;
26
- }
1
+ import { getMeta, getPG } from '@opengis/fastify-table/utils.js';
2
+
3
+ export default async function dataInsert({
4
+ table, data, pg: pg1,
5
+ }) {
6
+ const pg = pg1 || getPG({ name: 'client' });
7
+ if (!data) return null;
8
+ const { columns } = await getMeta(table);
9
+ if (!columns) return null;
10
+
11
+ const names = columns.map((el) => el.name);
12
+ const filterData = Object.keys(data)
13
+ .filter((el) => data[el] && names.includes(el)).map((el) => [el, data[el]]);
14
+
15
+ const insertQuery = `insert into ${table}
16
+
17
+ ( ${filterData?.map((key) => `"${key[0]}"`).join(',')})
18
+
19
+ values (${filterData?.map((key, i) => (key[0] === 'property_json' ? `to_json($${i + 1}::${key[1] && typeof key[1] === 'object' ? 'json' : 'text'})` : `$${i + 1}`)).join(',')})
20
+
21
+ returning *`;
22
+
23
+ const res = await pg.query(insertQuery, [...filterData.map((el) => (typeof el[1] === 'object' && (!Array.isArray(el[1]) || typeof el[1]?.[0] === 'object') ? JSON.stringify(el[1]) : el[1]))]) || {};
24
+
25
+ return res;
26
+ }