-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathpublic_loader.sh
executable file
·189 lines (117 loc) · 5.49 KB
/
public_loader.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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
#!/bin/bash
# Configurable options (though we recommend not changing these)
POSTGIS_PORT=6001
POSTGIS_CONTAINER_NAME=cccs-postgis-public
QGIS_SERVER_CONTAINER_NAME=cccs-qgis-server-public
QGIS_SERVER_PORT=6003
# -------------------------------------------------------
# You should not need to change anything below this point
# -------------------------------------------------------
# Specify the base path to the shapefiles dir as parameter when calling this
# script or it will default to the path below
DATA_PATH=/home/sync/cccs-maps/public/bps_indonesia
if [ -n "$1" ]
then
DATA_PATH=$1
fi
DB=gis
USER=docker
PASSWORD=docker
PSQL="psql -p ${POSTGIS_PORT} -h localhost -U docker ${DB}"
# Helpers to run shp2pgsql from in docker so we dont need to
# have it installed on the host
# We dont' use -t and we added -a=STDOUT so that we get only the stdout
# that we need to pip it into the next process
SHP2PGSQL="docker run --rm -i -a=STDOUT -v ${DATA_PATH}:/bps_indonesia/ kartoza/postgis /usr/bin/shp2pgsql"
# Where the shapefiles will appear to be in the docker container
VOLUME=/bps_indonesia
source functions.sh
install_dependencies
restart_postgis_server
function load_shapefile {
# Helper function to load a shapefile using OGR2OGR
SHAPE_FILE=$1
TABLE=$2
SQL="$3"
CONN="dbname='${DB}' host='localhost' port='${POSTGIS_PORT}' user='${USER}' password='${PASSWORD}'"
ogr2ogr \
-progress \
-append \
-skipfailures \
-a_srs "EPSG:4326" \
-nlt PROMOTE_TO_MULTI \
-f "ESRI Shapefile" \
PG:"${CONN}" \
${SHAPE_FILE} \
-nln ${TABLE} -sql "${SQL}"
}
#The public folders contain shapefiles that have the same name , the only
#difference being the prefix to show which folder it came from and others
#having field names which have different names so we will load data from a
#single corresponding table that has many records
#Firstly load all the files listed in the text file because they contain
# records with more columns than the other corresponding shapefiles
echo "Loading shapefiles"
echo "------------------"
for SHAPE_FILE in `cat public.txt`
do
echo "Loading ${SHAPE_FILE}"
${SHP2PGSQL} -s 4326 -c -D -I -W LATIN1 ${VOLUME}/${SHAPE_FILE} | ${PSQL}
done
echo "Running the sql file to clean the database"
echo "-------------------------------------------"
${PSQL} -f public.sql
echo "Updating the source datasets"
echo "----------------------------"
${PSQL} -c "UPDATE admin_point_l5 set source ='mtb';"
${PSQL} -c "UPDATE admin_area_l3 set source ='mbd';"
${PSQL} -c "UPDATE admin_area_l4 set source ='mbd';"
${PSQL} -c "UPDATE admin_area_l5 set source ='mbd';"
${PSQL} -c "UPDATE infra_airports set source ='mtb';"
${PSQL} -c "UPDATE infra_roads set source ='mtb';"
${PSQL} -c "UPDATE infra_seaports set source ='mtb';"
${PSQL} -c "UPDATE trans_sea_lane set source ='mtb';"
echo "Appending data to tables"
echo "------------------------"
SHAPE_FILE=${DATA_PATH}/MBD_public/shapefiles/admin_point-L5_IDN_MBD_population.shp
TABLE=admin_point_l5
SQL="SELECT name as desa, population as desa_popul,range_pop as range_pop, class as class, kode2010 as kode2010 from 'admin_point-L5_IDN_MBD_population'"
load_shapefile ${SHAPE_FILE} ${TABLE} "${SQL}"
SHAPE_FILE=${DATA_PATH}/MBD_public/shapefiles/infra-airports_point-L3_IDN_MBD.shp
TABLE=infra_airports
SQL="SELECT name from 'infra-airports_point-L3_IDN_MBD'"
load_shapefile ${SHAPE_FILE} ${TABLE} "${SQL}"
SHAPE_FILE=${DATA_PATH}/MBD_public/shapefiles/infra-roads_line-L3_IDN_MBD.shp
TABLE=infra_roads
SQL="SELECT id from 'infra-roads_line-L3_IDN_MBD'"
load_shapefile ${SHAPE_FILE} ${TABLE} "${SQL}"
SHAPE_FILE=${DATA_PATH}/MBD_public/shapefiles/infra-seports_point-L3_IDN_MBD.shp
TABLE=infra_seports
SQL="SELECT name from 'infra-seports_point-L3_IDN_MBD'"
load_shapefile ${SHAPE_FILE} ${TABLE} "${SQL}"
#Append layers from the MTB_public folder whilst also mapping fields which we saw as the same
SHAPE_FILE=${DATA_PATH}/MTB_public/shapefiles/admin_area-L3_IDN_MTB.shp
TABLE=admin_area_l3
SQL="SELECT provinsi, kabkotno as kab, kabkot from 'admin_area-L3_IDN_MTB'"
load_shapefile ${SHAPE_FILE} ${TABLE} "${SQL}"
SHAPE_FILE=${DATA_PATH}/MTB_public/shapefiles/admin_area-L4_IDN_MTB.shp
TABLE=admin_area_l4
SQL="SELECT kecamatan, kecno as kec from 'admin_area-L4_IDN_MTB'"
load_shapefile ${SHAPE_FILE} ${TABLE} "${SQL}"
SHAPE_FILE=${DATA_PATH}/MTB_public/shapefiles/admin_area-L5_IDN_MTB.shp
TABLE=admin_area_l5
SQL="SELECT kode2010,provinsi,provno as prop,kabkot,kabkotno as kab,kecamatan,kecno as kec,desa as nama,desano as desa,sumber,desa_popul from 'admin_area-L5_IDN_MTB'"
load_shapefile ${SHAPE_FILE} ${TABLE} "${SQL}"
echo "Final update"
echo "------------------------"
${PSQL} -c "UPDATE admin_point_l5 SET kabkot = 'Maluku Barat Daya' WHERE kabkot IS NULL;"
${PSQL} -c "UPDATE admin_area_l4 SET kabkot = 'Maluku Tenggara Barat' WHERE kabkot IS NULL;"
${PSQL} -c "UPDATE admin_area_l3 set source ='mtb' where source IS NULL;"
${PSQL} -c "UPDATE admin_area_l4 set source ='mtb' where source IS NULL;"
${PSQL} -c "UPDATE admin_area_l5 set source ='mtb' where source IS NULL;"
${PSQL} -c "UPDATE infra_airports set source ='mbd' where source IS NULL;"
${PSQL} -c "UPDATE infra_roads set source ='mbd' where source IS NULL;"
${PSQL} -c "UPDATE infra_seaports set source ='mbd' where source IS NULL;"
${PSQL} -c "UPDATE trans_sea_lane set source ='mbd' where source IS NULL;"
${PSQL} -c "UPDATE admin_point_l5 set source = 'mbd' where source IS NULL;"
restart_qgis_server