-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathcreateGnafDb.sh
executable file
·138 lines (115 loc) · 4.57 KB
/
createGnafDb.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
#! /bin/bash
# script to download and unpack GNAF and write a SQL script to load it.
set -ex
baseDir=$PWD
scriptDir=$baseDir/src/main/script
dataDir=$baseDir/data
mkdir -p $dataDir
# JSON URL from near top-right of: http://www.data.gov.au/dataset/geocoded-national-address-file-g-naf
jsonUrl=http://www.data.gov.au/api/3/action/package_show?id=19432f89-dc3a-4ef3-b943-5326ef1dbecc
# get data URL for current version from JSON
curl -sL $jsonUrl > meta.json
dataUrl=$( jq -r '.result.resources[] | select(.format == "ZIP") | .url' meta.json )
last_modified=$( jq -r '.result.resources[] | select(.format == "ZIP") | .last_modified' meta.json )
# download ZIP data file unless already done
zip=$dataDir/${dataUrl##*/}
[[ -f "$zip" ]] || ( cd $dataDir; wget "$dataUrl" )
unzipped=$dataDir/unzipped
# get dir path where the zip file's */Extras/ will be extracted (contains release month so releases don't clobber each other)
# get path from zip, discard leading info up to time and following spaces, keep the rest apart from the trailing /
# maybe a bit too brittle?
gnafExtras="$unzipped/$( unzip -l "$zip" '*/Extras/' | sed -rn '/Extras/s~^.*[0-9][0-9]:[0-9][0-9] *(.*)/$~\1~p' )"
# unzip unless $gnafExtras already exists
[[ -d "$gnafExtras" ]] || ( mkdir -p $unzipped; cd $unzipped; unzip $zip )
# get dir path parent of Standard/
gnafData="$unzipped/$( unzip -l "$zip" '*/Standard/' | sed -rn '/Standard/s~^.*[0-9][0-9]:[0-9][0-9] *(.*)/Standard/$~\1~p' )"
mkdir -p target/generated
cat > target/generated/version.json <<EoF
{
"git-commit": "$( git rev-parse HEAD )",
"sbt-version": "$( sed --regexp-extended 's/.*:=\s*"([^"]+)"/\1/' ../version.sbt )",
"gnaf-version": "$last_modified"
}
EoF
# echo ${gnafData##*/G-NAF } -- old method for determining version
# Load GNAF into a relational database following https://www.psma.com.au/sites/default/files/g-naf_-_getting_started_guide.pdf
{
# issue message during SQL script execution
progress() {
echo
echo "SELECT '$1' AS Progress, CURRENT_TIME() AS Time;"
echo
}
progress "modified: $gnafExtras/GNAF_TableCreation_Scripts/create_tables_ansi.sql"
sed -e 's/DROP TABLE/DROP TABLE IF EXISTS/' -e 's/numeric([0-9])/integer/' "$gnafExtras/GNAF_TableCreation_Scripts/create_tables_ansi.sql"
progress "load Authority Code ..."
while read tbl
do
echo "INSERT INTO ${tbl} SELECT * FROM CSVREAD('$gnafData/Authority Code/Authority_Code_${tbl}_psv.psv', null, 'fieldSeparator=|');"
done <<-'EoF'
ADDRESS_ALIAS_TYPE_AUT
ADDRESS_TYPE_AUT
FLAT_TYPE_AUT
GEOCODE_RELIABILITY_AUT
GEOCODE_TYPE_AUT
GEOCODED_LEVEL_TYPE_AUT
LEVEL_TYPE_AUT
LOCALITY_ALIAS_TYPE_AUT
LOCALITY_CLASS_AUT
MB_MATCH_CODE_AUT
PS_JOIN_TYPE_AUT
STREET_CLASS_AUT
STREET_TYPE_AUT
STREET_LOCALITY_ALIAS_TYPE_AUT
STREET_SUFFIX_AUT
EoF
# table names pasted from g-naf_-_getting_started_guide.pdf referenced above
progress "load Standard ..."
while read tbl
do
progress "load ${tbl} ..."
# A-Z mess matches 2 and 3 char state abreviations (note * would try to load {state}_STREET_LOCALITY_psv.psv into LOCALITY)
ls -1 "${gnafData}"/Standard/{[A-Z][A-Z],[A-Z][A-Z][A-Z]}_${tbl}_psv.psv | while read f
do
echo "INSERT INTO ${tbl} SELECT * FROM CSVREAD('$f', null, 'fieldSeparator=|');"
done
done <<-'EoF'
ADDRESS_ALIAS
ADDRESS_DEFAULT_GEOCODE
ADDRESS_DETAIL
ADDRESS_MESH_BLOCK_2011
ADDRESS_SITE_GEOCODE
ADDRESS_SITE
LOCALITY
LOCALITY_ALIAS
LOCALITY_NEIGHBOUR
LOCALITY_POINT
MB_2011
PRIMARY_SECONDARY
STATE
STREET_LOCALITY
STREET_LOCALITY_ALIAS
STREET_LOCALITY_POINT
EoF
# table names pasted from g-naf_-_getting_started_guide.pdf referenced above
progress "add constraints ..."
sed --regexp-extended --file=$scriptDir/constraint.sed "$gnafExtras/GNAF_TableCreation_Scripts/add_fk_constraints.sql"
progress "add an index on STREET_NAME (this is not part of the getting_started_guide)..."
echo "create index STREET_LOCALITY_NAME_IDX on STREET_LOCALITY (STREET_NAME);"
# progress "add view (suggested in getting_started_guide) ..."
# commented out as not useful/too slow
# cat "$gnafExtras/GNAF_View_Scripts/address_view.sql"
# echo ";"
progress "Create READONLY user ..."
cat <<-'EoF'
CREATE USER READONLY PASSWORD 'READONLY';
GRANT SELECT ON SCHEMA PUBLIC TO READONLY;
EoF
} | sed 's/REM/--/' > $dataDir/createGnafDb.sql
cat <<-'EoF'
Start H2 database engine with: java -jar h2*.jar -web -pg
Create an empty database by connecting to a new dburl e.g. jdbc:h2:file:~/gnaf (specify 'gnaf' as the username and password).
In the SQL input area enter: RUNSCRIPT FROM 'data/createGnafDb.sql'
or paste in the content of this file (to get progress feedback lacking with RUNSCRIPT).
After an hour (with SSD) you should have a GNAF database.
EoF