@opengis/gis 0.2.120 → 0.2.122
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 +148 -148
- package/dist/{CardIcon-Dx_myDwM.js → CardIcon-Bu_mm6QX.js} +1 -1
- package/dist/{EntityCreatePage-Ch8NU_Yw.js → EntityCreatePage-Da8XgBKU.js} +14 -14
- package/dist/{EntityEditPage-CRRcW7FL.js → EntityEditPage-QktKEAxz.js} +27 -27
- package/dist/{EntityTablePage-DY9v1aWL.js → EntityTablePage-BQKMFYxV.js} +26 -26
- package/dist/{ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-DgQHLSak.js → ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-CF1EEob3.js} +1 -1
- package/dist/{HeaderActions.vue_vue_type_script_setup_true_lang-BQ32ioLC.js → HeaderActions.vue_vue_type_script_setup_true_lang-B2ErIdAR.js} +30 -30
- package/dist/{MapSettings-CaGPr5uG.js → MapSettings-eE5rNSLf.js} +33 -33
- package/dist/{RastersTablePage-CJyO2DoI.js → RastersTablePage-B_vF9yl7.js} +29 -29
- package/dist/{cartocss-Bhat1m61.js → cartocss-DcepkzNt.js} +12 -12
- package/dist/{import-utils-BxeYqcn7.js → import-utils-CDIgsIUf.js} +33 -33
- package/dist/{index-Ba6SE4TN.js → index-CActL7Mw.js} +64 -64
- package/dist/index.css +1 -1
- package/dist/index.js +1 -1
- package/dist/index.umd.cjs +12 -12
- package/dist/{raster-Cbs1xR5Y.js → raster-BsBJMgM3.js} +101 -101
- package/dist/{register-D0AsH83v.js → register-BSlpAeRe.js} +8 -8
- package/dist/{service-C4nt_DBO.js → service-CbPCldfY.js} +11 -11
- package/dist/{vs-datatable-QG5b0CCL.js → vs-datatable-RkRQEa10.js} +28 -28
- package/module/cls.json +6 -6
- package/module/gis/card/gis.metadata.table/index.yml +22 -22
- package/module/gis/card/gis.metadata.table/main_info.hbs +20 -20
- package/module/gis/card/gis.metadata.table/metadata_info.hbs +27 -27
- package/module/gis/card/gis.metadata.table/other.hbs +25 -25
- package/module/gis/card/gis.rasters.table/index.yml +11 -11
- package/module/gis/card/gis.rasters.table/main_info.hbs +27 -27
- package/module/gis/card/gis.registers.table/cls.hbs +36 -36
- package/module/gis/card/gis.registers.table/columns.hbs +89 -89
- package/module/gis/card/gis.registers.table/filters.hbs +80 -80
- package/module/gis/card/gis.registers.table/index.yml +23 -23
- package/module/gis/card/gis.registers.table/main_info.hbs +35 -35
- package/module/gis/card/gis.registers.table/source.hbs +45 -45
- package/module/gis/card/gis.services.table/attributes.hbs +91 -91
- package/module/gis/card/gis.services.table/filters.hbs +83 -83
- package/module/gis/card/gis.services.table/index.yml +25 -25
- package/module/gis/card/gis.services.table/main_info.hbs +27 -27
- package/module/gis/card/gis.services.table/source.hbs +25 -25
- package/module/gis/cls/bool.yes_no.json +12 -12
- package/module/gis/cls/encoding.json +14 -14
- package/module/gis/cls/geom_type.json +14 -14
- package/module/gis/cls/gis.column_type.json +34 -34
- package/module/gis/cls/gis.column_view_type.json +26 -26
- package/module/gis/cls/gis.filter_type.json +22 -22
- package/module/gis/cls/language.json +10 -10
- package/module/gis/cls/meta.service_type.json +42 -42
- package/module/gis/cls/ogc.service.json +21 -21
- package/module/gis/cls/service_type.json +42 -42
- package/module/gis/cls/source_type.json +10 -10
- package/module/gis/cls/standarts.json +6 -6
- package/module/gis/cls/topic_category.json +106 -106
- package/module/gis/cls/update_frequency.json +29 -29
- package/module/gis/cls/view.json +21 -21
- package/module/gis/form/feedback.answer.form.json +10 -10
- package/module/gis/form/gis.cartocss.form.json +54 -54
- package/module/gis/form/gis.group_list.form.json +17 -17
- package/module/gis/form/gis.maps.form.json +61 -61
- package/module/gis/form/gis.metadata.form.json +240 -240
- package/module/gis/form/gis.metadata_new.form.json +195 -195
- package/module/gis/form/gis.ogc_service.form.json +51 -51
- package/module/gis/form/gis.rasters.form.json +76 -76
- package/module/gis/form/gis.registers.form.json +124 -124
- package/module/gis/form/gis.registers_column.form.json +84 -84
- package/module/gis/form/gis.registers_filter.form.json +65 -65
- package/module/gis/form/gis.services.form.json +111 -111
- package/module/gis/form/gis.services_attributes.form.json +75 -75
- package/module/gis/form/gis.services_filter.form.json +65 -65
- package/module/gis/menu.json +43 -43
- package/module/gis/select/admin.cls.name.sql +2 -2
- package/module/gis/select/layer_list.sql +7 -7
- package/module/gis/select/layer_list_text.sql +7 -7
- package/module/gis/select/pg.column_name.geometry.sql +12 -12
- package/module/gis/select/pg.columns.parent.sql +6 -6
- package/module/gis/select/pg.table_name.sql +17 -17
- package/module/gis/select/service_id.sql +1 -1
- package/module/gis/table/gis.cartocss.table.json +74 -74
- package/module/gis/table/gis.group_list.table.json +58 -58
- package/module/gis/table/gis.maps.table.json +110 -110
- package/module/gis/table/gis.metadata.table.json +70 -70
- package/module/gis/table/gis.metadata_new.table.json +137 -137
- package/module/gis/table/gis.ogc_service.table.json +100 -100
- package/module/gis/table/gis.rasters.table.json +101 -101
- package/module/gis/table/gis.registers.table.json +143 -143
- package/module/gis/table/gis.services.table.json +120 -120
- package/module/gis/table/site.gis.registers.table.json +88 -88
- package/module/gis/table/site.gis.services.table.json +106 -106
- package/module/gis/templates/ISO19136_2017_gml_template.xml +330 -330
- package/module/gis/tokens.yml +5 -5
- package/module/permissions/form/permissions.users.form.json +151 -151
- package/module/permissions/table/gis.permissions.table.json +97 -97
- package/module/test/cls/bp_build_type.json +37 -37
- package/module/test/cls/ts.temp_status.json +18 -18
- package/module/test/cls/ts.temp_structure.ts_class.json +49 -49
- package/module/test/cls/ts.temp_type.json +9 -9
- package/module/test/layer/bp.json +59 -59
- package/module/test/layer/bp1.yml +33 -33
- package/module/test/layer/individual.yml +53 -53
- package/module/test/layer/ts.linking_passport.yml +55 -55
- package/module/test/layer/ts.temp_structure.yml +50 -50
- package/module/test/map/addr.yml +21 -21
- package/module/test/map/bp_myo.json +43 -43
- package/module/test/map/bpf.json +43 -43
- package/module/test/map/main.json +37 -37
- package/module/test/map/mbd.json +92 -92
- package/module/test/map/ts.json +53 -53
- package/module/test/select/address_id.json +2 -2
- package/module/test/select/address_id.sql +7 -7
- package/module/test/table/data_address.street.table.json +69 -69
- package/module/test/table/data_bp_myo.bp.table.json +122 -122
- package/package.json +75 -75
- package/plugin.js +55 -55
- package/server/migrations/array_intersect.sql +13 -13
- package/server/migrations/cartocss.sql +27 -27
- package/server/migrations/group_list.sql +74 -74
- package/server/migrations/maps.sql +30 -30
- package/server/migrations/metadata.sql +415 -415
- package/server/migrations/ogc.sql +106 -106
- package/server/migrations/rasters.sql +265 -265
- package/server/migrations/services.sql +247 -247
- package/server/migrations/services_users_rel.sql +22 -22
- package/server/migrations/widgets.sql +20 -20
- package/server/plugins/crons.js +21 -21
- package/server/plugins/mapnik/funcs/checkRasterFile.js +109 -109
- package/server/plugins/mapnik/funcs/mapnik.js +146 -146
- package/server/plugins/mapnik/funcs/rootFolder.mjs +8 -8
- package/server/plugins/mapnik/map.proto +234 -234
- package/server/plugins/vite.js +74 -74
- package/server/routes/gis/cartocss/add.cartocss.js +42 -42
- package/server/routes/gis/cartocss/get.cartocss.js +50 -50
- package/server/routes/gis/checkXML.js +118 -118
- package/server/routes/gis/dashboard.js +29 -29
- package/server/routes/gis/index.mjs +87 -87
- package/server/routes/gis/metadata/editMetadata.js +34 -34
- package/server/routes/gis/metadata/metadataXML.js +13 -13
- package/server/routes/gis/ogc/map.info.point.js +124 -124
- package/server/routes/gis/registers/add.registry.js +35 -35
- package/server/routes/gis/registers/del.registry.js +14 -14
- package/server/routes/gis/registers/funcs/classifiers.js +100 -100
- package/server/routes/gis/registers/funcs/columns.js +4 -4
- package/server/routes/gis/registers/funcs/content.type.js +9 -9
- package/server/routes/gis/registers/funcs/get.info.js +89 -89
- package/server/routes/gis/registers/funcs/handleRegistryRequest.js +146 -146
- package/server/routes/gis/registers/gis.export.js +153 -153
- package/server/routes/gis/registers/gis.registry.js +64 -64
- package/server/routes/gis/registers/gis.registry.list.js +59 -59
- package/server/routes/gis/registers/insert.columns.js +107 -107
- package/server/routes/gis/registers/insert.filters.js +110 -110
- package/server/routes/gis/registers/map.registry.js +79 -79
- package/server/routes/gis/services/add.service.js +64 -64
- package/server/routes/gis/services/del.service.js +12 -12
- package/server/routes/gis/services/get.layer.geom.js +27 -27
- package/server/routes/gis/services/get.services.col.js +33 -33
- package/server/routes/gis/services/get.services.js +84 -84
- package/server/routes/gis/services/legend.auto.js +77 -77
- package/server/routes/map/controllers/clearTiles.js +34 -34
- package/server/routes/map/controllers/geojson.js +187 -187
- package/server/routes/map/controllers/jsonData.js +205 -205
- package/server/routes/map/controllers/layerList.js +102 -102
- package/server/routes/map/controllers/map.js +123 -123
- package/server/routes/map/controllers/mapCatalog.js +72 -72
- package/server/routes/map/controllers/mapCatalogAttribute.js +55 -55
- package/server/routes/map/controllers/mapFeatures.js +128 -128
- package/server/routes/map/controllers/mapFormat.js +222 -222
- package/server/routes/map/controllers/mapTiles.js +152 -152
- package/server/routes/map/controllers/maps.js +15 -15
- package/server/routes/map/controllers/marker_icon.js +43 -43
- package/server/routes/map/controllers/vtile.js +172 -172
- package/server/routes/map/index.mjs +169 -169
- package/server/routes/map/maps/add.map.js +43 -43
- package/server/routes/map/maps/del.map.js +18 -18
- package/server/routes/map/maps/get.map.js +112 -112
- package/server/routes/map/vtile1.js +179 -179
- package/server/routes/map/widgets/add.widget.js +38 -38
- package/server/routes/map/widgets/del.widget.js +22 -22
- package/server/routes/map/widgets/get.widget.js +40 -40
- package/server/routes/mapnik/controllers/clearTiles.js +106 -106
- package/server/routes/mapnik/controllers/createXml.js +67 -67
- package/server/routes/mapnik/controllers/createXmlMulti.js +76 -76
- package/server/routes/mapnik/controllers/fileSearch.js +38 -38
- package/server/routes/mapnik/controllers/fileStat.js +28 -28
- package/server/routes/mapnik/controllers/mapnikLogger.js +29 -29
- package/server/routes/mapnik/controllers/mapnikStat.js +20 -20
- package/server/routes/mapnik/controllers/rasterInfo.js +54 -54
- package/server/routes/mapnik/controllers/readDir.js +22 -22
- package/server/routes/mapnik/controllers/rtile.js +150 -150
- package/server/routes/mapnik/controllers/uploadRaster.js +157 -157
- package/server/routes/mapnik/functions/cartoBounds.js +28 -28
- package/server/routes/mapnik/functions/uploadXML.js +110 -110
- package/server/routes/mapnik/index.js +27 -27
- package/server/routes/permissions/controllers/catalog.permissions.edit.js +22 -22
- package/server/routes/permissions/controllers/catalog.permissions.js +7 -7
- package/server/routes/permissions/controllers/gis.catalog.js +80 -80
- package/server/routes/permissions/controllers/utils/get.permissions.js +59 -59
- package/server/routes/permissions/index.mjs +18 -18
- package/server/routes/root.mjs +3 -3
- package/utils.js +13 -13
|
@@ -1,109 +1,109 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
|
|
3
|
-
import { config, eventStream } from '@opengis/fastify-table/utils.js';
|
|
4
|
-
|
|
5
|
-
import mapnik from "./mapnik.js";
|
|
6
|
-
|
|
7
|
-
const {
|
|
8
|
-
GetRasterStatus, CreateXML, RenderTile, GetRasterInfo,
|
|
9
|
-
} = mapnik();
|
|
10
|
-
|
|
11
|
-
function sequence(arr, fn) {
|
|
12
|
-
const obj = {};
|
|
13
|
-
return arr.reduce(
|
|
14
|
-
(promise, item, idx) => promise.then(() => fn({
|
|
15
|
-
...item, idx,
|
|
16
|
-
})).then(r => Object.assign(obj, r)),
|
|
17
|
-
Promise.resolve(),
|
|
18
|
-
).then(() => obj);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
const unsafe = true;
|
|
22
|
-
|
|
23
|
-
export default async function checkRasterFile({ rows, reply, nocache }) {
|
|
24
|
-
const callback = reply ? eventStream(reply) : () => { };
|
|
25
|
-
|
|
26
|
-
let
|
|
27
|
-
createdCount = 0,
|
|
28
|
-
existsCount = 0,
|
|
29
|
-
fileNotFoundCount = 0,
|
|
30
|
-
xmlErrorCount = 0,
|
|
31
|
-
renderErrorCount = 0,
|
|
32
|
-
rasterInfoErrorCount = 0;
|
|
33
|
-
|
|
34
|
-
const result = await sequence((rows || []), async ({
|
|
35
|
-
relpath, srid, idx,
|
|
36
|
-
}) => {
|
|
37
|
-
callback(`${idx + 1}/${rows.length} (${relpath})`);
|
|
38
|
-
const relpath1 = [config.mapnik?.folder, 'raster', relpath].filter(Boolean).join('/');
|
|
39
|
-
|
|
40
|
-
// check raster upload status, skip for directories
|
|
41
|
-
const uploadStatus = !path.extname(relpath) ? {} : await GetRasterStatus({ path: relpath1 });
|
|
42
|
-
|
|
43
|
-
if (uploadStatus.exists === false) {
|
|
44
|
-
fileNotFoundCount += 1;
|
|
45
|
-
callback(`file not found: ${relpath1} `);
|
|
46
|
-
return null;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
// create at xml/:id with name only, always - by path
|
|
50
|
-
const resp = await CreateXML({ path: relpath1, srid, nocache }, (msg) => {
|
|
51
|
-
if (typeof msg === 'string' && msg === 'XML creation complete') {
|
|
52
|
-
createdCount += 1;
|
|
53
|
-
}
|
|
54
|
-
if (typeof msg === 'string' && msg.startsWith('XML already exists')) {
|
|
55
|
-
existsCount += 1;
|
|
56
|
-
}
|
|
57
|
-
callback(msg);
|
|
58
|
-
}, unsafe).catch(err => ({ error: err }));
|
|
59
|
-
|
|
60
|
-
if (resp.error?.message && resp.error.message.startsWith('5 NOT_FOUND')) {
|
|
61
|
-
fileNotFoundCount += 1;
|
|
62
|
-
callback(`directory not found: ${relpath1} `);
|
|
63
|
-
return null;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (resp.error) {
|
|
67
|
-
xmlErrorCount += 1;
|
|
68
|
-
callback(`create xml error: ${resp.error.toString()} (${relpath1})`);
|
|
69
|
-
return null;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
const data = await RenderTile({
|
|
73
|
-
path: relpath1,
|
|
74
|
-
width: 256,
|
|
75
|
-
bbox: [3713463.7081504324, 6088362.176970857, 3713616.5822070027, 6088515.051027427], // /:id/18/155363/91245.png
|
|
76
|
-
ttl: '0',
|
|
77
|
-
}).catch(err => ({ err: err.toString() }));
|
|
78
|
-
|
|
79
|
-
if (data.err) {
|
|
80
|
-
renderErrorCount += 1;
|
|
81
|
-
callback(`render error: ${data.err} (${relpath1})`);
|
|
82
|
-
return null;
|
|
83
|
-
}
|
|
84
|
-
callback(`render ok: ${relpath1} `);
|
|
85
|
-
|
|
86
|
-
const { data: rasterInfo, err } = await GetRasterInfo({
|
|
87
|
-
path: relpath1,
|
|
88
|
-
ttl: '0',
|
|
89
|
-
}).catch(e => ({ err: e }));
|
|
90
|
-
|
|
91
|
-
if (err) {
|
|
92
|
-
rasterInfoErrorCount += 1;
|
|
93
|
-
callback(`raster info error: ${err} (${relpath1})`);
|
|
94
|
-
return null;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
return { [relpath1]: rasterInfo };
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
callback(`${existsCount} - xml exists`);
|
|
101
|
-
callback(`${createdCount} - xml created`);
|
|
102
|
-
callback(`${fileNotFoundCount} - file not found`);
|
|
103
|
-
callback(`${xmlErrorCount} - xml errors`);
|
|
104
|
-
callback(`${renderErrorCount} - render errors`);
|
|
105
|
-
callback(`${rasterInfoErrorCount} - raster info errors`);
|
|
106
|
-
|
|
107
|
-
callback('finish', 1);
|
|
108
|
-
return result;
|
|
109
|
-
}
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
|
|
3
|
+
import { config, eventStream } from '@opengis/fastify-table/utils.js';
|
|
4
|
+
|
|
5
|
+
import mapnik from "./mapnik.js";
|
|
6
|
+
|
|
7
|
+
const {
|
|
8
|
+
GetRasterStatus, CreateXML, RenderTile, GetRasterInfo,
|
|
9
|
+
} = mapnik();
|
|
10
|
+
|
|
11
|
+
function sequence(arr, fn) {
|
|
12
|
+
const obj = {};
|
|
13
|
+
return arr.reduce(
|
|
14
|
+
(promise, item, idx) => promise.then(() => fn({
|
|
15
|
+
...item, idx,
|
|
16
|
+
})).then(r => Object.assign(obj, r)),
|
|
17
|
+
Promise.resolve(),
|
|
18
|
+
).then(() => obj);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const unsafe = true;
|
|
22
|
+
|
|
23
|
+
export default async function checkRasterFile({ rows, reply, nocache }) {
|
|
24
|
+
const callback = reply ? eventStream(reply) : () => { };
|
|
25
|
+
|
|
26
|
+
let
|
|
27
|
+
createdCount = 0,
|
|
28
|
+
existsCount = 0,
|
|
29
|
+
fileNotFoundCount = 0,
|
|
30
|
+
xmlErrorCount = 0,
|
|
31
|
+
renderErrorCount = 0,
|
|
32
|
+
rasterInfoErrorCount = 0;
|
|
33
|
+
|
|
34
|
+
const result = await sequence((rows || []), async ({
|
|
35
|
+
relpath, srid, idx,
|
|
36
|
+
}) => {
|
|
37
|
+
callback(`${idx + 1}/${rows.length} (${relpath})`);
|
|
38
|
+
const relpath1 = [config.mapnik?.folder, 'raster', relpath].filter(Boolean).join('/');
|
|
39
|
+
|
|
40
|
+
// check raster upload status, skip for directories
|
|
41
|
+
const uploadStatus = !path.extname(relpath) ? {} : await GetRasterStatus({ path: relpath1 });
|
|
42
|
+
|
|
43
|
+
if (uploadStatus.exists === false) {
|
|
44
|
+
fileNotFoundCount += 1;
|
|
45
|
+
callback(`file not found: ${relpath1} `);
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// create at xml/:id with name only, always - by path
|
|
50
|
+
const resp = await CreateXML({ path: relpath1, srid, nocache }, (msg) => {
|
|
51
|
+
if (typeof msg === 'string' && msg === 'XML creation complete') {
|
|
52
|
+
createdCount += 1;
|
|
53
|
+
}
|
|
54
|
+
if (typeof msg === 'string' && msg.startsWith('XML already exists')) {
|
|
55
|
+
existsCount += 1;
|
|
56
|
+
}
|
|
57
|
+
callback(msg);
|
|
58
|
+
}, unsafe).catch(err => ({ error: err }));
|
|
59
|
+
|
|
60
|
+
if (resp.error?.message && resp.error.message.startsWith('5 NOT_FOUND')) {
|
|
61
|
+
fileNotFoundCount += 1;
|
|
62
|
+
callback(`directory not found: ${relpath1} `);
|
|
63
|
+
return null;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
if (resp.error) {
|
|
67
|
+
xmlErrorCount += 1;
|
|
68
|
+
callback(`create xml error: ${resp.error.toString()} (${relpath1})`);
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const data = await RenderTile({
|
|
73
|
+
path: relpath1,
|
|
74
|
+
width: 256,
|
|
75
|
+
bbox: [3713463.7081504324, 6088362.176970857, 3713616.5822070027, 6088515.051027427], // /:id/18/155363/91245.png
|
|
76
|
+
ttl: '0',
|
|
77
|
+
}).catch(err => ({ err: err.toString() }));
|
|
78
|
+
|
|
79
|
+
if (data.err) {
|
|
80
|
+
renderErrorCount += 1;
|
|
81
|
+
callback(`render error: ${data.err} (${relpath1})`);
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
84
|
+
callback(`render ok: ${relpath1} `);
|
|
85
|
+
|
|
86
|
+
const { data: rasterInfo, err } = await GetRasterInfo({
|
|
87
|
+
path: relpath1,
|
|
88
|
+
ttl: '0',
|
|
89
|
+
}).catch(e => ({ err: e }));
|
|
90
|
+
|
|
91
|
+
if (err) {
|
|
92
|
+
rasterInfoErrorCount += 1;
|
|
93
|
+
callback(`raster info error: ${err} (${relpath1})`);
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
return { [relpath1]: rasterInfo };
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
callback(`${existsCount} - xml exists`);
|
|
101
|
+
callback(`${createdCount} - xml created`);
|
|
102
|
+
callback(`${fileNotFoundCount} - file not found`);
|
|
103
|
+
callback(`${xmlErrorCount} - xml errors`);
|
|
104
|
+
callback(`${renderErrorCount} - render errors`);
|
|
105
|
+
callback(`${rasterInfoErrorCount} - raster info errors`);
|
|
106
|
+
|
|
107
|
+
callback('finish', 1);
|
|
108
|
+
return result;
|
|
109
|
+
}
|
|
@@ -1,146 +1,146 @@
|
|
|
1
|
-
import path from "node:path";
|
|
2
|
-
import { fileURLToPath } from 'node:url';
|
|
3
|
-
|
|
4
|
-
import grpc from "@grpc/grpc-js";
|
|
5
|
-
import protoLoader from "@grpc/proto-loader";
|
|
6
|
-
|
|
7
|
-
import { config } from "@opengis/fastify-table/utils.js";
|
|
8
|
-
|
|
9
|
-
const filepath = fileURLToPath(import.meta.url);
|
|
10
|
-
const dirname = path.dirname(filepath);
|
|
11
|
-
|
|
12
|
-
const PROTO_PATH = path.join(dirname, '../', 'map.proto');
|
|
13
|
-
// const PROTO_PATH = config.mapServerAddress && config.mapServerAddress.startsWith('127.0.0.1') ? path.join(dirname, '../../../../../../service/mapnikp/map.proto') : path.join(dirname, '../', 'map.proto');
|
|
14
|
-
|
|
15
|
-
const { mapnik } = config;
|
|
16
|
-
|
|
17
|
-
if (!mapnik?.server) {
|
|
18
|
-
throw new Error("Mapnik server address is not defined in the configuration.");
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
const proto = grpc.loadPackageDefinition(
|
|
22
|
-
protoLoader.loadSync(
|
|
23
|
-
PROTO_PATH,
|
|
24
|
-
{
|
|
25
|
-
keepCase: true,
|
|
26
|
-
longs: String,
|
|
27
|
-
enums: String,
|
|
28
|
-
defaults: true,
|
|
29
|
-
oneofs: true,
|
|
30
|
-
},
|
|
31
|
-
),
|
|
32
|
-
);
|
|
33
|
-
|
|
34
|
-
const mapClient = new proto.map.MapService(
|
|
35
|
-
mapnik.server,
|
|
36
|
-
grpc.credentials.createInsecure(),
|
|
37
|
-
);
|
|
38
|
-
|
|
39
|
-
mapClient.waitForReady(Date.now() + 5000, (err) => {
|
|
40
|
-
if (err) {
|
|
41
|
-
config.ready.mapnik = false;
|
|
42
|
-
console.error("Mapnik client connection timeout or failure:", err);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
config.ready.mapnik = true;
|
|
46
|
-
console.log("Mapnik client connected successfully.");
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
/*
|
|
51
|
-
[
|
|
52
|
-
'ClearTile',
|
|
53
|
-
'CreateXML',
|
|
54
|
-
'GetLogs',
|
|
55
|
-
'GetRender',
|
|
56
|
-
'GetStat',
|
|
57
|
-
'ReadDir',
|
|
58
|
-
'RenderTile',
|
|
59
|
-
'UploadRaster',
|
|
60
|
-
'UploadXML',
|
|
61
|
-
'GetRasterStatus', // for resumable upload support
|
|
62
|
-
]
|
|
63
|
-
*/
|
|
64
|
-
|
|
65
|
-
function formatObject(obj1) {
|
|
66
|
-
return Object.keys(obj1 || {}).reduce((acc1, key) => {
|
|
67
|
-
const { kind } = obj1[key];
|
|
68
|
-
const value = obj1[key][kind];
|
|
69
|
-
if (key === 'timestamp') {
|
|
70
|
-
Object.assign(acc1, { [key]: new Date(value * 1000).toISOString() });
|
|
71
|
-
}
|
|
72
|
-
else if (kind === 'structValue') {
|
|
73
|
-
Object.assign(acc1, { [key]: formatObject(value.fields) });
|
|
74
|
-
}
|
|
75
|
-
else {
|
|
76
|
-
Object.assign(acc1, { [key]: value });
|
|
77
|
-
}
|
|
78
|
-
return acc1;
|
|
79
|
-
}, {});
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
const grpcMethods = Object.getOwnPropertyNames(
|
|
83
|
-
Object.getPrototypeOf(mapClient),
|
|
84
|
-
)
|
|
85
|
-
.filter(key => key.slice(0, 1).toUpperCase() === key.slice(0, 1))
|
|
86
|
-
.reduce((acc, curr) => ({
|
|
87
|
-
...acc,
|
|
88
|
-
[curr]: async (inputData, callback, unsafe) => new Promise((res, rej) => {
|
|
89
|
-
if (curr === "CreateXML" && typeof callback === 'function') {
|
|
90
|
-
const stream = mapClient[curr].call(
|
|
91
|
-
mapClient,
|
|
92
|
-
inputData,
|
|
93
|
-
(err, data) => {
|
|
94
|
-
if (err) {
|
|
95
|
-
return rej(err);
|
|
96
|
-
}
|
|
97
|
-
return res(data);
|
|
98
|
-
},
|
|
99
|
-
);
|
|
100
|
-
stream.on("error", (err) => {
|
|
101
|
-
// unsafe=true prevents from sequence termination etc
|
|
102
|
-
callback(err?.message || err, unsafe ? null : 1);
|
|
103
|
-
rej(err);
|
|
104
|
-
});
|
|
105
|
-
stream.on("data", (resp) => {
|
|
106
|
-
callback(resp?.message || resp?.error || JSON.stringify(resp));
|
|
107
|
-
});
|
|
108
|
-
stream.on("end", () => res('finish'));
|
|
109
|
-
}
|
|
110
|
-
else if (curr === 'GetStat') {
|
|
111
|
-
mapClient[curr].call(
|
|
112
|
-
mapClient,
|
|
113
|
-
inputData,
|
|
114
|
-
(err, data) => {
|
|
115
|
-
if (err) {
|
|
116
|
-
return rej(err || 'invalid response');
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
const { fields } = data?.result || {};
|
|
120
|
-
// google.protobuf.Struct to js object
|
|
121
|
-
const obj = formatObject(fields);
|
|
122
|
-
return res(obj);
|
|
123
|
-
},
|
|
124
|
-
);
|
|
125
|
-
}
|
|
126
|
-
else {
|
|
127
|
-
mapClient[curr].call(
|
|
128
|
-
mapClient,
|
|
129
|
-
inputData,
|
|
130
|
-
(err, data) => {
|
|
131
|
-
if (err) {
|
|
132
|
-
return rej(err);
|
|
133
|
-
}
|
|
134
|
-
return res(data);
|
|
135
|
-
},
|
|
136
|
-
);
|
|
137
|
-
}
|
|
138
|
-
}),
|
|
139
|
-
}), {});
|
|
140
|
-
|
|
141
|
-
const getMapnik = () => ({
|
|
142
|
-
...grpcMethods,
|
|
143
|
-
mapServerAddress: mapnik?.server,
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
export default getMapnik;
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { fileURLToPath } from 'node:url';
|
|
3
|
+
|
|
4
|
+
import grpc from "@grpc/grpc-js";
|
|
5
|
+
import protoLoader from "@grpc/proto-loader";
|
|
6
|
+
|
|
7
|
+
import { config } from "@opengis/fastify-table/utils.js";
|
|
8
|
+
|
|
9
|
+
const filepath = fileURLToPath(import.meta.url);
|
|
10
|
+
const dirname = path.dirname(filepath);
|
|
11
|
+
|
|
12
|
+
const PROTO_PATH = path.join(dirname, '../', 'map.proto');
|
|
13
|
+
// const PROTO_PATH = config.mapServerAddress && config.mapServerAddress.startsWith('127.0.0.1') ? path.join(dirname, '../../../../../../service/mapnikp/map.proto') : path.join(dirname, '../', 'map.proto');
|
|
14
|
+
|
|
15
|
+
const { mapnik } = config;
|
|
16
|
+
|
|
17
|
+
if (!mapnik?.server) {
|
|
18
|
+
throw new Error("Mapnik server address is not defined in the configuration.");
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const proto = grpc.loadPackageDefinition(
|
|
22
|
+
protoLoader.loadSync(
|
|
23
|
+
PROTO_PATH,
|
|
24
|
+
{
|
|
25
|
+
keepCase: true,
|
|
26
|
+
longs: String,
|
|
27
|
+
enums: String,
|
|
28
|
+
defaults: true,
|
|
29
|
+
oneofs: true,
|
|
30
|
+
},
|
|
31
|
+
),
|
|
32
|
+
);
|
|
33
|
+
|
|
34
|
+
const mapClient = new proto.map.MapService(
|
|
35
|
+
mapnik.server,
|
|
36
|
+
grpc.credentials.createInsecure(),
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
mapClient.waitForReady(Date.now() + 5000, (err) => {
|
|
40
|
+
if (err) {
|
|
41
|
+
config.ready.mapnik = false;
|
|
42
|
+
console.error("Mapnik client connection timeout or failure:", err);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
config.ready.mapnik = true;
|
|
46
|
+
console.log("Mapnik client connected successfully.");
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
/*
|
|
51
|
+
[
|
|
52
|
+
'ClearTile',
|
|
53
|
+
'CreateXML',
|
|
54
|
+
'GetLogs',
|
|
55
|
+
'GetRender',
|
|
56
|
+
'GetStat',
|
|
57
|
+
'ReadDir',
|
|
58
|
+
'RenderTile',
|
|
59
|
+
'UploadRaster',
|
|
60
|
+
'UploadXML',
|
|
61
|
+
'GetRasterStatus', // for resumable upload support
|
|
62
|
+
]
|
|
63
|
+
*/
|
|
64
|
+
|
|
65
|
+
function formatObject(obj1) {
|
|
66
|
+
return Object.keys(obj1 || {}).reduce((acc1, key) => {
|
|
67
|
+
const { kind } = obj1[key];
|
|
68
|
+
const value = obj1[key][kind];
|
|
69
|
+
if (key === 'timestamp') {
|
|
70
|
+
Object.assign(acc1, { [key]: new Date(value * 1000).toISOString() });
|
|
71
|
+
}
|
|
72
|
+
else if (kind === 'structValue') {
|
|
73
|
+
Object.assign(acc1, { [key]: formatObject(value.fields) });
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
Object.assign(acc1, { [key]: value });
|
|
77
|
+
}
|
|
78
|
+
return acc1;
|
|
79
|
+
}, {});
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const grpcMethods = Object.getOwnPropertyNames(
|
|
83
|
+
Object.getPrototypeOf(mapClient),
|
|
84
|
+
)
|
|
85
|
+
.filter(key => key.slice(0, 1).toUpperCase() === key.slice(0, 1))
|
|
86
|
+
.reduce((acc, curr) => ({
|
|
87
|
+
...acc,
|
|
88
|
+
[curr]: async (inputData, callback, unsafe) => new Promise((res, rej) => {
|
|
89
|
+
if (curr === "CreateXML" && typeof callback === 'function') {
|
|
90
|
+
const stream = mapClient[curr].call(
|
|
91
|
+
mapClient,
|
|
92
|
+
inputData,
|
|
93
|
+
(err, data) => {
|
|
94
|
+
if (err) {
|
|
95
|
+
return rej(err);
|
|
96
|
+
}
|
|
97
|
+
return res(data);
|
|
98
|
+
},
|
|
99
|
+
);
|
|
100
|
+
stream.on("error", (err) => {
|
|
101
|
+
// unsafe=true prevents from sequence termination etc
|
|
102
|
+
callback(err?.message || err, unsafe ? null : 1);
|
|
103
|
+
rej(err);
|
|
104
|
+
});
|
|
105
|
+
stream.on("data", (resp) => {
|
|
106
|
+
callback(resp?.message || resp?.error || JSON.stringify(resp));
|
|
107
|
+
});
|
|
108
|
+
stream.on("end", () => res('finish'));
|
|
109
|
+
}
|
|
110
|
+
else if (curr === 'GetStat') {
|
|
111
|
+
mapClient[curr].call(
|
|
112
|
+
mapClient,
|
|
113
|
+
inputData,
|
|
114
|
+
(err, data) => {
|
|
115
|
+
if (err) {
|
|
116
|
+
return rej(err || 'invalid response');
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
const { fields } = data?.result || {};
|
|
120
|
+
// google.protobuf.Struct to js object
|
|
121
|
+
const obj = formatObject(fields);
|
|
122
|
+
return res(obj);
|
|
123
|
+
},
|
|
124
|
+
);
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
mapClient[curr].call(
|
|
128
|
+
mapClient,
|
|
129
|
+
inputData,
|
|
130
|
+
(err, data) => {
|
|
131
|
+
if (err) {
|
|
132
|
+
return rej(err);
|
|
133
|
+
}
|
|
134
|
+
return res(data);
|
|
135
|
+
},
|
|
136
|
+
);
|
|
137
|
+
}
|
|
138
|
+
}),
|
|
139
|
+
}), {});
|
|
140
|
+
|
|
141
|
+
const getMapnik = () => ({
|
|
142
|
+
...grpcMethods,
|
|
143
|
+
mapServerAddress: mapnik?.server,
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
export default getMapnik;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
import { existsSync } from 'node:fs';
|
|
3
|
-
|
|
4
|
-
import { config } from '@opengis/fastify-table/utils.js';
|
|
5
|
-
|
|
6
|
-
const root = config.temp || (existsSync('/data/local') ? '/data/local/kamianske' : process.cwd());
|
|
7
|
-
|
|
8
|
-
export default path.join(root, 'log/map').replace(/\\/g, '/');
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { existsSync } from 'node:fs';
|
|
3
|
+
|
|
4
|
+
import { config } from '@opengis/fastify-table/utils.js';
|
|
5
|
+
|
|
6
|
+
const root = config.temp || (existsSync('/data/local') ? '/data/local/kamianske' : process.cwd());
|
|
7
|
+
|
|
8
|
+
export default path.join(root, 'log/map').replace(/\\/g, '/');
|