@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.
- package/README.md +29 -29
- package/config.js +4 -4
- package/dist/{IconSearch-Bl8C0SfP.js → IconSearch-BtomZb8r.js} +1 -1
- package/dist/{add-page-BKDaCY6R.js → add-page-B2luTaID.js} +1 -1
- package/dist/{admin-interface-DKj7YByU.js → admin-interface-BTkZcKR5.js} +2 -2
- package/dist/{admin-view-G0Lme4Ai.js → admin-view--m-d7PyT.js} +3 -3
- package/dist/admin.js +1 -1
- package/dist/admin.umd.cjs +6 -6
- package/dist/{card-page-BElxWM3j.js → card-page-DD80MOw6.js} +21 -21
- package/dist/{card-view-CSq2SQcv.js → card-view-BGniLwQl.js} +1 -1
- package/dist/{edit-page-ClkVwxLr.js → edit-page-DS2vRs3y.js} +1 -1
- package/dist/{import-file-CQXB9LOO.js → import-file-ChmncuMJ.js} +2125 -2127
- 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 +45 -45
- 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 -102
- 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 +142 -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,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
|
+
}
|