basic repo setup
[dcaegen2/services/son-handler.git] / mvn-phase-lib.sh
1 #!/bin/bash
2
3 # ================================================================================
4 # Copyright (c) 2019 AT&T Intellectual Property. All rights reserved.
5 # ================================================================================
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 #     http://www.apache.org/licenses/LICENSE-2.0
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 # ============LICENSE_END=========================================================
18 #
19
20
21 #MVN_PROJECT_MODULEID="$1"
22 #MVN_PHASE="$2"
23 #PROJECT_ROOT=$(dirname $0)
24
25 FQDN="${MVN_PROJECT_GROUPID}.${MVN_PROJECT_ARTIFACTID}"
26 if [ "$MVN_PROJECT_MODULEID" == "__" ]; then
27   MVN_PROJECT_MODULEID=""
28 fi
29
30 if [[ "$MVN_PROJECT_VERSION" == *SNAPSHOT ]]; then
31   echo "=> for SNAPSHOT artifact build"
32   MVN_DEPLOYMENT_TYPE='SNAPSHOT'
33 else
34   echo "=> for STAGING/RELEASE artifact build"
35   MVN_DEPLOYMENT_TYPE='STAGING'
36 fi
37 echo "MVN_DEPLOYMENT_TYPE is             [$MVN_DEPLOYMENT_TYPE]"
38
39
40 TIMESTAMP=$(date +%C%y%m%dT%H%M%S)
41
42 # expected environment variables
43 if [ -z "${MVN_NEXUSPROXY}" ]; then
44     echo "MVN_NEXUSPROXY environment variable not set.  Cannot proceed"
45     exit
46 fi
47 MVN_NEXUSPROXY_HOST=$(echo "$MVN_NEXUSPROXY" |cut -f3 -d'/' | cut -f1 -d':')
48 echo "=> Nexus Proxy at $MVN_NEXUSPROXY_HOST, $MVN_NEXUSPROXY"
49
50 if [ -z "$WORKSPACE" ]; then
51     WORKSPACE=$(pwd)
52 fi
53
54 if [ -z "$SETTINGS_FILE" ]; then
55     echo "SETTINGS_FILE environment variable not set.  Cannot proceed"
56     exit
57 fi
58
59
60
61 # mvn phase in life cycle
62 MVN_PHASE="$2"
63
64 echo "MVN_PROJECT_MODULEID is            [$MVN_PROJECT_MODULEID]"
65 echo "MVN_PHASE is                       [$MVN_PHASE]"
66 echo "MVN_PROJECT_GROUPID is             [$MVN_PROJECT_GROUPID]"
67 echo "MVN_PROJECT_ARTIFACTID is          [$MVN_PROJECT_ARTIFACTID]"
68 echo "MVN_PROJECT_VERSION is             [$MVN_PROJECT_VERSION]"
69 echo "MVN_NEXUSPROXY is                  [$MVN_NEXUSPROXY]"
70 echo "MVN_RAWREPO_BASEURL_UPLOAD is      [$MVN_RAWREPO_BASEURL_UPLOAD]"
71 echo "MVN_RAWREPO_BASEURL_DOWNLOAD is    [$MVN_RAWREPO_BASEURL_DOWNLOAD]"
72 MVN_RAWREPO_HOST=$(echo "$MVN_RAWREPO_BASEURL_UPLOAD" | cut -f3 -d'/' |cut -f1 -d':')
73 echo "MVN_RAWREPO_HOST is                [$MVN_RAWREPO_HOST]"
74 echo "MVN_RAWREPO_SERVERID is            [$MVN_RAWREPO_SERVERID]"
75 echo "MVN_DOCKERREGISTRY_DAILY is        [$MVN_DOCKERREGISTRY_DAILY]"
76 echo "MVN_DOCKERREGISTRY_RELEASE is      [$MVN_DOCKERREGISTRY_RELEASE]"
77
78 echo "MVN_PYPISERVER_SERVERID            [$MVN_PYPISERVER_SERVERID]"
79 echo "MVN_PYPISERVER_BASEURL is          [$MVN_PYPISERVER_BASEURL]"
80
81
82
83 clean_templated_files() 
84 {
85   TEMPLATE_FILES=$(find . -name "*-template")
86   for F in $TEMPLATE_FILES; do
87     F2=$(echo "$F" | sed 's/-template$//')
88     rm -f "$F2"
89   done
90 }
91 clean_tox_files() 
92 {
93   TOX_FILES=$(find . -name ".tox")
94   TOX_FILES="$TOX_FILES $(find . -name 'venv-tox')"
95   for F in $TOX_FILES; do
96     rm -rf "$F"
97   done
98 }
99
100 expand_templates() 
101 {
102   # set up env variables, get ready for template resolution
103   # NOTE: CCSDK artifacts do not distinguish REALESE vs SNAPSHOTs
104   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_plugins_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.plugins"
105   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_plugins_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.plugins"
106   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_blueprints_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.blueprints"
107   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_blueprints_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.blueprints"
108  
109   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2/releases"
110   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2/snapshots"
111   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_plugins_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.plugins/releases"
112   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_plugins_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.plugins/snapshots"
113   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_blueprints_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.blueprints/releases"
114   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_blueprints_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.blueprints/snapshots"
115
116   export ONAPTEMPLATE_PYPIURL_org_onap_dcaegen2="$MVN_PYPISERVER_BASEURL"
117
118   export ONAPTEMPLATE_DOCKERREGURL_org_onap_dcaegen2_releases="$MVN_DOCKERREGISTRY_DAILY"
119   export ONAPTEMPLATE_DOCKERREGURL_org_onap_dcaegen2_snapshots="$MVN_DOCKERREGISTRY_DAILY/snapshots"
120
121
122   TEMPLATE_FILES=$(find . -name "*-template")
123   for F in $TEMPLATE_FILES; do
124     F2=$(echo "$F" | sed 's/-template$//')
125     cp "$F" "$F2"
126     MOD=$(stat --format '%a' "$F")
127     chmod "$MOD" "$F2"
128   done
129    
130
131   TEMPLATES=$(env |grep ONAPTEMPLATE)
132   if [ -z "$TEMPLATES" ]; then
133     return 0
134   fi
135
136   echo "====> Resolving the following temaplate from environment variables "
137   echo "[$TEMPLATES]"
138   SELFFILE=$(echo "$0" | rev | cut -f1 -d '/' | rev)
139   for TEMPLATE in $TEMPLATES; do
140     KEY=$(echo "$TEMPLATE" | cut -f1 -d'=')
141     VALUE=$(echo "$TEMPLATE" | cut -f2 -d'=')
142     VALUE2=$(echo "$TEMPLATE" | cut -f2 -d'=' |sed 's/\//\\\//g')
143     set +e
144     FILES=$(grep -rl "$KEY")
145     set -e
146
147     if [ -z "$FILES" ]; then
148       continue
149     fi
150
151     # assuming FILES is not longer than 2M bytes, the limit for variable value max size on this VM
152     for F in $FILES; do
153       if [[ $F == *"$SELFFILE" ]]; then
154         continue
155       fi
156       if [[ "$F" == *-template ]]; then
157         continue
158       fi
159
160       echo "======> Resolving template $KEY to value $VALUE for file $F"
161       sed -i "s/{{[[:space:]]*$KEY[[:space:]]*}}/$VALUE2/g" "$F"
162       #cat "$F"
163     done
164
165     #if [ ! -z "$FILES" ]; then
166     #   echo "====> Resolving template $VALUE to value $VALUE"
167     #   #CMD="grep -rl \"$VALUE\" | tr '\n' '\0' | xargs -0 sed -i \"s/{{[[:space:]]*$VALUE[[:space:]]*}}/$VALUE/g\""
168     #   grep -rl "$KEY" | tr '\n' '\0' | xargs -0 sed -i 's/$KEY/$VALUE2/g'
169     #   #echo $CMD
170     #   #eval $CMD
171     #fi
172   done
173   echo "====> Done template reolving"
174 }
175
176
177 run_tox_test() 
178
179   set -x
180   CURDIR=$(pwd)
181   TOXINIS=$(find . -name "tox.ini")
182   for TOXINI in "${TOXINIS[@]}"; do
183     DIR=$(echo "$TOXINI" | rev | cut -f2- -d'/' | rev)
184     cd "${CURDIR}/${DIR}"
185     rm -rf ./venv-tox ./.tox
186     virtualenv ./venv-tox
187     source ./venv-tox/bin/activate
188     pip install --upgrade pip
189     pip install --upgrade tox argparse
190     pip freeze
191     tox
192     deactivate
193     rm -rf ./venv-tox ./.tox
194   done
195 }
196
197 build_wagons() 
198 {
199   rm -rf ./*.wgn venv-pkg
200
201   SETUPFILES=$(find . -name "setup.py")
202   for SETUPFILE in $SETUPFILES; do
203     PLUGIN_DIR=$(echo "$SETUPFILE" |rev | cut -f 2- -d '/' |rev)
204     PLUGIN_NAME=$(grep 'name' "$SETUPFILE" | cut -f2 -d'=' | sed 's/[^0-9a-zA-Z\.]*//g')
205     PLUGIN_VERSION=$(grep 'version' "$SETUPFILE" | cut -f2 -d'=' | sed 's/[^0-9\.]*//g')
206
207     echo "In $PLUGIN_DIR, $PLUGIN_NAME, $PLUGIN_VERSION"
208
209     virtualenv ./venv-pkg
210     source ./venv-pkg/bin/activate
211     pip install --upgrade pip
212     pip install wagon
213     wagon create --format tar.gz "$PLUGIN_DIR"
214     deactivate
215     rm -rf venv-pkg
216
217     PKG_FILE_NAMES=( "${PLUGIN_NAME}-${PLUGIN_VERSION}"*.wgn )
218     echo Built package: "${PKG_FILE_NAMES[@]}"
219   done
220 }
221
222
223 upload_raw_file() 
224 {
225   # Extract the username and password to the nexus repo from the settings file
226   USER=$(xpath -q -e "//servers/server[id='$MVN_RAWREPO_SERVERID']/username/text()" "$SETTINGS_FILE")
227   PASS=$(xpath -q -e "//servers/server[id='$MVN_RAWREPO_SERVERID']/password/text()" "$SETTINGS_FILE")
228   NETRC=$(mktemp)
229   echo "machine $MVN_RAWREPO_HOST login $USER password $PASS" > "$NETRC"
230
231   REPO="$MVN_RAWREPO_BASEURL_UPLOAD"
232
233   OUTPUT_FILE=$(echo "$1" | sed -e "s/^.\///")
234   EXT=$(echo "$OUTPUT_FILE" | rev |cut -f1 -d '.' |rev)
235   if [ "$EXT" == 'yaml' ]; then
236     OUTPUT_FILE_TYPE='text/x-yaml'
237   elif [ "$EXT" == 'json' ]; then
238     OUTPUT_FILE_TYPE='application/json'
239   elif [ "$EXT" == 'sh' ]; then
240     OUTPUT_FILE_TYPE='text/x-shellscript'
241   elif [ "$EXT" == 'gz' ]; then
242     OUTPUT_FILE_TYPE='application/gzip'
243   elif [ "$EXT" == 'wgn' ]; then
244     OUTPUT_FILE_TYPE='application/gzip'
245   else
246     OUTPUT_FILE_TYPE='application/octet-stream'
247   fi
248
249
250   if [ "$MVN_DEPLOYMENT_TYPE" == 'SNAPSHOT' ]; then
251     SEND_TO="${REPO}/${MVN_PROJECT_GROUPID}/snapshots"
252   elif [ "$MVN_DEPLOYMENT_TYPE" == 'STAGING' ]; then
253     SEND_TO="${REPO}/{$MVN_PROJECT_GROUPID}/releases"
254   else
255     echo "Unreconfnized deployment type, quit"
256     exit
257   fi
258   if [ ! -z "$MVN_PROJECT_MODULEID" ]; then
259     SEND_TO="$SEND_TO/$MVN_PROJECT_MODULEID"
260   fi
261
262   echo "Sending ${OUTPUT_FILE} to Nexus: ${SEND_TO}"
263   curl -vkn --netrc-file "${NETRC}" --upload-file "${OUTPUT_FILE}" -X PUT -H "Content-Type: $OUTPUT_FILE_TYPE" "${SEND_TO}/${OUTPUT_FILE}-${MVN_PROJECT_VERSION}-${TIMESTAMP}"
264   curl -vkn --netrc-file "${NETRC}" --upload-file "${OUTPUT_FILE}" -X PUT -H "Content-Type: $OUTPUT_FILE_TYPE" "${SEND_TO}/${OUTPUT_FILE}-${MVN_PROJECT_VERSION}"
265   curl -vkn --netrc-file "${NETRC}" --upload-file "${OUTPUT_FILE}" -X PUT -H "Content-Type: $OUTPUT_FILE_TYPE" "${SEND_TO}/${OUTPUT_FILE}"
266 }
267
268
269
270 upload_wagons_and_type_yamls()
271 {
272   WAGONS=$(ls -1 ./*.wgn)
273   for WAGON in $WAGONS ; do
274     WAGON_NAME=$(echo "$WAGON" | cut -f1 -d '-')
275     WAGON_VERSION=$(echo "$WAGON" | cut -f2 -d '-')
276     WAGON_TYPEFILE=$(grep -rl "$WAGON_NAME" | grep yaml | head -1)
277    
278     upload_raw_file "$WAGON"
279     upload_raw_file "$WAGON_TYPEFILE"
280   done
281 }
282
283 upload_files_of_extension()
284 {
285   FILES=$(ls -1 ./*."$1")
286   for F in $FILES ; do
287     upload_raw_file "$F"
288   done
289 }
290
291
292 generate_pypirc_then_publish() 
293 {
294   set +x
295   USER=$(xpath -e "//servers/server[id='$MVN_PYPISERVER_SERVERID']/username/text()" "$SETTINGS_FILE")
296   PASS=$(xpath -e "//servers/server[id='$MVN_PYPISERVER_SERVERID']/password/text()" "$SETTINGS_FILE")
297
298   if [[ "$MVN_PYPISERVER_BASEURL" != */ ]]; then
299     MVN_PYPISERVER_BASEURL="${MVN_PYPISERVER_BASEURL}/"
300   fi
301  
302
303   cat > ~/.pypirc <<EOL
304 [distutils]
305 index-servers = 
306   $MVN_PYPISERVER_SERVERID
307  
308 [$MVN_PYPISERVER_SERVERID]
309 repository: $MVN_PYPISERVER_BASEURL
310 username: $USER
311 password: $PASS
312 EOL
313
314   # this may fail if a package of same version exists
315   python setup.py sdist register -r "$MVN_PYPISERVER_SERVERID" upload -r "$MVN_PYPISERVER_SERVERID"
316   set -x
317 }
318
319
320
321 build_and_push_docker()
322 {
323   IMAGENAME="onap/${FQDN}.${MVN_PROJECT_MODULEID}"
324   IMAGENAME=$(echo "$IMAGENAME" | sed -e 's/_*$//g' -e 's/\.*$//g')
325   IMAGENAME=$(echo "$IMAGENAME" | tr '[:upper:]' '[:lower:]')
326
327   # use the major and minor version of the MVN artifact version as docker image version
328   VERSION="${MVN_PROJECT_VERSION//[^0-9.]/}"
329   VERSION2=$(echo "$VERSION" | cut -f1-2 -d'.')
330
331   LFQI="${IMAGENAME}:${VERSION}-${TIMESTAMP}"
332   # build a docker image
333   docker build --rm -f ./Dockerfile -t "${LFQI}" ./
334
335   REPO=""
336   if [ $MVN_DEPLOYMENT_TYPE == "SNAPSHOT" ]; then
337      REPO=$MVN_DOCKERREGISTRY_DAILY
338   elif [ $MVN_DEPLOYMENT_TYPE == "STAGING" ]; then
339      # there seems to be no staging docker registry?  set to use SNAPSHOT also
340      #REPO=$MVN_DOCKERREGISTRY_RELEASE
341      REPO=$MVN_DOCKERREGISTRY_DAILY
342   else
343      echo "Fail to determine DEPLOYMENT_TYPE"
344      REPO=$MVN_DOCKERREGISTRY_DAILY
345   fi
346   echo "DEPLOYMENT_TYPE is: $MVN_DEPLOYMENT_TYPE, repo is $REPO"
347
348   if [ ! -z "$REPO" ]; then
349     USER=$(xpath -e "//servers/server[id='$REPO']/username/text()" "$SETTINGS_FILE")
350     PASS=$(xpath -e "//servers/server[id='$REPO']/password/text()" "$SETTINGS_FILE")
351     if [ -z "$USER" ]; then
352       echo "Error: no user provided"
353     fi
354     if [ -z "$PASS" ]; then
355       echo "Error: no password provided"
356     fi
357     [ -z "$PASS" ] && PASS_PROVIDED="<empty>" || PASS_PROVIDED="<password>"
358     echo docker login "$REPO" -u "$USER" -p "$PASS_PROVIDED"
359     docker login "$REPO" -u "$USER" -p "$PASS"
360
361     if [ $MVN_DEPLOYMENT_TYPE == "SNAPSHOT" ]; then
362       REPO="$REPO/snapshots"
363     elif [ $MVN_DEPLOYMENT_TYPE == "STAGING" ]; then
364       # there seems to be no staging docker registry?  set to use SNAPSHOT also
365       #REPO=$MVN_DOCKERREGISTRY_RELEASE
366       REPO="$REPO"
367     else
368       echo "Fail to determine DEPLOYMENT_TYPE"
369       REPO="$REPO/unknown"
370     fi
371
372     OLDTAG="${LFQI}"
373     PUSHTAGS="${REPO}/${IMAGENAME}:${VERSION2}-${TIMESTAMP} ${REPO}/${IMAGENAME}:${VERSION2} ${REPO}/${IMAGENAME}:${VERSION2}-latest"
374     for NEWTAG in ${PUSHTAGS}
375     do
376       echo "tagging ${OLDTAG} to ${NEWTAG}"
377       docker tag "${OLDTAG}" "${NEWTAG}"
378       echo "pushing ${NEWTAG}"
379       docker push "${NEWTAG}"
380       OLDTAG="${NEWTAG}"
381     done
382   fi
383
384 }
385
386
387