-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathanalyzer-qa-missing-route500.sh
executable file
·38 lines (31 loc) · 1.61 KB
/
analyzer-qa-missing-route500.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/bin/bash
source $(dirname $0)/config.sh
OUT=/home/cquest/public_html/insee_route500-france.xml
psql osm -c "refresh materialized view r500_pts;"
echo "<?xml version=\"1.0\" encoding=\"UTF-8\"?>
<analysers timestamp=\"`date -u +%Y-%m-%dT%H:%M:%SZ`\">
<analyser timestamp=\"`date -u +%Y-%m-%dT%H:%M:%SZ`\">
<class item=\"7170\" tag=\"highway\" id=\"2\" level=\"3\">
<classtext lang=\"fr\" title=\"ref=* ou route potentiellement manquante à proximité\" />
<classtext lang=\"en\" title=\"ref=* or possibly missing highway in the area\" />
</class>
" > $OUT
psql osm -c "
with r as (select p.geom, r.num_route, r.dep, r.id_rte500, st_transform(p.geom,4326) as way from r500_pts p join r500 r on (r.id_rte500=p.id)
where num_route !='')
select format('<error class=\"2\" subclass=\"1\"><location lat=\"%s\" lon=\"%s\" /><text lang=\"fr\" value=\"%s (id_route500: %s)\" /></error>',
round(st_y(st_centroid(r.way))::numeric,6),
round(st_x(st_centroid(r.way))::numeric,6),
string_agg(distinct(regexp_replace(r.num_route,'([A-Z]*)([0-9A-Z]*$)','\1 \2')),','), string_agg(distinct(r.id_rte500::text),','))
from r
left join planet_osm_line l on (st_dwithin(l.way,r.geom,300)
and (r.num_route=regexp_replace(regexp_replace(upper(l.ref),'[^0-9A-Z\.]*','','g'),'^M','D')
or r.num_route=regexp_replace(upper(l.tags->'old_ref'),'[^0-9A-Z]*','','g')
or r.num_route=regexp_replace(upper(l.tags->'nat_ref'),'[^0-9A-Z]*','','g'))
and l.highway is not null and l.ref is not null)
where l.ref is null and r.num_route is not null group by r.way;
" -t >> $OUT
echo "
</analyser>
</analysers>" >> $OUT
send_frontend $OUT