@opengis/admin 0.1.35 → 0.1.37

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 (104) hide show
  1. package/README.md +29 -29
  2. package/config.js +4 -4
  3. package/dist/{IconSearch-Bl8C0SfP.js → IconSearch-BtomZb8r.js} +1 -1
  4. package/dist/{add-page-BKDaCY6R.js → add-page-B2luTaID.js} +1 -1
  5. package/dist/{admin-interface-DKj7YByU.js → admin-interface-BTkZcKR5.js} +2 -2
  6. package/dist/{admin-view-G0Lme4Ai.js → admin-view--m-d7PyT.js} +3 -3
  7. package/dist/admin.js +1 -1
  8. package/dist/admin.umd.cjs +6 -6
  9. package/dist/{card-page-BElxWM3j.js → card-page-DD80MOw6.js} +21 -21
  10. package/dist/{card-view-CSq2SQcv.js → card-view-BGniLwQl.js} +1 -1
  11. package/dist/{edit-page-ClkVwxLr.js → edit-page-DS2vRs3y.js} +1 -1
  12. package/dist/{import-file-CQXB9LOO.js → import-file-ChmncuMJ.js} +2125 -2127
  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 +13 -13
  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.properties.form.json +15 -15
  32. package/module/settings/form/admin.roles.form.json +19 -19
  33. package/module/settings/form/admin.routes.form.json +25 -25
  34. package/module/settings/form/admin.table_properties.form.json +70 -70
  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 +150 -150
  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 +45 -45
  44. package/module/settings/select/core.roles.json +2 -2
  45. package/module/settings/select/core.user_uid.sql +1 -1
  46. package/module/settings/table/admin.access.table.json +77 -77
  47. package/module/settings/table/admin.properties.table.json +33 -33
  48. package/module/settings/table/admin.roles.table.json +58 -58
  49. package/module/settings/table/admin.routes.table.json +55 -55
  50. package/module/settings/table/admin.table_properties.table.json +81 -81
  51. package/module/settings/table/admin.user_properties.table.json +28 -28
  52. package/module/settings/table/admin.user_roles.table.json +66 -66
  53. package/module/settings/table/admin.users.table.json +119 -119
  54. package/package.json +74 -74
  55. package/plugin.js +101 -102
  56. package/server/helpers/controllers/badge.js +11 -11
  57. package/server/helpers/controllers/hb.js +2 -2
  58. package/server/helpers/controllers/map.js +2 -2
  59. package/server/helpers/controllers/mls.js +2 -2
  60. package/server/helpers/controllers/vue.js +2 -2
  61. package/server/helpers/index.mjs +13 -13
  62. package/server/plugins/docs.js +28 -28
  63. package/server/plugins/hook.js +166 -166
  64. package/server/plugins/vite.js +69 -69
  65. package/server/routes/data/controllers/cardData.js +56 -56
  66. package/server/routes/data/controllers/cardTabData.js +39 -39
  67. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +85 -85
  68. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +142 -142
  69. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  70. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +67 -67
  71. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  72. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  73. package/server/routes/data/controllers/tableData.js +121 -121
  74. package/server/routes/data/controllers/tableDataId.js +27 -27
  75. package/server/routes/data/controllers/tableFilter.js +55 -55
  76. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  77. package/server/routes/data/controllers/utils/getColumns.js +21 -21
  78. package/server/routes/data/index.mjs +12 -12
  79. package/server/routes/menu/controllers/getMenu.js +33 -33
  80. package/server/routes/menu/index.mjs +5 -5
  81. package/server/routes/properties/controllers/admin.properties.get.js +29 -29
  82. package/server/routes/properties/controllers/user.properties.get.js +34 -34
  83. package/server/routes/properties/controllers/user.properties.post.js +30 -30
  84. package/server/routes/properties/funcs/getSettings.js +56 -56
  85. package/server/routes/properties/funcs/setSettings.js +44 -44
  86. package/server/routes/properties/funcs/utils/dataInsert.js +26 -26
  87. package/server/routes/properties/index.mjs +26 -26
  88. package/server/routes/root.mjs +3 -3
  89. package/server/routes/templates/controllers/getTemplate.js +14 -14
  90. package/server/routes/templates/index.mjs +14 -14
  91. package/server/templates/cls/itree.recrzone_category.json +73 -73
  92. package/server/templates/cls/test.json +9 -9
  93. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  94. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  95. package/server/templates/form/cp_building.form.json +32 -32
  96. package/server/templates/form/form-user-pass.json +10 -10
  97. package/server/templates/form/form-user_group.json +39 -39
  98. package/server/templates/form/form-users.json +156 -156
  99. package/server/templates/form/user_group_access.form.json +22 -22
  100. package/server/templates/select/account_id.json +2 -2
  101. package/server/templates/table/gis.dataset.table.json +43 -43
  102. package/server/templates/table/management.user_group.table.json +112 -112
  103. package/server/templates/table/management.users.table.json +126 -126
  104. package/utils.js +8 -8
@@ -1,56 +1,56 @@
1
- import { getTemplate } from "@opengis/fastify-table/utils.js";
2
-
3
- export default async function tableFilter(req) {
4
- const time = Date.now();
5
- const { pg, funcs = {}, params = {}, query = {}, session = {} } = req;
6
- const { uid } = session.passport?.user || {};
7
-
8
- if (!params.name) {
9
- return { message: 'not enouggh params: name', status: 400 };
10
- }
11
-
12
- const loadTable = await getTemplate('table', params.name);
13
-
14
- if (!loadTable) {
15
- return { message: 'table not found', status: 404 };
16
- }
17
-
18
- const { columns } = await funcs.getMeta({ table: loadTable.table });
19
-
20
- const filters = loadTable?.filter_list || loadTable?.filters || loadTable?.filterList || [];
21
- filters.forEach(el => {
22
- Object.assign(el, { id: el.name || el.id, name: el.name || el.id });
23
- });
24
-
25
- // table_properties - user filter
26
- const { rows: properties = [] } = await pg.query(`select property_id, property_key, property_title, property_format, property_data from admin.table_properties where property_type='filter' and property_entity=$1 and uid=$2`, [params.name, uid]);
27
- properties.forEach((row) => filters.push({ id: row.property_key, name: row.property_key, ua: row.property_title, type: row.property_format, data: row.property_data }));
28
-
29
- await Promise.all(filters.filter((el) => el.data).map(async (el) => {
30
-
31
- const cls = await getTemplate(['cls', 'select'], el.data);
32
- const name = el.name || el.id;
33
-
34
- if (!cls?.length || !Array.isArray(cls) || !loadTable.table || !name) return;
35
- const { dataTypeID } = columns.find((item) => item.name === name) || {};
36
- if (!dataTypeID) return;
37
-
38
- const countArr = pg.pgType?.[dataTypeID]?.includes('[]')
39
- ? await pg.queryCache(`select unnest(${name})::text as id,count(*) from ${loadTable.table} group by unnest(${name})`)
40
- : await pg.queryCache(`select ${name}::text as id,count(*) from ${loadTable.table} group by ${name}`);
41
-
42
- const options = countArr.rows.map(cel => {
43
- const data = cls.find(c => c.id === cel.id);
44
- return { ...cel, ...data };
45
- });
46
- Object.assign(el, { options });
47
- }));
48
-
49
- return {
50
- time: Date.now() - time,
51
- list: filters,
52
- custom: loadTable?.filterCustom?.map(el => ({ label: el.label })),
53
- inline: loadTable?.filterInline,
54
- state: loadTable?.filterState?.map(el => ({ label: el.label })),
55
- };
1
+ import { getTemplate } from "@opengis/fastify-table/utils.js";
2
+
3
+ export default async function tableFilter(req) {
4
+ const time = Date.now();
5
+ const { pg, funcs = {}, params = {}, query = {}, session = {} } = req;
6
+ const { uid } = session.passport?.user || {};
7
+
8
+ if (!params.name) {
9
+ return { message: 'not enouggh params: name', status: 400 };
10
+ }
11
+
12
+ const loadTable = await getTemplate('table', params.name);
13
+
14
+ if (!loadTable) {
15
+ return { message: 'table not found', status: 404 };
16
+ }
17
+
18
+ const { columns } = await funcs.getMeta({ table: loadTable.table });
19
+
20
+ const filters = loadTable?.filter_list || loadTable?.filters || loadTable?.filterList || [];
21
+ filters.forEach(el => {
22
+ Object.assign(el, { id: el.name || el.id, name: el.name || el.id });
23
+ });
24
+
25
+ // table_properties - user filter
26
+ const { rows: properties = [] } = await pg.query(`select property_id, property_key, property_title, property_format, property_data from admin.table_properties where property_type='filter' and property_entity=$1 and uid=$2`, [params.name, uid]);
27
+ properties.forEach((row) => filters.push({ id: row.property_key, name: row.property_key, ua: row.property_title, type: row.property_format, data: row.property_data }));
28
+
29
+ await Promise.all(filters.filter((el) => el.data).map(async (el) => {
30
+
31
+ const cls = await getTemplate(['cls', 'select'], el.data);
32
+ const name = el.name || el.id;
33
+
34
+ if (!cls?.length || !Array.isArray(cls) || !loadTable.table || !name) return;
35
+ const { dataTypeID } = columns.find((item) => item.name === name) || {};
36
+ if (!dataTypeID) return;
37
+
38
+ const countArr = pg.pgType?.[dataTypeID]?.includes('[]')
39
+ ? await pg.queryCache(`select unnest(${name})::text as id,count(*) from ${loadTable.table} group by unnest(${name})`)
40
+ : await pg.queryCache(`select ${name}::text as id,count(*) from ${loadTable.table} group by ${name}`);
41
+
42
+ const options = countArr.rows.map(cel => {
43
+ const data = cls.find(c => c.id === cel.id);
44
+ return { ...cel, ...data };
45
+ });
46
+ Object.assign(el, { options });
47
+ }));
48
+
49
+ return {
50
+ time: Date.now() - time,
51
+ list: filters,
52
+ custom: loadTable?.filterCustom?.map(el => ({ label: el.label })),
53
+ inline: loadTable?.filterInline,
54
+ state: loadTable?.filterState?.map(el => ({ label: el.label })),
55
+ };
56
56
  }
@@ -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
+ }