|
@ -196,7 +196,7 @@ export -f file_put |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_get_docker_compose_links() { |
|
|
_get_docker_compose_links() { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
links charm charm_part master_charm |
|
|
links charm charm_part master_charm |
|
|
if [ -z "$service" ]; then |
|
|
if [ -z "$service" ]; then |
|
|
print_syntax_error "$FUNCNAME: Please specify a service as first argument." |
|
|
print_syntax_error "$FUNCNAME: Please specify a service as first argument." |
|
@ -227,7 +227,7 @@ _get_docker_compose_links() { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_get_docker_compose_opts() { |
|
|
_get_docker_compose_opts() { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
links charm charm_part master_charm |
|
|
links charm charm_part master_charm |
|
|
if [ -z "$service" ]; then |
|
|
if [ -z "$service" ]; then |
|
|
print_syntax_error "$FUNCNAME: Please specify a service as first argument." |
|
|
print_syntax_error "$FUNCNAME: Please specify a service as first argument." |
|
@ -255,7 +255,7 @@ _get_docker_compose_opts() { |
|
|
## Some metadata.yml (of subordinates) will indeed modify other |
|
|
## Some metadata.yml (of subordinates) will indeed modify other |
|
|
## services than themselves. |
|
|
## services than themselves. |
|
|
_get_docker_compose_service_mixin() { |
|
|
_get_docker_compose_service_mixin() { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" links charm charm_part |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" links charm charm_part |
|
|
if [ -z "$service" ]; then |
|
|
if [ -z "$service" ]; then |
|
|
print_syntax_error "$FUNCNAME: Please specify a service as first argument." |
|
|
print_syntax_error "$FUNCNAME: Please specify a service as first argument." |
|
|
return 1 |
|
|
return 1 |
|
@ -286,8 +286,7 @@ _get_docker_compose_service_mixin() { |
|
|
merge_yaml_str "$links_yaml" "$charm_yaml" "$docker_compose_options" |
|
|
merge_yaml_str "$links_yaml" "$charm_yaml" "$docker_compose_options" |
|
|
else |
|
|
else |
|
|
echo "$links_yaml" |
|
|
echo "$links_yaml" |
|
|
fi > "$cache_file" |
|
|
|
|
|
cat "$cache_file" |
|
|
|
|
|
|
|
|
fi | tee "$cache_file" |
|
|
} |
|
|
} |
|
|
export -f _get_docker_compose_service_mixin |
|
|
export -f _get_docker_compose_service_mixin |
|
|
|
|
|
|
|
@ -299,7 +298,7 @@ export -f _get_docker_compose_service_mixin |
|
|
## @export |
|
|
## @export |
|
|
## @cache: !system !nofail +stdout |
|
|
## @cache: !system !nofail +stdout |
|
|
get_docker_compose () { |
|
|
get_docker_compose () { |
|
|
local cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" entries services service |
|
|
|
|
|
|
|
|
local cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" entries services service start |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
cat "$cache_file" |
|
|
cat "$cache_file" |
|
@ -347,7 +346,7 @@ export -f get_docker_compose |
|
|
|
|
|
|
|
|
## XXXvlab: a lot to be done to cache the results |
|
|
## XXXvlab: a lot to be done to cache the results |
|
|
get_compose_service_def () { |
|
|
get_compose_service_def () { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
cat "$cache_file" |
|
|
cat "$cache_file" |
|
@ -378,7 +377,7 @@ export -f get_compose_service_def |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get_service_charm () { |
|
|
get_service_charm () { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
cat "$cache_file" |
|
|
cat "$cache_file" |
|
@ -419,7 +418,7 @@ export -f get_service_def |
|
|
|
|
|
|
|
|
## Return the base docker image name of a service |
|
|
## Return the base docker image name of a service |
|
|
service_base_docker_image() { |
|
|
service_base_docker_image() { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
master_charm charm service_image service_build service_dockerfile |
|
|
master_charm charm service_image service_build service_dockerfile |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
@ -597,7 +596,7 @@ export -f array_member |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get_charm_relation_def () { |
|
|
get_charm_relation_def () { |
|
|
local charm="$1" relation_name="$2" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local charm="$1" relation_name="$2" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
relation_def metadata |
|
|
relation_def metadata |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
@ -612,7 +611,7 @@ export -f get_charm_relation_def |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get_charm_tech_dep_orientation_for_relation() { |
|
|
get_charm_tech_dep_orientation_for_relation() { |
|
|
local charm="$1" relation_name="$2" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local charm="$1" relation_name="$2" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
relation_def metadata value |
|
|
relation_def metadata value |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
@ -630,7 +629,7 @@ export -f get_charm_tech_dep_orientation_for_relation |
|
|
## Use compose file to get deps, and relation definition in metadata.yml |
|
|
## Use compose file to get deps, and relation definition in metadata.yml |
|
|
## for tech-dep attribute. |
|
|
## for tech-dep attribute. |
|
|
get_service_deps() { |
|
|
get_service_deps() { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
cat "$cache_file" |
|
|
cat "$cache_file" |
|
@ -714,8 +713,7 @@ get_ordered_service_dependencies() { |
|
|
fi |
|
|
fi |
|
|
done |
|
|
done |
|
|
i=$((i + 1)) |
|
|
i=$((i + 1)) |
|
|
done > "$cache_file" |
|
|
|
|
|
cat "$cache_file" |
|
|
|
|
|
|
|
|
done | tee "$cache_file" |
|
|
} |
|
|
} |
|
|
export -f get_ordered_service_dependencies |
|
|
export -f get_ordered_service_dependencies |
|
|
|
|
|
|
|
@ -950,7 +948,7 @@ export -f _run_service_relation |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get_compose_relations () { |
|
|
get_compose_relations () { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" relation_name relation_def |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" relation_name relation_def |
|
|
|
|
|
|
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
@ -1103,7 +1101,7 @@ export -f _run_service_action_relation |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get_relation_data_dir() { |
|
|
get_relation_data_dir() { |
|
|
local charm="$1" target_charm="$2" relation_name="$3" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" |
|
|
|
|
|
|
|
|
local charm="$1" target_charm="$2" relation_name="$3" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
cat "$cache_file" |
|
|
cat "$cache_file" |
|
@ -1149,7 +1147,7 @@ export -f get_relation_data_file |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
has_service_action () { |
|
|
has_service_action () { |
|
|
local service="$1" action="$2" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local service="$1" action="$2" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
target_script charm target_charm |
|
|
target_script charm target_charm |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
@ -1204,7 +1202,7 @@ export -f run_service_action |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get_compose_relation_config() { |
|
|
get_compose_relation_config() { |
|
|
local service=$1 relation_config cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" |
|
|
|
|
|
|
|
|
local service=$1 relation_config cache_file="$state_tmpdir/$FUNCNAME.cache.$1" |
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
# debug "$FUNCNAME: cache hit ($*)" |
|
|
cat "$cache_file" |
|
|
cat "$cache_file" |
|
@ -1242,7 +1240,7 @@ export -f get_compose_relation_config |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_get_master_charm_for_service() { |
|
|
_get_master_charm_for_service() { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
charm metadata requires master_charm target_charm target_service service_def |
|
|
charm metadata requires master_charm target_charm target_service service_def |
|
|
|
|
|
|
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
@ -1308,7 +1306,7 @@ export -f _get_master_charm_for_service |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_get_top_master_charm_for_service() { |
|
|
_get_top_master_charm_for_service() { |
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local service="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
current_service |
|
|
current_service |
|
|
|
|
|
|
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
@ -1345,7 +1343,7 @@ export -f get_charm_metadata |
|
|
## docker-compose entry (thinking of subordinates). The result |
|
|
## docker-compose entry (thinking of subordinates). The result |
|
|
## will be merge with master charms. |
|
|
## will be merge with master charms. |
|
|
get_docker_compose_mixin_from_metadata() { |
|
|
get_docker_compose_mixin_from_metadata() { |
|
|
local charm="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$(echo "$*" | md5_compat)" \ |
|
|
|
|
|
|
|
|
local charm="$1" cache_file="$state_tmpdir/$FUNCNAME.cache.$1" \ |
|
|
metadata_file metadata volumes docker_compose subordinate image |
|
|
metadata_file metadata volumes docker_compose subordinate image |
|
|
|
|
|
|
|
|
if [ -e "$cache_file" ]; then |
|
|
if [ -e "$cache_file" ]; then |
|
|