From 3b0a998a1a3c8b7bd4b896d7d9192961d5a0841d Mon Sep 17 00:00:00 2001 From: Jesse Alford Date: Fri, 28 Aug 2020 14:27:06 -0700 Subject: [PATCH] Update docs with dual-pass interp info Signed-off-by: Kira Boyle Co-authored-by: Kira Boyle --- docs/interpolate/README.md | 54 +++++++++++++++++-- .../templates/interpolate/ADDITIONAL_INFO.md | 54 +++++++++++++++++-- 2 files changed, 102 insertions(+), 6 deletions(-) diff --git a/docs/interpolate/README.md b/docs/interpolate/README.md index 10c73e356..2ee37b075 100644 --- a/docs/interpolate/README.md +++ b/docs/interpolate/README.md @@ -47,7 +47,6 @@ Global Flags: ``` ## Interpolation - Given a template file with a variable reference: ```yaml @@ -55,7 +54,8 @@ Given a template file with a variable reference: key: ((variable_name)) ``` -Values can be provided from a separate variables yaml file (`--vars-file`) or from environment variables (`--vars-env`). +Values can be provided from a separate variables yaml file (`--vars-file`) +or from environment variables (`--vars-env`). To load variables from a file use the `--vars-file` flag. @@ -81,4 +81,52 @@ OM_VAR_variable_name=some_value om interpolate \ The interpolation support is inspired by similar features in BOSH. You can [refer to the BOSH documentation](https://bosh.io/docs/cli-int/) for details on how interpolation -is performed. \ No newline at end of file +is performed. + +One significant difference from similar features in BOSH +and Concourse `fly` is that `om` performs _dual-pass_ interpolation. +That is, the template is interpolated (including applying ops files) once, +and then the output of that interpolation is interpolated again, +using the same arguments (except for Ops Files, +which are not necessarily idempotent). + +This allows the use of _mapping variables_, +variables that contain a value that is a variable in turn. +Mapping variables are useful for mapping +between programmatically-generated variable names +such as those created by `om config-template` and `om staged-director-config`, +and credentials that may be used in multiple places, +such as database passwords. + +Such config might look something like this: + +``` +cc: + database-password: ((cc_database_password)) +uaa: + database-password: ((uaa_database_password)) +``` + +In such cases, a vars-file like this can encode the relationship: + +``` +--- +cc_database_password: ((sql_password)) +uaa_database_password: ((sql_password)) +``` + +Assuming the value of `sql_password` is available to the interpolation, +it will be present in the final output, +like so: + +``` +cc: + database-password: actualsqlpasswordverysecure +uaa: + database-password: actualsqlpasswordverysecure +``` + +This feature generally shouldn't interfere with interpolation +as it would normally work in BOSH. +If you encounter any situation where this difference is an unwelcome surprise, +please open an issue; we were unable to think of any. diff --git a/docsgenerator/templates/interpolate/ADDITIONAL_INFO.md b/docsgenerator/templates/interpolate/ADDITIONAL_INFO.md index c16a29408..509054008 100644 --- a/docsgenerator/templates/interpolate/ADDITIONAL_INFO.md +++ b/docsgenerator/templates/interpolate/ADDITIONAL_INFO.md @@ -1,5 +1,4 @@ ## Interpolation - Given a template file with a variable reference: ```yaml @@ -7,7 +6,8 @@ Given a template file with a variable reference: key: ((variable_name)) ``` -Values can be provided from a separate variables yaml file (`--vars-file`) or from environment variables (`--vars-env`). +Values can be provided from a separate variables yaml file (`--vars-file`) +or from environment variables (`--vars-env`). To load variables from a file use the `--vars-file` flag. @@ -33,4 +33,52 @@ OM_VAR_variable_name=some_value om interpolate \ The interpolation support is inspired by similar features in BOSH. You can [refer to the BOSH documentation](https://bosh.io/docs/cli-int/) for details on how interpolation -is performed. \ No newline at end of file +is performed. + +One significant difference from similar features in BOSH +and Concourse `fly` is that `om` performs _dual-pass_ interpolation. +That is, the template is interpolated (including applying ops files) once, +and then the output of that interpolation is interpolated again, +using the same arguments (except for Ops Files, +which are not necessarily idempotent). + +This allows the use of _mapping variables_, +variables that contain a value that is a variable in turn. +Mapping variables are useful for mapping +between programmatically-generated variable names +such as those created by `om config-template` and `om staged-director-config`, +and credentials that may be used in multiple places, +such as database passwords. + +Such config might look something like this: + +``` +cc: + database-password: ((cc_database_password)) +uaa: + database-password: ((uaa_database_password)) +``` + +In such cases, a vars-file like this can encode the relationship: + +``` +--- +cc_database_password: ((sql_password)) +uaa_database_password: ((sql_password)) +``` + +Assuming the value of `sql_password` is available to the interpolation, +it will be present in the final output, +like so: + +``` +cc: + database-password: actualsqlpasswordverysecure +uaa: + database-password: actualsqlpasswordverysecure +``` + +This feature generally shouldn't interfere with interpolation +as it would normally work in BOSH. +If you encounter any situation where this difference is an unwelcome surprise, +please open an issue; we were unable to think of any.