@opengis/gis 0.2.91 → 0.2.93
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 +7238 -6834
- package/dist/index.umd.cjs +66 -66
- 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 +39 -39
- 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 +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/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 +111 -111
- package/module/gis/table/gis.metadata.table.json +70 -70
- 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 +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/permissions/form/permissions.users.form.json +151 -151
- package/module/permissions/table/gis.permissions.table.json +98 -98
- package/module/test/cls/bp_build_type.json +37 -37
- package/module/test/cls/doc_status.json +31 -31
- 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/select/core.user_uid.sql +1 -1
- 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 +76 -76
- package/plugin.js +49 -49
- package/server/migrations/array_intersect.sql +13 -13
- package/server/migrations/cartocss.sql +25 -25
- package/server/migrations/group_list.sql +74 -74
- package/server/migrations/maps.sql +30 -30
- package/server/migrations/metadata.sql +416 -0
- 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 +108 -108
- package/server/plugins/mapnik/funcs/mapnik.js +146 -146
- package/server/plugins/mapnik/funcs/rootFolder.mjs +8 -8
- package/server/plugins/mapnik/map.proto +231 -231
- package/server/plugins/vite.js +75 -75
- package/server/routes/gis/cartocss/add.cartocss.js +39 -39
- package/server/routes/gis/cartocss/get.cartocss.js +49 -49
- package/server/routes/gis/checkXML.js +118 -0
- package/server/routes/gis/dashboard.js +29 -29
- package/server/routes/gis/index.mjs +87 -73
- package/server/routes/gis/metadata/editMetadata.js +34 -0
- 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 +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 +103 -103
- 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 +225 -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 +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 +112 -112
- package/server/routes/map/vtile1.js +176 -176
- 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 +94 -94
- package/server/routes/mapnik/controllers/createXml.js +66 -66
- package/server/routes/mapnik/controllers/createXmlMulti.js +75 -75
- package/server/routes/mapnik/controllers/fileSearch.js +34 -34
- package/server/routes/mapnik/controllers/fileStat.js +27 -27
- 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 +50 -50
- package/server/routes/mapnik/controllers/readDir.js +19 -19
- package/server/routes/mapnik/controllers/rtile.js +122 -122
- package/server/routes/mapnik/controllers/uploadRaster.js +157 -157
- package/server/routes/mapnik/functions/cartoBounds.js +23 -23
- package/server/routes/mapnik/functions/uploadXML.js +110 -110
- package/server/routes/mapnik/index.js +28 -28
- 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 +43 -43
- package/server/routes/permissions/index.mjs +18 -18
- package/server/routes/root.mjs +3 -3
- package/utils.js +13 -13
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
import { config } from '@opengis/fastify-table/utils.js';
|
|
2
|
-
|
|
3
|
-
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
4
|
-
|
|
5
|
-
const { GetStat } = mapnik();
|
|
6
|
-
|
|
7
|
-
export default async function mapnikStat({
|
|
8
|
-
params, query,
|
|
9
|
-
}, reply) {
|
|
10
|
-
if (!config.mapServerAddress) {
|
|
11
|
-
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const stat = await GetStat({
|
|
15
|
-
period: params.period,
|
|
16
|
-
ttl: query.nocache ? '0' : undefined,
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
return reply.status(200).send(stat);
|
|
20
|
-
}
|
|
1
|
+
import { config } from '@opengis/fastify-table/utils.js';
|
|
2
|
+
|
|
3
|
+
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
4
|
+
|
|
5
|
+
const { GetStat } = mapnik();
|
|
6
|
+
|
|
7
|
+
export default async function mapnikStat({
|
|
8
|
+
params, query,
|
|
9
|
+
}, reply) {
|
|
10
|
+
if (!config.mapServerAddress) {
|
|
11
|
+
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const stat = await GetStat({
|
|
15
|
+
period: params.period,
|
|
16
|
+
ttl: query.nocache ? '0' : undefined,
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
return reply.status(200).send(stat);
|
|
20
|
+
}
|
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
import { config, pgClients } from '@opengis/fastify-table/utils.js';
|
|
2
|
-
|
|
3
|
-
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
4
|
-
|
|
5
|
-
const { GetRasterInfo } = mapnik();
|
|
6
|
-
|
|
7
|
-
const { prefix = '/api' } = config;
|
|
8
|
-
|
|
9
|
-
export default async function rasterInfo({
|
|
10
|
-
pg = pgClients.client, params, query,
|
|
11
|
-
}, reply) {
|
|
12
|
-
const time = Date.now();
|
|
13
|
-
if (!config.mapServerAddress) {
|
|
14
|
-
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
const raster = pg.pk?.['gis.rasters']
|
|
18
|
-
? await pg.query('select raster_id, source_path, name, description, raster_key, is_active, is_public, srid, proj4 from gis.rasters where raster_id=$1::text', [params.id])
|
|
19
|
-
.then(el => el.rows?.[0] || {})
|
|
20
|
-
: {};
|
|
21
|
-
|
|
22
|
-
if (raster.raster_id && !raster.source_path) {
|
|
23
|
-
return reply.status(400).send({ error: 'empty source_path', code: 400 });
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
if (!raster.raster_id) {
|
|
27
|
-
const decodedPath = Buffer.from(params.id, 'base64url').toString('utf-8');
|
|
28
|
-
Object.assign(raster, { source_path: decodedPath });
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
const proj4 = raster.proj4 || (raster.srid && pg.pk?.['public.spatial_ref_sys'] ? await pg.query('select proj4text from public.spatial_ref_sys where srid=$1', [raster.srid]).then(el => el.rows?.[0]?.proj4text) : undefined);
|
|
32
|
-
|
|
33
|
-
const { data, cache } = await GetRasterInfo({
|
|
34
|
-
path: raster.source_path,
|
|
35
|
-
proj4,
|
|
36
|
-
ttl: query.nocache ? '0' : '1h',
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
if (query.debug) {
|
|
40
|
-
return { data, cache, raster };
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
return {
|
|
44
|
-
time: Date.now() - time,
|
|
45
|
-
...data,
|
|
46
|
-
...raster,
|
|
47
|
-
cache,
|
|
48
|
-
url: `${prefix}/gis-rtile/${Buffer.from(raster.source_path).toString('base64url')}/{z}/{x}/{y}.png`,
|
|
49
|
-
};
|
|
50
|
-
}
|
|
1
|
+
import { config, pgClients } from '@opengis/fastify-table/utils.js';
|
|
2
|
+
|
|
3
|
+
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
4
|
+
|
|
5
|
+
const { GetRasterInfo } = mapnik();
|
|
6
|
+
|
|
7
|
+
const { prefix = '/api' } = config;
|
|
8
|
+
|
|
9
|
+
export default async function rasterInfo({
|
|
10
|
+
pg = pgClients.client, params, query,
|
|
11
|
+
}, reply) {
|
|
12
|
+
const time = Date.now();
|
|
13
|
+
if (!config.mapServerAddress) {
|
|
14
|
+
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
const raster = pg.pk?.['gis.rasters']
|
|
18
|
+
? await pg.query('select raster_id, source_path, name, description, raster_key, is_active, is_public, srid, proj4 from gis.rasters where raster_id=$1::text', [params.id])
|
|
19
|
+
.then(el => el.rows?.[0] || {})
|
|
20
|
+
: {};
|
|
21
|
+
|
|
22
|
+
if (raster.raster_id && !raster.source_path) {
|
|
23
|
+
return reply.status(400).send({ error: 'empty source_path', code: 400 });
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
if (!raster.raster_id) {
|
|
27
|
+
const decodedPath = Buffer.from(params.id, 'base64url').toString('utf-8');
|
|
28
|
+
Object.assign(raster, { source_path: decodedPath });
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
const proj4 = raster.proj4 || (raster.srid && pg.pk?.['public.spatial_ref_sys'] ? await pg.query('select proj4text from public.spatial_ref_sys where srid=$1', [raster.srid]).then(el => el.rows?.[0]?.proj4text) : undefined);
|
|
32
|
+
|
|
33
|
+
const { data, cache } = await GetRasterInfo({
|
|
34
|
+
path: raster.source_path,
|
|
35
|
+
proj4,
|
|
36
|
+
ttl: query.nocache ? '0' : '1h',
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
if (query.debug) {
|
|
40
|
+
return { data, cache, raster };
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
return {
|
|
44
|
+
time: Date.now() - time,
|
|
45
|
+
...data,
|
|
46
|
+
...raster,
|
|
47
|
+
cache,
|
|
48
|
+
url: `${prefix}/gis-rtile/${Buffer.from(raster.source_path).toString('base64url')}/{z}/{x}/{y}.png`,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
2
|
-
|
|
3
|
-
const { ReadDir } = mapnik();
|
|
4
|
-
|
|
5
|
-
// example: GET /api/gis-files?dir=tiles/3828667893214610450
|
|
6
|
-
export default async function readDir({
|
|
7
|
-
query,
|
|
8
|
-
}, reply) {
|
|
9
|
-
if (!ReadDir) {
|
|
10
|
-
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
const { dir } = query;
|
|
14
|
-
|
|
15
|
-
const {
|
|
16
|
-
exists = false, count = 0, files = [], directories = [],
|
|
17
|
-
} = await ReadDir({ path: dir });
|
|
18
|
-
return { exists, count, data: files.map(el => ({ type: 'file', ...el })).concat(directories.map(el => ({ type: 'directory', ...el }))) };
|
|
19
|
-
}
|
|
1
|
+
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
2
|
+
|
|
3
|
+
const { ReadDir } = mapnik();
|
|
4
|
+
|
|
5
|
+
// example: GET /api/gis-files?dir=tiles/3828667893214610450
|
|
6
|
+
export default async function readDir({
|
|
7
|
+
query,
|
|
8
|
+
}, reply) {
|
|
9
|
+
if (!ReadDir) {
|
|
10
|
+
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const { dir } = query;
|
|
14
|
+
|
|
15
|
+
const {
|
|
16
|
+
exists = false, count = 0, files = [], directories = [],
|
|
17
|
+
} = await ReadDir({ path: dir });
|
|
18
|
+
return { exists, count, data: files.map(el => ({ type: 'file', ...el })).concat(directories.map(el => ({ type: 'directory', ...el }))) };
|
|
19
|
+
}
|
|
@@ -1,122 +1,122 @@
|
|
|
1
|
-
import { createHash } from 'node:crypto';
|
|
2
|
-
|
|
3
|
-
import Sphericalmercator from '@mapbox/sphericalmercator';
|
|
4
|
-
|
|
5
|
-
import { config, logger, pgClients } from '@opengis/fastify-table/utils.js';
|
|
6
|
-
|
|
7
|
-
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
8
|
-
|
|
9
|
-
const { RenderTile } = mapnik();
|
|
10
|
-
|
|
11
|
-
const mercator = new Sphericalmercator({ size: 256 });
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Формування растрового tile cartoCss
|
|
15
|
-
*
|
|
16
|
-
* @method GET
|
|
17
|
-
* @alias rtile
|
|
18
|
-
* @param {String} bbox - bbox
|
|
19
|
-
* @param {Number} height - висота по координатам
|
|
20
|
-
* @param {Number} width - ширина по координатам
|
|
21
|
-
* @param {String} data - стилізація
|
|
22
|
-
* @param {String} lang - мова
|
|
23
|
-
* @param {String} z - координата z
|
|
24
|
-
* @param {String} x - координата y
|
|
25
|
-
* @param {String} y - координата x
|
|
26
|
-
*/
|
|
27
|
-
|
|
28
|
-
export default async function rtile({
|
|
29
|
-
pg = pgClients.client, params, query,
|
|
30
|
-
}, reply) {
|
|
31
|
-
if (!RenderTile) {
|
|
32
|
-
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const { id, z, y } = params;
|
|
36
|
-
|
|
37
|
-
const x = params.x.split('.')[0] - 0;
|
|
38
|
-
|
|
39
|
-
if (!id) {
|
|
40
|
-
return reply.status(400).send({ error: 'not enough params: id', code: 400 });
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
if (!x || !y || !z) {
|
|
44
|
-
return reply.status(400).send({ error: 'not enough params: xyz', code: 400 });
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
const raster = pg.pk?.['gis.rasters']
|
|
48
|
-
? await pg.query('select raster_id, source_path from gis.rasters where raster_id=$1::text', [id])
|
|
49
|
-
.then(el => el.rows?.[0] || {})
|
|
50
|
-
: {};
|
|
51
|
-
|
|
52
|
-
// const relpath = raster ? `/map/raster/${raster.source_path}` : null;
|
|
53
|
-
|
|
54
|
-
const carto = pg.pk?.['gis.cartocss']
|
|
55
|
-
? await pg.query('select cartocss_id, source_path from gis.cartocss where cartocss_id=$1::text', [id])
|
|
56
|
-
.then(el => el.rows?.[0] || {})
|
|
57
|
-
: {};
|
|
58
|
-
|
|
59
|
-
const cartoExists = !!carto.cartocss_id;
|
|
60
|
-
|
|
61
|
-
if (!raster.raster_id && !cartoExists) {
|
|
62
|
-
const decodedPath = Buffer.from(id, 'base64url').toString('utf-8');
|
|
63
|
-
Object.assign(raster, { source_path: decodedPath });
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (!raster.source_path && !cartoExists) {
|
|
67
|
-
return reply.status(404).send({ error: 'raster / cartocss not found', code: 404 });
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
const bbox = mercator.bbox(y, x, z, false, '900913');
|
|
71
|
-
|
|
72
|
-
try {
|
|
73
|
-
const ttl = (query.nocache ? '0' : null)
|
|
74
|
-
|| (cartoExists ? '1h' : null);
|
|
75
|
-
|
|
76
|
-
const md5 = raster.source_path
|
|
77
|
-
? createHash('md5').update(raster.source_path).digest('hex')
|
|
78
|
-
: undefined;
|
|
79
|
-
const base64 = raster.source_path
|
|
80
|
-
? Buffer.from(raster.source_path).toString('base64url')
|
|
81
|
-
: undefined;
|
|
82
|
-
|
|
83
|
-
const param = {
|
|
84
|
-
path: cartoExists ? null : raster.source_path, // for rasters only
|
|
85
|
-
name: cartoExists && carto.source_path ? `vector/${carto.source_path}` : id, // required for cartocss
|
|
86
|
-
width: 256,
|
|
87
|
-
bbox,
|
|
88
|
-
ttl,
|
|
89
|
-
debug: query.debug,
|
|
90
|
-
};
|
|
91
|
-
// console.log(param);
|
|
92
|
-
const data = await RenderTile(param);
|
|
93
|
-
|
|
94
|
-
if (query.debug) {
|
|
95
|
-
return {
|
|
96
|
-
...data,
|
|
97
|
-
ttl,
|
|
98
|
-
md5_path: md5,
|
|
99
|
-
base64_path: base64,
|
|
100
|
-
raster: !!raster.raster_id,
|
|
101
|
-
carto: cartoExists,
|
|
102
|
-
};
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
if (data.err) {
|
|
106
|
-
logger.file('rtile/error', {
|
|
107
|
-
error: data.err, x, y, z, id: cartoExists ? carto.cartocss_id : raster.raster_id, type: cartoExists ? 'css' : 'raster',
|
|
108
|
-
});
|
|
109
|
-
return reply.status(500).send({ error: config.local ? data.err : 'render error', code: 500 });
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
const buffer = Buffer.from(data.base64, 'base64');
|
|
113
|
-
|
|
114
|
-
return reply.headers({ 'Content-Type': 'image/png', 'Cache-Control': query.nocache || query.nottl ? 'no-store, no-cache, must-revalidate' : 'public, max-age=2592000' }).send(buffer);
|
|
115
|
-
}
|
|
116
|
-
catch (err) {
|
|
117
|
-
logger.file('rtile/error', {
|
|
118
|
-
error: err.toString(), stack: err.stack, x, y, z, id: cartoExists ? carto.cartocss_id : raster.raster_id, type: cartoExists ? 'css' : 'raster',
|
|
119
|
-
});
|
|
120
|
-
return reply.status(500).send({ error: config.local ? err.toString() : 'rtile error', code: 500 });
|
|
121
|
-
}
|
|
122
|
-
}
|
|
1
|
+
import { createHash } from 'node:crypto';
|
|
2
|
+
|
|
3
|
+
import Sphericalmercator from '@mapbox/sphericalmercator';
|
|
4
|
+
|
|
5
|
+
import { config, logger, pgClients } from '@opengis/fastify-table/utils.js';
|
|
6
|
+
|
|
7
|
+
import mapnik from '../../../plugins/mapnik/funcs/mapnik.js';
|
|
8
|
+
|
|
9
|
+
const { RenderTile } = mapnik();
|
|
10
|
+
|
|
11
|
+
const mercator = new Sphericalmercator({ size: 256 });
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Формування растрового tile cartoCss
|
|
15
|
+
*
|
|
16
|
+
* @method GET
|
|
17
|
+
* @alias rtile
|
|
18
|
+
* @param {String} bbox - bbox
|
|
19
|
+
* @param {Number} height - висота по координатам
|
|
20
|
+
* @param {Number} width - ширина по координатам
|
|
21
|
+
* @param {String} data - стилізація
|
|
22
|
+
* @param {String} lang - мова
|
|
23
|
+
* @param {String} z - координата z
|
|
24
|
+
* @param {String} x - координата y
|
|
25
|
+
* @param {String} y - координата x
|
|
26
|
+
*/
|
|
27
|
+
|
|
28
|
+
export default async function rtile({
|
|
29
|
+
pg = pgClients.client, params, query,
|
|
30
|
+
}, reply) {
|
|
31
|
+
if (!RenderTile) {
|
|
32
|
+
return reply.status(400).send({ error: 'mapnik server address needed', code: 400 });
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const { id, z, y } = params;
|
|
36
|
+
|
|
37
|
+
const x = params.x.split('.')[0] - 0;
|
|
38
|
+
|
|
39
|
+
if (!id) {
|
|
40
|
+
return reply.status(400).send({ error: 'not enough params: id', code: 400 });
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
if (!x || !y || !z) {
|
|
44
|
+
return reply.status(400).send({ error: 'not enough params: xyz', code: 400 });
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const raster = pg.pk?.['gis.rasters']
|
|
48
|
+
? await pg.query('select raster_id, source_path from gis.rasters where raster_id=$1::text', [id])
|
|
49
|
+
.then(el => el.rows?.[0] || {})
|
|
50
|
+
: {};
|
|
51
|
+
|
|
52
|
+
// const relpath = raster ? `/map/raster/${raster.source_path}` : null;
|
|
53
|
+
|
|
54
|
+
const carto = pg.pk?.['gis.cartocss']
|
|
55
|
+
? await pg.query('select cartocss_id, source_path from gis.cartocss where cartocss_id=$1::text', [id])
|
|
56
|
+
.then(el => el.rows?.[0] || {})
|
|
57
|
+
: {};
|
|
58
|
+
|
|
59
|
+
const cartoExists = !!carto.cartocss_id;
|
|
60
|
+
|
|
61
|
+
if (!raster.raster_id && !cartoExists) {
|
|
62
|
+
const decodedPath = Buffer.from(id, 'base64url').toString('utf-8');
|
|
63
|
+
Object.assign(raster, { source_path: decodedPath });
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
if (!raster.source_path && !cartoExists) {
|
|
67
|
+
return reply.status(404).send({ error: 'raster / cartocss not found', code: 404 });
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
const bbox = mercator.bbox(y, x, z, false, '900913');
|
|
71
|
+
|
|
72
|
+
try {
|
|
73
|
+
const ttl = (query.nocache ? '0' : null)
|
|
74
|
+
|| (cartoExists ? '1h' : null);
|
|
75
|
+
|
|
76
|
+
const md5 = raster.source_path
|
|
77
|
+
? createHash('md5').update(raster.source_path).digest('hex')
|
|
78
|
+
: undefined;
|
|
79
|
+
const base64 = raster.source_path
|
|
80
|
+
? Buffer.from(raster.source_path).toString('base64url')
|
|
81
|
+
: undefined;
|
|
82
|
+
|
|
83
|
+
const param = {
|
|
84
|
+
path: cartoExists ? null : raster.source_path, // for rasters only
|
|
85
|
+
name: cartoExists && carto.source_path ? `vector/${carto.source_path}` : id, // required for cartocss
|
|
86
|
+
width: 256,
|
|
87
|
+
bbox,
|
|
88
|
+
ttl,
|
|
89
|
+
debug: query.debug,
|
|
90
|
+
};
|
|
91
|
+
// console.log(param);
|
|
92
|
+
const data = await RenderTile(param);
|
|
93
|
+
|
|
94
|
+
if (query.debug) {
|
|
95
|
+
return {
|
|
96
|
+
...data,
|
|
97
|
+
ttl,
|
|
98
|
+
md5_path: md5,
|
|
99
|
+
base64_path: base64,
|
|
100
|
+
raster: !!raster.raster_id,
|
|
101
|
+
carto: cartoExists,
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
if (data.err) {
|
|
106
|
+
logger.file('rtile/error', {
|
|
107
|
+
error: data.err, x, y, z, id: cartoExists ? carto.cartocss_id : raster.raster_id, type: cartoExists ? 'css' : 'raster',
|
|
108
|
+
});
|
|
109
|
+
return reply.status(500).send({ error: config.local ? data.err : 'render error', code: 500 });
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
const buffer = Buffer.from(data.base64, 'base64');
|
|
113
|
+
|
|
114
|
+
return reply.headers({ 'Content-Type': 'image/png', 'Cache-Control': query.nocache || query.nottl ? 'no-store, no-cache, must-revalidate' : 'public, max-age=2592000' }).send(buffer);
|
|
115
|
+
}
|
|
116
|
+
catch (err) {
|
|
117
|
+
logger.file('rtile/error', {
|
|
118
|
+
error: err.toString(), stack: err.stack, x, y, z, id: cartoExists ? carto.cartocss_id : raster.raster_id, type: cartoExists ? 'css' : 'raster',
|
|
119
|
+
});
|
|
120
|
+
return reply.status(500).send({ error: config.local ? err.toString() : 'rtile error', code: 500 });
|
|
121
|
+
}
|
|
122
|
+
}
|