ownCloud
Toggle Dark/Light/Auto mode Toggle Dark/Light/Auto mode Toggle Dark/Light/Auto mode Back to homepage

Envvar Naming Scopes

The scope of an environment variable can be derived from its name. Therefore, it is important to follow the correct naming scheme to enable easy and proper identification. This is important when either:

  • a new local envvar is introduced.
  • a new global envvar is added to an existing local envvar.

Envvar Definition

  • A variable that is only used in a particular service is a local envvar.
  • A variable that is used in more than one service is a global envvar.
  • If applicapable, a global envvar has a local counterpart.
  • Variables that are not limited to any service are by definition global.

Naming Scope

Local Envvars

A local envvar always starts with the service name such as POSTPROCESSING_LOG_FILE.

Global Envvars

A global envvar always starts with OCIS_ like OCIS_LOG_FILE.

Note that this envvar is the global representation of the local example from above.

To get a list of global envvars used in all services, see the Global Environment Variables table in the ocis admin documentation.

Lifecycle of Envvars

The envvar struct tag contains at maximum the following key/value pairs to document the lifecycle of a config variable:

  • introductionVersion
  • deprecationVersion
  • removalVersion
  • deprecationInfo
  • deprecationReplacement

Introduce new Envvars

If a new envvar is introduced, only the introductionVersion is required.

  • During development, set introductionVersion to a short, alphabetic code name that represents the upcoming release (e.g. releaseX).
  • This identifier stays constant until the release receives its final production semantic-version number.

The docs helper scripts render these alphabetic identifiers verbatim. They appear in the next (master) branch of the admin docs as rendered here.

Once the release is cut, before tagging, replace them with the actual semantic version (e.g. releaseX7.2.0).

A new production version MUST NOT contain any alphabetic identifyers but the semantic version only.

Adding Envvars to Existing Ones

If an envvar has been introduced with a particular version, the introductionVersion gets a value accordingly. If an additional envvar like a global one is added to this existing envvar later on, the introduction version will not be changed.

Deprecate Existing Envvars

See the deprecation rules documentation for more details.

Separating Multiple Envvars

When multiple envvars are defined for one purpose like a global and local one, use ; (semicolon) to properly separate the envvars in go code. Though it is possible to separate with , (comma) according go rules, the current implementation of the docs generation process only recognizes semicolons as separator.