@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.
- package/README.md +29 -29
- package/config.js +4 -4
- package/dist/{add-page-C5g2yN5N.js → add-page-CYAz9FdO.js} +1 -1
- package/dist/{admin-interface-zpEN5ODZ.js → admin-interface-BfY0EPQi.js} +1 -1
- package/dist/{admin-view-DD8_bEjC.js → admin-view-CcyuPjSQ.js} +2 -2
- package/dist/admin.js +1 -1
- package/dist/admin.umd.cjs +5 -5
- package/dist/{card-page-BpMHxKbw.js → card-page-DV3pe4fv.js} +21 -21
- package/dist/{card-view-Ddro0nc4.js → card-view-pwoN8ZHo.js} +1 -1
- package/dist/{edit-page-BL9SogVY.js → edit-page-PNY_GQBC.js} +1 -1
- package/dist/{import-file-DBSDU17c.js → import-file-aqrl_bc7.js} +20 -13
- package/dist/style.css +1 -1
- package/module/settings/card/admin.roles.table/access.hbs +27 -27
- package/module/settings/card/admin.roles.table/general_info.hbs +16 -16
- package/module/settings/card/admin.roles.table/index.yml +14 -14
- package/module/settings/card/admin.roles.table/users.hbs +27 -27
- package/module/settings/card/admin.routes.table/general_info.hbs +40 -40
- package/module/settings/card/admin.routes.table/index.yml +8 -8
- package/module/settings/card/admin.routes.table/users.hbs +33 -33
- package/module/settings/card/admin.users.table/general_info.hbs +25 -25
- package/module/settings/card/admin.users.table/index.yml +12 -12
- package/module/settings/card/admin.users.table/logs.hbs +30 -30
- package/module/settings/card/admin.users.table/user_roles.hbs +24 -24
- package/module/settings/cls/core.actions.json +13 -13
- package/module/settings/cls/core.scope.json +13 -13
- package/module/settings/cls/properties.site_status.json +13 -13
- package/module/settings/cls/properties.widget_status.json +13 -13
- package/module/settings/cls/users.user_type.json +13 -13
- package/module/settings/form/admin.access.form.json +36 -36
- package/module/settings/form/admin.properties.form.json +15 -15
- package/module/settings/form/admin.roles.form.json +19 -19
- package/module/settings/form/admin.routes.form.json +25 -25
- package/module/settings/form/admin.table_properties.form.json +70 -70
- package/module/settings/form/admin.user_properties.form.json +15 -15
- package/module/settings/form/admin.user_roles.form.json +21 -21
- package/module/settings/form/admin.users.form.json +150 -150
- package/module/settings/form/user.user_roles.form.json +13 -13
- package/module/settings/interface/admin.properties.json +4 -4
- package/module/settings/interface/admin.roles.json +4 -4
- package/module/settings/interface/admin.routes.json +4 -4
- package/module/settings/interface/admin.users.json +4 -4
- package/module/settings/menu.json +50 -50
- package/module/settings/select/core.roles.json +2 -2
- package/module/settings/select/core.user_uid.sql +1 -1
- package/module/settings/table/admin.access.table.json +77 -77
- package/module/settings/table/admin.properties.table.json +33 -33
- package/module/settings/table/admin.roles.table.json +58 -58
- package/module/settings/table/admin.routes.table.json +55 -55
- package/module/settings/table/admin.table_properties.table.json +81 -81
- package/module/settings/table/admin.user_properties.table.json +28 -28
- package/module/settings/table/admin.user_roles.table.json +66 -66
- package/module/settings/table/admin.users.table.json +119 -119
- package/package.json +74 -74
- package/plugin.js +101 -101
- package/server/helpers/controllers/badge.js +11 -11
- package/server/helpers/controllers/hb.js +2 -2
- package/server/helpers/controllers/map.js +2 -2
- package/server/helpers/controllers/mls.js +2 -2
- package/server/helpers/controllers/vue.js +2 -2
- package/server/helpers/index.mjs +13 -13
- package/server/plugins/docs.js +28 -28
- package/server/plugins/hook.js +166 -166
- package/server/plugins/vite.js +69 -69
- package/server/routes/data/controllers/cardData.js +56 -56
- package/server/routes/data/controllers/cardTabData.js +39 -39
- package/server/routes/data/controllers/funcs/getFilterSQL/index.js +85 -85
- package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +145 -142
- package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
- package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +67 -67
- package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
- package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
- package/server/routes/data/controllers/tableData.js +121 -121
- package/server/routes/data/controllers/tableDataId.js +27 -27
- package/server/routes/data/controllers/tableFilter.js +55 -55
- package/server/routes/data/controllers/utils/assignTokens.js +30 -30
- package/server/routes/data/controllers/utils/getColumns.js +21 -21
- package/server/routes/data/index.mjs +12 -12
- package/server/routes/menu/controllers/getMenu.js +33 -33
- package/server/routes/menu/index.mjs +5 -5
- package/server/routes/properties/controllers/admin.properties.get.js +29 -29
- package/server/routes/properties/controllers/user.properties.get.js +34 -34
- package/server/routes/properties/controllers/user.properties.post.js +30 -30
- package/server/routes/properties/funcs/getSettings.js +56 -56
- package/server/routes/properties/funcs/setSettings.js +44 -44
- package/server/routes/properties/funcs/utils/dataInsert.js +26 -26
- package/server/routes/properties/index.mjs +26 -26
- package/server/routes/root.mjs +3 -3
- package/server/routes/templates/controllers/getTemplate.js +14 -14
- package/server/routes/templates/index.mjs +14 -14
- package/server/templates/cls/itree.recrzone_category.json +73 -73
- package/server/templates/cls/test.json +9 -9
- package/server/templates/form/admin.user_cls.data.form.json +49 -49
- package/server/templates/form/admin.user_group_rel.form.json +21 -21
- package/server/templates/form/cp_building.form.json +32 -32
- package/server/templates/form/form-user-pass.json +10 -10
- package/server/templates/form/form-user_group.json +39 -39
- package/server/templates/form/form-users.json +156 -156
- package/server/templates/form/user_group_access.form.json +22 -22
- package/server/templates/select/account_id.json +2 -2
- package/server/templates/table/gis.dataset.table.json +43 -43
- package/server/templates/table/management.user_group.table.json +112 -112
- package/server/templates/table/management.users.table.json +126 -126
- 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
|
+
}
|