@opengis/gis 0.2.50 → 0.2.51
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 +5 -5
- package/dist/index.css +1 -1
- package/dist/index.js +143 -143
- package/dist/index.umd.cjs +3 -3
- 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/gis.cartocss.form.json +45 -45
- 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.ogc_service.form.json +45 -45
- package/module/gis/form/gis.rasters.form.json +103 -103
- 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/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 +62 -62
- package/module/gis/table/gis.group_list.table.json +35 -35
- package/module/gis/table/gis.maps.table.json +108 -108
- package/module/gis/table/gis.metadata.table.json +70 -70
- package/module/gis/table/gis.ogc_service.table.json +98 -98
- package/module/gis/table/gis.rasters.table.json +101 -101
- package/module/gis/table/gis.registers.table.json +144 -144
- package/module/gis/table/gis.services.table.json +121 -121
- 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/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 +36 -36
- package/module/test/map/mbd.json +91 -91
- package/module/test/map/ts.json +52 -52
- 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 +45 -45
- package/server/migrations/maps.sql +30 -30
- package/server/migrations/ogc.sql +106 -106
- package/server/migrations/rasters.sql +263 -263
- package/server/migrations/services.sql +247 -247
- package/server/migrations/widgets.sql +20 -20
- package/server/plugins/crons.js +21 -21
- package/server/plugins/mapnik/funcs/checkRasterFile.js +92 -92
- package/server/plugins/mapnik/funcs/mapnik.js +112 -112
- package/server/plugins/mapnik/funcs/rootFolder.mjs +8 -8
- package/server/plugins/mapnik/map.proto +187 -155
- package/server/plugins/vite.js +74 -74
- package/server/routes/gis/cartocss/add.cartocss.js +152 -152
- package/server/routes/gis/cartocss/get.cartocss.js +12 -12
- package/server/routes/gis/dashboard.js +29 -29
- package/server/routes/gis/index.mjs +73 -73
- 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 +145 -145
- package/server/routes/gis/registers/gis.export.js +148 -148
- 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/geojson.js +187 -187
- package/server/routes/map/controllers/jsonData.js +205 -205
- package/server/routes/map/controllers/layerList.js +60 -60
- 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 +83 -83
- 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 +142 -142
- 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 +80 -80
- package/server/routes/map/vtile1.js +170 -170
- 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/createXml.js +63 -63
- package/server/routes/mapnik/controllers/mapnikLogger.js +14 -0
- package/server/routes/mapnik/controllers/mapnikStat.js +14 -0
- package/server/routes/mapnik/controllers/rasterInfo.js +36 -0
- package/server/routes/mapnik/controllers/rtile.js +96 -106
- package/server/routes/mapnik/controllers/rtileMBD.js +91 -91
- package/server/routes/mapnik/controllers/uploadRaster.js +157 -157
- package/server/routes/mapnik/index.js +19 -16
- package/server/routes/root.mjs +3 -3
- package/utils.js +13 -13
|
@@ -1,92 +1,92 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
|
|
3
|
-
import { eventStream } from '@opengis/fastify-table/utils.js';
|
|
4
|
-
|
|
5
|
-
import mapnik from "./mapnik.js";
|
|
6
|
-
|
|
7
|
-
const { GetRasterStatus, CreateXML, RenderTile } = mapnik();
|
|
8
|
-
|
|
9
|
-
function sequence(arr, fn) {
|
|
10
|
-
return arr.reduce(
|
|
11
|
-
(promise, relpath, idx) => promise.then(() => fn({
|
|
12
|
-
relpath, idx,
|
|
13
|
-
})),
|
|
14
|
-
Promise.resolve(),
|
|
15
|
-
);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
const unsafe = true;
|
|
19
|
-
|
|
20
|
-
export default async function checkRasterFile(arr, reply) {
|
|
21
|
-
const callback = reply ? eventStream(reply) : () => { };
|
|
22
|
-
|
|
23
|
-
let
|
|
24
|
-
createdCount = 0,
|
|
25
|
-
existsCount = 0,
|
|
26
|
-
fileNotFoundCount = 0,
|
|
27
|
-
xmlErrorCount = 0,
|
|
28
|
-
renderErrorCount = 0;
|
|
29
|
-
|
|
30
|
-
await sequence((arr || []), async ({
|
|
31
|
-
relpath, idx,
|
|
32
|
-
}) => {
|
|
33
|
-
callback(`${idx + 1}/${arr.length}`);
|
|
34
|
-
|
|
35
|
-
// check raster upload status, skip for directories
|
|
36
|
-
const uploadStatus = !path.extname(relpath) ? {} : await GetRasterStatus({ path: relpath });
|
|
37
|
-
|
|
38
|
-
if (uploadStatus.exists === false) {
|
|
39
|
-
fileNotFoundCount += 1;
|
|
40
|
-
callback(`file not found: ${relpath} `);
|
|
41
|
-
return null;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
// create at xml/:id with name only, always - by path
|
|
45
|
-
const resp = await CreateXML({ path: relpath }, (msg) => {
|
|
46
|
-
if (typeof msg === 'string' && msg === 'XML creation complete') {
|
|
47
|
-
createdCount += 1;
|
|
48
|
-
}
|
|
49
|
-
if (typeof msg === 'string' && msg.startsWith('XML already exists')) {
|
|
50
|
-
existsCount += 1;
|
|
51
|
-
}
|
|
52
|
-
callback(msg);
|
|
53
|
-
}, unsafe).catch(err => ({ error: err }));
|
|
54
|
-
|
|
55
|
-
if (resp.error?.message && resp.error.message.startsWith('5 NOT_FOUND')) {
|
|
56
|
-
fileNotFoundCount += 1;
|
|
57
|
-
callback(`directory not found: ${relpath} `);
|
|
58
|
-
return null;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
if (resp.error) {
|
|
62
|
-
xmlErrorCount += 1;
|
|
63
|
-
callback(`create xml error: ${resp.error.toString()} (${relpath})`);
|
|
64
|
-
return null;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
const data = await RenderTile({
|
|
68
|
-
path: relpath,
|
|
69
|
-
width: 256,
|
|
70
|
-
height: 256,
|
|
71
|
-
bbox: [3713463.7081504324, 6088362.176970857, 3713616.5822070027, 6088515.051027427], // /:id/18/155363/91245.png
|
|
72
|
-
ttl: '0',
|
|
73
|
-
}).catch(err => ({ err: err.toString() }));
|
|
74
|
-
|
|
75
|
-
if (data.err) {
|
|
76
|
-
renderErrorCount += 1;
|
|
77
|
-
callback(`render error: ${data.err} (${relpath})`);
|
|
78
|
-
return null;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
callback(`render ok: ${relpath} `);
|
|
82
|
-
return null;
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
callback(`${existsCount} - xml exists`);
|
|
86
|
-
callback(`${createdCount} - xml created`);
|
|
87
|
-
callback(`${fileNotFoundCount} - file not found`);
|
|
88
|
-
callback(`${xmlErrorCount} - xml errors`);
|
|
89
|
-
callback(`${renderErrorCount} - render errors`);
|
|
90
|
-
|
|
91
|
-
callback('finish', 1);
|
|
92
|
-
}
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
|
|
3
|
+
import { eventStream } from '@opengis/fastify-table/utils.js';
|
|
4
|
+
|
|
5
|
+
import mapnik from "./mapnik.js";
|
|
6
|
+
|
|
7
|
+
const { GetRasterStatus, CreateXML, RenderTile } = mapnik();
|
|
8
|
+
|
|
9
|
+
function sequence(arr, fn) {
|
|
10
|
+
return arr.reduce(
|
|
11
|
+
(promise, relpath, idx) => promise.then(() => fn({
|
|
12
|
+
relpath, idx,
|
|
13
|
+
})),
|
|
14
|
+
Promise.resolve(),
|
|
15
|
+
);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const unsafe = true;
|
|
19
|
+
|
|
20
|
+
export default async function checkRasterFile(arr, reply) {
|
|
21
|
+
const callback = reply ? eventStream(reply) : () => { };
|
|
22
|
+
|
|
23
|
+
let
|
|
24
|
+
createdCount = 0,
|
|
25
|
+
existsCount = 0,
|
|
26
|
+
fileNotFoundCount = 0,
|
|
27
|
+
xmlErrorCount = 0,
|
|
28
|
+
renderErrorCount = 0;
|
|
29
|
+
|
|
30
|
+
await sequence((arr || []), async ({
|
|
31
|
+
relpath, idx,
|
|
32
|
+
}) => {
|
|
33
|
+
callback(`${idx + 1}/${arr.length}`);
|
|
34
|
+
|
|
35
|
+
// check raster upload status, skip for directories
|
|
36
|
+
const uploadStatus = !path.extname(relpath) ? {} : await GetRasterStatus({ path: relpath });
|
|
37
|
+
|
|
38
|
+
if (uploadStatus.exists === false) {
|
|
39
|
+
fileNotFoundCount += 1;
|
|
40
|
+
callback(`file not found: ${relpath} `);
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// create at xml/:id with name only, always - by path
|
|
45
|
+
const resp = await CreateXML({ path: relpath }, (msg) => {
|
|
46
|
+
if (typeof msg === 'string' && msg === 'XML creation complete') {
|
|
47
|
+
createdCount += 1;
|
|
48
|
+
}
|
|
49
|
+
if (typeof msg === 'string' && msg.startsWith('XML already exists')) {
|
|
50
|
+
existsCount += 1;
|
|
51
|
+
}
|
|
52
|
+
callback(msg);
|
|
53
|
+
}, unsafe).catch(err => ({ error: err }));
|
|
54
|
+
|
|
55
|
+
if (resp.error?.message && resp.error.message.startsWith('5 NOT_FOUND')) {
|
|
56
|
+
fileNotFoundCount += 1;
|
|
57
|
+
callback(`directory not found: ${relpath} `);
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
if (resp.error) {
|
|
62
|
+
xmlErrorCount += 1;
|
|
63
|
+
callback(`create xml error: ${resp.error.toString()} (${relpath})`);
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
const data = await RenderTile({
|
|
68
|
+
path: relpath,
|
|
69
|
+
width: 256,
|
|
70
|
+
height: 256,
|
|
71
|
+
bbox: [3713463.7081504324, 6088362.176970857, 3713616.5822070027, 6088515.051027427], // /:id/18/155363/91245.png
|
|
72
|
+
ttl: '0',
|
|
73
|
+
}).catch(err => ({ err: err.toString() }));
|
|
74
|
+
|
|
75
|
+
if (data.err) {
|
|
76
|
+
renderErrorCount += 1;
|
|
77
|
+
callback(`render error: ${data.err} (${relpath})`);
|
|
78
|
+
return null;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
callback(`render ok: ${relpath} `);
|
|
82
|
+
return null;
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
callback(`${existsCount} - xml exists`);
|
|
86
|
+
callback(`${createdCount} - xml created`);
|
|
87
|
+
callback(`${fileNotFoundCount} - file not found`);
|
|
88
|
+
callback(`${xmlErrorCount} - xml errors`);
|
|
89
|
+
callback(`${renderErrorCount} - render errors`);
|
|
90
|
+
|
|
91
|
+
callback('finish', 1);
|
|
92
|
+
}
|
|
@@ -1,112 +1,112 @@
|
|
|
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 { mapServerAddress, ready } = config;
|
|
16
|
-
|
|
17
|
-
if (!mapServerAddress) {
|
|
18
|
-
throw new Error("Map 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
|
-
mapServerAddress,
|
|
36
|
-
grpc.credentials.createInsecure(),
|
|
37
|
-
);
|
|
38
|
-
|
|
39
|
-
mapClient.waitForReady(Date.now() + 5000, (err) => {
|
|
40
|
-
if (err) {
|
|
41
|
-
ready.mapnik = false;
|
|
42
|
-
console.error("Mapnik client connection timeout or failure:", err);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
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
|
-
const grpcMethods = Object.getOwnPropertyNames(
|
|
65
|
-
Object.getPrototypeOf(mapClient),
|
|
66
|
-
)
|
|
67
|
-
.filter(key => key.slice(0, 1).toUpperCase() === key.slice(0, 1))
|
|
68
|
-
.reduce((acc, curr) => ({
|
|
69
|
-
...acc,
|
|
70
|
-
[curr]: async (inputData, callback, unsafe) => new Promise((res, rej) => {
|
|
71
|
-
if (curr === "CreateXML" && typeof callback === 'function') {
|
|
72
|
-
const stream = mapClient[curr].call(
|
|
73
|
-
mapClient,
|
|
74
|
-
inputData,
|
|
75
|
-
(err, data) => {
|
|
76
|
-
if (err) {
|
|
77
|
-
return rej(err);
|
|
78
|
-
}
|
|
79
|
-
return res(data);
|
|
80
|
-
},
|
|
81
|
-
);
|
|
82
|
-
stream.on("error", (err) => {
|
|
83
|
-
// unsafe=true prevents from sequence termination etc
|
|
84
|
-
callback(err?.message || err, unsafe ? null : 1);
|
|
85
|
-
rej(err);
|
|
86
|
-
});
|
|
87
|
-
stream.on("data", (resp) => {
|
|
88
|
-
callback(resp?.message || resp?.error || JSON.stringify(resp));
|
|
89
|
-
});
|
|
90
|
-
stream.on("end", () => res('finish'));
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
mapClient[curr].call(
|
|
94
|
-
mapClient,
|
|
95
|
-
inputData,
|
|
96
|
-
(err, data) => {
|
|
97
|
-
if (err) {
|
|
98
|
-
return rej(err);
|
|
99
|
-
}
|
|
100
|
-
return res(data?.fields || data);
|
|
101
|
-
},
|
|
102
|
-
);
|
|
103
|
-
}
|
|
104
|
-
}),
|
|
105
|
-
}), {});
|
|
106
|
-
|
|
107
|
-
const getMapnik = () => ({
|
|
108
|
-
...grpcMethods,
|
|
109
|
-
mapServerAddress,
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
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 { mapServerAddress, ready } = config;
|
|
16
|
+
|
|
17
|
+
if (!mapServerAddress) {
|
|
18
|
+
throw new Error("Map 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
|
+
mapServerAddress,
|
|
36
|
+
grpc.credentials.createInsecure(),
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
mapClient.waitForReady(Date.now() + 5000, (err) => {
|
|
40
|
+
if (err) {
|
|
41
|
+
ready.mapnik = false;
|
|
42
|
+
console.error("Mapnik client connection timeout or failure:", err);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
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
|
+
const grpcMethods = Object.getOwnPropertyNames(
|
|
65
|
+
Object.getPrototypeOf(mapClient),
|
|
66
|
+
)
|
|
67
|
+
.filter(key => key.slice(0, 1).toUpperCase() === key.slice(0, 1))
|
|
68
|
+
.reduce((acc, curr) => ({
|
|
69
|
+
...acc,
|
|
70
|
+
[curr]: async (inputData, callback, unsafe) => new Promise((res, rej) => {
|
|
71
|
+
if (curr === "CreateXML" && typeof callback === 'function') {
|
|
72
|
+
const stream = mapClient[curr].call(
|
|
73
|
+
mapClient,
|
|
74
|
+
inputData,
|
|
75
|
+
(err, data) => {
|
|
76
|
+
if (err) {
|
|
77
|
+
return rej(err);
|
|
78
|
+
}
|
|
79
|
+
return res(data);
|
|
80
|
+
},
|
|
81
|
+
);
|
|
82
|
+
stream.on("error", (err) => {
|
|
83
|
+
// unsafe=true prevents from sequence termination etc
|
|
84
|
+
callback(err?.message || err, unsafe ? null : 1);
|
|
85
|
+
rej(err);
|
|
86
|
+
});
|
|
87
|
+
stream.on("data", (resp) => {
|
|
88
|
+
callback(resp?.message || resp?.error || JSON.stringify(resp));
|
|
89
|
+
});
|
|
90
|
+
stream.on("end", () => res('finish'));
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
mapClient[curr].call(
|
|
94
|
+
mapClient,
|
|
95
|
+
inputData,
|
|
96
|
+
(err, data) => {
|
|
97
|
+
if (err) {
|
|
98
|
+
return rej(err);
|
|
99
|
+
}
|
|
100
|
+
return res(data?.fields || data);
|
|
101
|
+
},
|
|
102
|
+
);
|
|
103
|
+
}
|
|
104
|
+
}),
|
|
105
|
+
}), {});
|
|
106
|
+
|
|
107
|
+
const getMapnik = () => ({
|
|
108
|
+
...grpcMethods,
|
|
109
|
+
mapServerAddress,
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
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, '/');
|