4 # ============LICENSE_START================================================
6 # =========================================================================
7 # Copyright (C) 2021-2022 Nordix Foundation.
8 # =========================================================================
9 # Licensed under the Apache License, Version 2.0 (the "License");
10 # you may not use this file except in compliance with the License.
11 # You may obtain a copy of the License at
13 # http://www.apache.org/licenses/LICENSE-2.0
15 # Unless required by applicable law or agreed to in writing, software
16 # distributed under the License is distributed on an "AS IS" BASIS,
17 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 # See the License for the specific language governing permissions and
19 # limitations under the License.
20 # ============LICENSE_END==================================================
25 SCRIPT_NAME=$(basename "$0")
27 release_data_file="./pf_release_data.csv"
29 # Use the bash internal OSTYPE variable to check for MacOS
30 if [[ "$OSTYPE" == "darwin"* ]]
40 echo "$SCRIPT_NAME - updates the inter-repo references in Policy Framework POM files"
42 echo " usage: $SCRIPT_NAME [-options]"
45 echo " -h - this help message"
46 echo " -d data_file - the policy release data file to use, generated by the 'getReleaseData.sh' script,"
47 echo " defaults to '$release_data_file'"
48 echo " -l location - the location of the policy framework repos on the file system,"
49 echo " defaults to '$repo_location'"
50 echo " -r repo - the policy repo to update"
51 echo " -p - update policy/parent references"
52 echo " -c - update policy/common references"
53 echo " -m - update policy/model references"
54 echo " -o - update policy/drools-pdp references"
55 echo " -x - update policy/apex-pdp references"
56 echo " -k - update docker base images in Dockerfiles"
57 echo " -f - update release data in policy parent"
58 echo " -s - update release references to snapshot references,"
59 echo " if omitted, snapshot references are updated to release references"
62 echo " $SCRIPT_NAME -pcm -r policy/pap"
63 echo " update the parent, common, and models references of policy/pap"
64 echo " to the current released version"
66 echo " $SCRIPT_NAME -c -m -s -r policy/api"
67 echo " update the common and models references of policy/api"
68 echo " to the current snapshot version"
75 update_drools_pdp=false
81 while getopts "hd:l:r:pcmoxkfs" opt
88 release_data_file=$OPTARG
94 specified_repo=$OPTARG
106 update_drools_pdp=true
129 echo "no arguments were specified"
133 if [[ -z "$repo_location" ]]
135 echo "policy repo location not specified on -l flag"
139 if ! [ -d "$repo_location" ]
141 echo "policy repo location '$repo_location' not found"
145 if [[ -z "$release_data_file" ]]
147 echo "policy release data file not specified on -d flag"
151 if ! [ -f "$release_data_file" ]
153 echo "policy release data file '$release_data_file' not found"
157 if [ -z "$specified_repo" ]
159 echo "repo not specified on -r flag"
163 # shellcheck disable=SC2034
164 # shellcheck disable=SC2046
165 read -r parent_repo \
166 parent_latest_released_tag \
167 parent_latest_snapshot_tag \
168 parent_changed_files \
169 parent_docker_images \
170 <<< $(grep policy/parent "$release_data_file" | tr ',' ' ' )
172 # shellcheck disable=SC2034
173 # shellcheck disable=SC2046
174 read -r common_repo \
175 common_latest_released_tag \
176 common_latest_snapshot_tag \
177 common_changed_files \
178 common_docker_images \
179 <<< $(grep policy/common "$release_data_file" | tr ',' ' ' )
181 # shellcheck disable=SC2034
182 # shellcheck disable=SC2046
183 read -r docker_repo \
184 docker_latest_released_tag \
185 docker_latest_snapshot_tag \
186 docker_changed_files \
187 docker_docker_images \
188 <<< $(grep policy/docker "$release_data_file" | tr ',' ' ' )
190 # shellcheck disable=SC2034
191 # shellcheck disable=SC2046
192 read -r models_repo \
193 models_latest_released_tag \
194 models_latest_snapshot_tag \
195 models_changed_files \
196 models_docker_images \
197 <<< $(grep policy/models "$release_data_file" | tr ',' ' ' )
199 # shellcheck disable=SC2034
200 # shellcheck disable=SC2046
201 read -r drools_pdp_repo \
202 drools_pdp_latest_released_tag \
203 drools_pdp_latest_snapshot_tag \
204 drools_pdp_changed_files \
205 drools_pdp_docker_images \
206 <<< $(grep policy/drools-pdp "$release_data_file" | tr ',' ' ' )
208 # shellcheck disable=SC2034
209 # shellcheck disable=SC2046
210 read -r apex_pdp_repo \
211 apex_pdp_latest_released_tag \
212 apex_pdp_latest_snapshot_tag \
213 apex_pdp_changed_files \
214 apex_pdp_docker_images \
215 <<< $(grep policy/apex-pdp "$release_data_file" | tr ',' ' ' )
217 # shellcheck disable=SC2034
218 # shellcheck disable=SC2046
219 read -r target_repo \
220 target_latest_released_tag \
221 target_latest_snapshot_tag \
222 target_changed_files \
223 target_docker_images \
224 <<< $(grep "$specified_repo" "$release_data_file" | tr ',' ' ' )
226 if [ -z "$target_repo" ]
228 echo "specified repo '$specified_repo' not found in policy release data file '$release_data_file'"
232 if [ ! "$specified_repo" = "$target_repo" ]
234 echo "specified repo '$specified_repo' does not match target repo '$target_repo'"
238 if [ "$update_parent" = true ]
240 if [ "$specified_repo" = "policy/parent" ]
242 if [ "$update_snapshot" = true ]
244 major_version=$(echo "$parent_latest_released_tag" | $SED -E 's/^([0-9]*)\.[0-9]*\.[0-9]*$/\1/')
245 minor_version=$(echo "$parent_latest_released_tag" | $SED -E 's/^[0-9]*\.([0-9]*)\.[0-9]*$/\1/')
246 patch_version=$(echo "$parent_latest_released_tag" | $SED -E 's/^[0-9]*\.[0-9]*\.([0-9]*)$/\1/')
247 new_patch_version=$(("$patch_version"+1))
249 new_snapshot_tag="$major_version"."$minor_version"."$new_patch_version"-SNAPSHOT
251 echo updating policy parent reference to "$new_snapshot_tag" on "$repo_location/$target_repo" . . .
253 "s/<version.parent.resources>.*<\/version.parent.resources>/<version.parent.resources>$new_snapshot_tag<\/version.parent.resources>/" \
254 "$repo_location/policy/parent/integration/pom.xml"
257 next_release_version=${parent_latest_snapshot_tag%-*}
259 echo "updating policy parent reference to $next_release_version on $repo_location/$target_repo . . ."
261 "s/<version.parent.resources>.*<\/version.parent.resources>/<version.parent.resources>$next_release_version<\/version.parent.resources>/" \
262 "$repo_location/policy/parent/integration/pom.xml"
266 if [ "$update_snapshot" = true ]
268 echo "updating policy parent reference to $parent_latest_snapshot_tag on $repo_location/$target_repo . . ."
270 -f "$repo_location/$target_repo/pom.xml" \
271 -g org.onap.policy.parent \
273 -v "$parent_latest_snapshot_tag"
276 echo "updating policy parent reference to $parent_latest_released_tag on $repo_location/$target_repo . . ."
278 -f "$repo_location/$target_repo/pom.xml" \
279 -g org.onap.policy.parent \
281 -v "$parent_latest_released_tag"
285 if [[ "$result_code" -eq 0 ]]
287 echo "policy parent reference updated on $repo_location/$target_repo"
289 echo "policy parent reference update failed on $repo_location/$target_repo"
294 if [ "$update_common" = true ]
296 if [ "$update_snapshot" = true ]
298 echo "updating policy common reference to $common_latest_snapshot_tag on $repo_location/$target_repo . . ."
300 -e "s/<policy.common.version>.*<\/policy.common.version>/<policy.common.version>$common_latest_snapshot_tag<\/policy.common.version>/" \
301 -e "s/<version.policy.common>.*<\/version.policy.common>/<version.policy.common>$common_latest_snapshot_tag<\/version.policy.common>/" \
302 "$repo_location/$target_repo/pom.xml"
305 echo "updating policy common reference to $common_latest_released_tag on $repo_location/$target_repo . . ."
307 -e "s/<policy.common.version>.*<\/policy.common.version>/<policy.common.version>$common_latest_released_tag<\/policy.common.version>/" \
308 -e "s/<version.policy.common>.*<\/version.policy.common>/<version.policy.common>$common_latest_released_tag<\/version.policy.common>/" \
309 "$repo_location/$target_repo/pom.xml"
312 if [[ "$result_code" -eq 0 ]]
314 echo "policy common reference updated on $repo_location/$target_repo"
316 echo "policy common reference update failed on $repo_location/$target_repo"
321 if [ "$update_models" = true ]
323 if [ "$update_snapshot" = true ]
325 echo "updating policy models reference to $models_latest_snapshot_tag on $repo_location/$target_repo . . ."
327 -e "s/<policy.models.version>.*<\/policy.models.version>/<policy.models.version>$models_latest_snapshot_tag<\/policy.models.version>/" \
328 -e "s/<version.policy.models>.*<\/version.policy.models>/<version.policy.models>$models_latest_snapshot_tag<\/version.policy.models>/" \
329 "$repo_location/$target_repo/pom.xml"
332 echo "updating policy models reference to $models_latest_released_tag on $repo_location/$target_repo . . ."
334 -e "s/<policy.models.version>.*<\/policy.models.version>/<policy.models.version>$models_latest_released_tag<\/policy.models.version>/" \
335 -e "s/<version.policy.models>.*<\/version.policy.models>/<version.policy.models>$models_latest_released_tag<\/version.policy.models>/" \
336 "$repo_location/$target_repo/pom.xml"
339 if [[ "$result_code" -eq 0 ]]
341 echo "policy models reference updated on $repo_location/$target_repo"
343 echo "policy models reference update failed on $repo_location/$target_repo"
348 if [ "$update_drools_pdp" = true ]
350 if [ "$update_snapshot" = true ]
352 echo "updating policy drools-pdp reference to $drools_pdp_latest_snapshot_tag on $repo_location/$target_repo . . ."
354 -e "s/<policy.drools-pdp.version>.*<\/policy.drools-pdp.version>/<policy.drools-pdp.version>$drools_pdp_latest_snapshot_tag<\/policy.drools-pdp.version>/" \
355 -e "s/<version.policy.drools-pdp>.*<\/version.policy.drools-pdp>/<version.policy.drools-pdp>$drools_pdp_latest_snapshot_tag<\/version.policy.drools-pdp>/" \
356 "$repo_location/$target_repo/pom.xml"
359 echo "updating policy drools-pdp reference to $drools_pdp_latest_released_tag on $repo_location/$target_repo . . ."
361 -e "s/<policy.drools-pdp.version>.*<\/policy.drools-pdp.version>/<policy.drools-pdp.version>$drools_pdp_latest_released_tag<\/policy.drools-pdp.version>/" \
362 -e "s/<version.policy.drools-pdp>.*<\/version.policy.drools-pdp>/<version.policy.drools-pdp>$drools_pdp_latest_released_tag<\/version.policy.drools-pdp>/" \
363 "$repo_location/$target_repo/pom.xml"
366 if [[ "$result_code" -eq 0 ]]
368 echo "policy drools-pdp reference updated on $repo_location/$target_repo"
370 echo "policy drools-pdp reference update failed on $repo_location/$target_repo"
375 if [ "$update_apex_pdp" = true ]
377 if [ "$update_snapshot" = true ]
379 echo "updating policy apex-pdp reference to $apex_pdp_latest_snapshot_tag on $repo_location/$target_repo . . ."
381 -e "s/<policy.apex-pdp.version>.*<\/policy.apex-pdp.version>/<policy.apex-pdp.version>$apex_pdp_latest_snapshot_tag<\/policy.apex-pdp.version>/" \
382 -e "s/<version.policy.apex-pdp>.*<\/version.policy.apex-pdp>/<version.policy.apex-pdp>$apex_pdp_latest_snapshot_tag<\/version.policy.apex-pdp>/" \
383 "$repo_location/$target_repo/pom.xml"
386 echo "updating policy apex-pdp reference to $apex_pdp_latest_released_tag on $repo_location/$target_repo . . ."
388 -e "s/<policy.apex-pdp.version>.*<\/policy.apex-pdp.version>/<policy.apex-pdp.version>$apex_pdp_latest_released_tag<\/policy.apex-pdp.version>/" \
389 -e "s/<version.policy.apex-pdp>.*<\/version.policy.apex-pdp>/<version.policy.apex-pdp>$apex_pdp_latest_released_tag<\/version.policy.apex-pdp>/" \
390 "$repo_location/$target_repo/pom.xml"
393 if [[ "$result_code" -eq 0 ]]
395 echo "policy apex-pdp reference updated on $repo_location/$target_repo"
397 echo "policy apex-pdp reference update failed on $repo_location/$target_repo"
402 if [ "$update_docker" = true ] && [ "$target_docker_images" != "" ]
404 echo "updating docker base images to version $docker_latest_released_tag on repo $repo_location/$target_repo . . ."
405 find "$repo_location/$target_repo" \
408 if [ "$update_snapshot" == true ]
410 find "$repo_location/$target_repo" \
412 -exec $SED -r -i "s/^(FROM onap\/policy-j[d|r][k|e]-alpine:)[0-9]*.[0-9]*.[0-9]*$/\1$docker_latest_snapshot_tag/" {} \;
415 find "$repo_location/$target_repo" \
417 -exec $SED -r -i "s/^(FROM onap\/policy-j[d|r][k|e]-alpine:)[0-9]*.[0-9]*.[0-9]*$/\1$docker_latest_released_tag/" {} \;
421 if [[ "$result_code" -eq 0 ]]
423 echo "docker base images updated on $repo_location/$target_repo"
425 echo "docker base images update failed on $repo_location/$target_repo"
430 if [ "$update_file" = true ]
432 if [ ! "$target_repo" = "policy/parent" ]
434 echo "update of data file can only be done on the policy/parent repo"
438 echo "updating release data at $repo_location/$target_repo/integration/src/main/resources/release . . ."
439 cp "$release_data_file" "$repo_location/$target_repo"/integration/src/main/resources/release
440 echo "updated release data at $repo_location/$target_repo/integration/src/main/resources/release"