Skip to content

OlaresManifest Specification

Every Olares Application Chart should include an OlaresManifest.yaml file in the root directory. OlaresManifest.yaml provides all the essential information about an Olares App. Both the Olares Market protocol and the Olares depend on this information to distribute and install applications.

NOTE

Latest Olares Manifest version: 0.11.0

  • Removed deprecated fields of sysData
  • Updated the example of shared app
  • Added the apiVersion
  • Added the sharedEntrance section
Changelog

0.10.0

  • Modified the categories field
  • Added the provider field in the Permission section
  • Added the Provider section, to allow apps to expose specific service interfaces within the cluster
  • Removed some deprecated fields from the Spec section
  • Removed some deprecated fields from the Option section
  • Added the allowMultipleInstall field, allowing the app to be installed as multiple independent instances
  • Added the Envs section, to define environment variables required by the application

0.9.0

  • Added a conflict field in options to declare incompatible applications
  • Removed analytics field in options
  • Modified the format of the tailscale section
  • Added a allowedOutboundPorts field to allow non-http protocol external access through the specified port
  • Modified the format of the ports section

0.8.3

  • Add a mandatory field in the dependencies section for dependent applications required for the installation
  • Add tailscaleAcls section to permit applications to open specified ports via Tailscale

0.8.2

  • Add a runAsUser option to force the app to run under non root user

0.8.1

  • Add a ports section to specify exposed ports for UDP or TCP

0.7.1

  • Add new authLevel value internal
  • Change spec>language to spec>locale and support i18n

Here's an example of what a OlaresManifest.yaml file might look like:

OlaresManifest.yaml Example
yaml
olaresManifest.version: '0.10.0'
olaresManifest.type: app
metadata:
  name: helloworld
  title: Hello World
  description: app helloworld
  icon: https://app.cdn.olares.com/appstore/default/defaulticon.webp
  version: 0.0.1
  categories:
  - Utilities
entrances:
- name: helloworld
  port: 8080
  title: Hello World
  host: helloworld
  icon: https://app.cdn.olares.com/appstore/default/defaulticon.webp
  authLevel: private
permission:
  appCache: true
  appData: true
  userData:
  - Home/Documents/
  - Home/Pictures/
  - Home/Downloads/BTDownloads/
spec:
  versionName: '0.0.1'
  featuredImage: https://link.to/featured_image.webp
  promoteImage:
  - https://link.to/promote_image1.webp
  - https://link.to/promote_image2.webp
  fullDescription: |
    A full description of your app.
  upgradeDescription: |
    Describe what is new in this upgraded version.
  developer: Developer's Name
  website: https://link.to.your.website
  sourceCode: https://link.to.sourceCode
  submitter: Submitter's Name
  locale:
  - en
  doc: https://link.to.documents
  supportArch:
  - amd64
  limitedCpu: 1000m
  limitedMemory: 1000Mi
  requiredCpu: 50m
  requiredDisk: 50Mi
  requiredMemory: 12Mi

options:
  dependencies:
  - name: olares
    type: system
    version: '>=0.1.0'

olaresManifest.type

  • Type: string
  • Accepted Value: app, recommend, middleware

Olares currently supports 3 types of applications, each requiring different fields. This document uses app as an example to explain each field. For information on other types, please refer to the corresponding configuration guide.

NOTE

recommend apps will not be listed in the Olares Market, but you can install recommendation algorithms for Wise by uploading a custom Chart.

olaresManifest.version

  • Type: string

As Olares evolves, the configuration specification of OlaresManifest.yaml may change. You can identify whether these changes will affect your application by checking the olaresManifest.version. The olaresManifest.version consists of three integers separated by periods.

  • An increase in the first digit indicates the introduction of incompatible configuration items. Applications that haven't updated their OlaresManifest.yaml will be unable to distribute or install.
  • An increase in the second digit signifies changes in the mandatory fields for distribution and installation. However, the Olares remains compatible with the application distribution and installation of previous configuration versions. We recommend developers to promptly update and upgrade the application's OlaresManifest.yaml file.
  • A change in the third digit does not affect the application's distribution and installation.

Developers can use 1-3 digit version numbers to indicate the application's configuration version. Here are some examples of valid versions:

yaml
olaresManifest.version: 1
olaresManifest.version: 1.1.0
olaresManifest.version: '2.2'
olaresManifest.version: "3.0.122"

apiVersion

  • Type: string
  • Optional
  • Accepted Value: v1,v2
  • Default: v1

For shared applications, use version v2, which supports multiple subcharts in a single OAC. For other applications, use v1.

Metadata

Basic information about the app shown in the system and Olares Market.

Example

yaml
metadata:
  name: nextcloud
  title: Nextcloud
  description: The productivity platform that keeps you in control
  icon: https://app.cdn.olares.com/appstore/nextcloud/icon.png
  version: 0.0.2
  categories:
  - Utilities
  - Productivity

name

  • Type: string
  • Accepted Value: ^[a-z][a-z0-9]{0,29}$

App’s namespace in Olares, lowercase alphanumeric characters only. It can be up to 30 characters, and needs to be consistent with FolderName and name field in Chart.yaml.

title

  • Type: string

The title of your app shown in the Olares Market. Must be within 30 characters.

description

  • Type: string

A short description appears below app title in the Olares Market.

icon

  • Type: url

Your app icon that appears in the Olares Market.

The app's icon must be a PNG or WEBP format file, up to 512 KB, with a size of 256x256 px.

version

  • Type: string

The Chart Version of the application. It should be incremented each time the content in the Chart changes. It should follow the Semantic Versioning 2.0.0 and needs to be consistent with the version field in Chart.yaml.

categories

  • Type: list<string>

Used to display your app on different category page in Olares Market.

Accepted Value for OS 1.11:

  • Blockchain, Utilities, Social Network, Entertainment, Productivity

Accepted Value for OS 1.12:

  • Creativity
  • Productivity_v112 (displayed as Productivity)
  • Developer Tools
  • Fun
  • Lifestyle
  • Utilities_v112 (displayed as Utilities)
  • AI

NOTE

Olares Market categories were updated in OS 1.12.0. To ensure your app is compatible with both versions 1.11 and 1.12, include category values for both versions in your configuration.

Entrances

The entrances (up to 10) that users can use to access the app. At least 1 is required.

Example

yaml
entrances:
- name: a
  host: firefox
  port: 3000
  title: Firefox
  authLevel: public
  invisible: false
- name: b
  host: firefox
  port: 3001
  title: admin

name

  • Type: string

  • Accepted Value: [a-z]([-a-z0-9]*[a-z0-9])?

    Name of the Entrance. It can be up to 63 characters, and needs to be unique in an app.

port

  • Type: int
  • Accepted Value: 0-65535

host

  • Type: string

  • Accepted Value: [a-z]([-a-z0-9]*[a-z0-9])?

    Ingress name of current entrance, lowercase alphanumeric characters and - only. It can be up to 63 characters.

title

  • Type: string

Title that appears in the Olares desktop after installed. It can be up to 30 characters.

icon

  • Type: url
  • Optional

Icon that appears in the Olares desktop after installed. The app's icon must be a PNG or WEBP format file, up to 512 KB, with a size of 256x256 px.

authLevel

  • Type: string
  • Accepted Value: public, private, internal
  • Default: private
  • Optional

Specify the authentication level of the entrance.

  • Public: Accessible by anyone on the Internet without restrictions.
  • Private: Requires authorization for access from both internal and external networks.
  • Internal: Requires authorization for access from external networks. No authentication is required when accessing from within the internal network (via LAN/VPN).

invisible

  • Type: boolean
  • Default: false
  • Optional

When invisible is true, the entrance will not be displayed on the Olares desktop.

openMethod

  • Type: string
  • Accepted Value: default, iframe, window
  • Default: default
  • Optional

Explicitly defines how to open this entrance in Desktop.

The iframe creates a new window within the desktop window through an iframe. The window opens a new tab in the browser. The default follows the system setting, which is iframe by default.

windowPushState

  • Type: boolean
  • Default: false
  • Optional

When embedding the application in an iframe on the desktop, the application's URL may change dynamically. Due to browser's same-origin policy, the desktop (parent window) cannot directly detect these changes in the iframe URL. Consequently, if you reopen the application tab, it will display the initial URL instead of the updated one.

To ensure a seamless user experience, you can enable this option by setting it to true. This action prompts the gateway to automatically inject the following code into the iframe. This code sends an event to the parent window (desktop) whenever the iframe's URL changes. As a result, the desktop can track URL changes and open the correct page.

Code
Javascript
<script>
  (function () {
    if (window.top == window) {
        return;
    }
    const originalPushState = history.pushState;
    const pushStateEvent = new Event("pushstate");
    history.pushState = function (...args) {
      originalPushState.apply(this, args);
      window.dispatchEvent(pushStateEvent);
    };
    window.addEventListener("pushstate", () => {
      window.parent.postMessage(
        {type: "locationHref", message: location.href},
        "*"
      );
    });
  })();
</script>

sharedEntrances

A shared entrance is an internal address provided by a shared application for other applications within the cluster to access. The field configuration for shared entrances is basically the same as for regular entrances. A typical shared entrance configuration is shown below.

Example

yaml
sharedEntrances:
  - name: ollamav2
    host: sharedentrances-ollama
    port: 0
    title: Ollama API
    icon: https://app.cdn.olares.com/appstore/ollama/icon.png
    invisible: true
    authLevel: internal

Ports

Specify exposed ports

Example

yaml
ports:
- name: rdp-tcp             # Name of the entrance that provides service
  host: windows-svc         # Ingress name of the entrance that provides service
  port: 3389                # Port of the entrance that provides service
  protocol: udp             # Protocol used by the exposed port
  exposePort: 46879         # The port to be exposed can only be assigned to one application at a time within the cluster.
  addToTailscaleAcl: true   # Automatically added to Tailscale's ACL

exposePort

  • Type: int
  • Optional
  • Accepted Value: 0-65535, except reserved ports 22, 80, 81, 443, 444, 2379, 18088.

Olares will expose the ports you specify for an application, which are accessible via the application domain name in the local network, for example: 84864c1f.your_olares_id.olares.com:46879. For each port you expose, Olares configures both TCP and UDP with the same port number.

NOTE

The exposed ports can only be accessed on the local network or through a VPN.

protocol

  • Type: string
  • Optional
  • Accepted Value: udp, tcp

The protocol used for the exposed port. If specified, Olares exposes only the specified protocol. If omitted, Olares exposes both UDP and TCP by default.

addToTailscaleAcl

  • Type: boolean
  • Optional
  • Default: false

When the addToTailscaleAcl field is set to true, the system will automatically assign a random port and add it to the Tailscale ACLs.

Tailscale

  • Type: map
  • Optional

Allow applications to add Access Control Lists (ACL) in Tailscale to open specified ports.

Example

yaml
tailscale:
  acls:
  - proto: tcp
    dst:
    - "*:46879"
  - proto: "" # Optional. If not specified, all supported protocols will be allowed.
    dst:
    -  "*:4557"

Permission

Example

yaml
permission:
  appCache: true
  appData: true
  userData:
  - /Home/

appCache

  • Type: boolean
  • Optional

Whether the app requires read and write permission to the Cache folder. If .Values.userspace.appCache is used in the deployment YAML, then appCache must be set to true.

appData

  • Type: boolean
  • Optional

Whether the app requires read and write permission to the Data folder. If .Values.userspace.appData is used in the deployment YAML, then appData must be set to true.

userData

  • Type: list<string>
  • Optional

Whether the app requires read and write permission to user's Home folder. List all directories that the application needs to access under the user's Home. All userData directory configured in the deployment YAML, must be included here.

provider

  • Type: list<map>
  • Optional

Use this field to declare APIs from other applications that your app needs to access. The target application must have exposed a providerName in its own provider section (refer to the Provider section below).

To configure access:

  1. Set the appName field to the name of the target application.
  2. Set the providerName field to match the name specified in the target app’s provider configuration.

You can optionally use the podSelectors field to specify which pods in your app should have access. If this field is omitted, all pods in your app will be injected with the outbound envoy sidecar to enable access.

Example for calling app

yaml
# App requiring provider, e.g. sonarr
permission:  
  provider:
  - appName: bazarr
    providerName: bazarr-svc
    podSelectors:
      - matchLabels:
          io.kompose.service: api

Example for provider app

yaml
#  Provider app, e.g. bazarr
provider:
- name: bazarr-svc
  entrance: bazarr-svc
  paths: ["/*"]
  verbs: ["*"]

Spec

Additional information about the application, primarily used for display in the Olares Market.

Example

yaml
spec:
  versionName: '10.8.11' 
  # The version of the application that this chart contains. It is recommended to enclose the version number in quotes. This value corresponds to the appVersion field in the `Chart.yaml` file. Note that it is not related to the `version` field.

  featuredImage: https://app.cdn.olares.com/appstore/jellyfin/promote_image_1.jpg
  # The featured image is displayed when the app is featured in the Market.

  promoteImage:
  - https://app.cdn.olares.com/appstore/jellyfin/promote_image_1.jpg
  - https://app.cdn.olares.com/appstore/jellyfin/promote_image_2.jpg
  - https://app.cdn.olares.com/appstore/jellyfin/promote_image_3.jpg
  fullDescription: |
    Jellyfin is the volunteer-built media solution that puts you in control of your media. Stream to any device from your own server, with no strings attached. Your media, your server, your way.
  upgradeDescription: |
    upgrade descriptions
  developer: Jellyfin
  website: https://jellyfin.org/
  doc: https://jellyfin.org/docs/
  sourceCode: https://github.com/jellyfin/jellyfin
  submitter: Olares
  locale:
  - en-US
  - zh-CN
  # List languages and regions supported by this app

  requiredMemory: 256Mi
  requiredDisk: 128Mi
  requiredCpu: 0.5
  # Specifies the minimum resources required to install and run the application. Once the app is installed, the system will reserve these resources to ensure optimal performance.

  limitedDisk: 256Mi
  limitedCpu: 1
  limitedMemory: 512Mi
  # Specifies the maximum resource limits for the application. If the app exceeds these limits, it will be temporarily suspended to prevent system overload and ensure stability.

  legal:
  - text: Community Standards
    url: https://jellyfin.org/docs/general/community-standards/
  - text: Security policy
    url: https://github.com/jellyfin/jellyfin/security/policy
  license:
  - text: GPL-2.0
    url: https://github.com/jellyfin/jellyfin/blob/master/LICENSE
  supportClient:
  - android: https://play.google.com/store/apps/details?id=org.jellyfin.mobile
  - ios: https://apps.apple.com/us/app/jellyfin-mobile/id1480192618

i18n

To add multi-language support for your app in Olares Market:

  1. Create an i18n folder in the Olares Application Chart root directory.
  2. In the i18n folder, create separate subdirectories for each supported locale.
  3. In each locale subdirectory, place a localized version of the OlaresManifest.yaml file.

Olares Market will automatically display the content of the corresponding "OlaresManifest.yaml" file based on users' locale settings.

Example

.
├── Chart.yaml
├── README.md
├── OlaresManifest.yaml
├── i18n
│   ├── en-US
│   │   └── OlaresManifest.yaml
│   └── zh-CN
│       └── OlaresManifest.yaml
├── owners
├── templates
│   └── deployment.yaml
└── values.yaml

Currently, you can add i18n content for the following fields:

yaml
metadata:
  description:
  title:
spec:
  fullDescription:
  upgradeDescription:

supportArch

  • Type: list<string>
  • Accepted Value: amd64, arm64
  • Optional

Specifies the CPU architecture supported by the application. Currently only amd64 and arm64 are available.

Example

yaml
spec:
  supportArch:
  - amd64
  - arm64

NOTE

Olares does not support mixed-architecture clusters for now.

onlyAdmin

  • Type: boolean
  • Default: false
  • Optional

When set to true, only the admin can install this app.

runAsUser

  • Type: boolean
  • Optional

When set to true, Olares forces the application to run under user ID 1000 (as a non-root user).

Middleware

  • Type: map
  • Optional

Olares provides highly available middleware services. Developers do not need to install middleware repeatedly. Add the required middleware here, then use the corresponding middleware values in the application's deployment YAML file.

Use the scripts field to specify scripts that should be executed after the database is created. Additionally, use the extension field to add the corresponding extension in the database.

NOTE

MongoDB, MySQL, MariaDB, MinIO, and RabbitMQ must first be installed by an admin from the Market before they can be used by other applications.

PostgreSQL

Example

yaml
middleware:
  postgres:
    username: immich
    databases:
    - name: immich
      extensions:
      - vectors
      - earthdistance
      scripts:
      - BEGIN;                                           
      - ALTER DATABASE $databasename SET search_path TO "$user", public, vectors;
      - ALTER SCHEMA vectors OWNER TO $dbusername;
      - COMMIT;
      # The OS provides two variables, $databasename and $dbusername, which will be replaced by Olares Application Runtime when the command is executed.

Use the middleware information in deployment YAML

yaml
# For PostgreSQL, the corresponding value is as follows
- name: DB_POSTGRESDB_DATABASE # The database name you configured in OlaresManifest, specified in middleware.postgres.databases[i].name
  value: {{ .Values.postgres.databases.<dbname> }}
- name: DB_POSTGRESDB_HOST
  value: {{ .Values.postgres.host }}
- name: DB_POSTGRESDB_PORT
  value: "{{ .Values.postgres.port }}"
- name: DB_POSTGRESDB_USER
  value: {{ .Values.postgres.username }}
- name: DB_POSTGRESDB_PASSWORD
  value: {{ .Values.postgres.password }}

Redis

Example

yaml
middleware:
  redis:
    password: password
    namespace: db0

Use the middleware information in deployment YAML

yaml
# For Redis, the corresponding value is as follows
host --> {{ .Values.redis.host }}
port --> "{{ .Values.redis.port }}"
password --> "{{ .Values.redis.password }}"

MongoDB

Example

yaml
middleware:
  mongodb:
    username: chromium
    databases:
    - name: chromium
      script:
      - 'db.getSiblingDB("$databasename").myCollection.insertOne({ x: 111 });'
      # Please make sure each line is a complete query.

Use the middleware information in deployment YAML

yaml
# For MongoDB, the corresponding value is as follows
host --> {{ .Values.mongodb.host }}
port --> "{{ .Values.mongodb.port }}"  # The port and password in the yaml file need to be enclosed in double quotes.
username --> {{ .Values.mongodb.username }}
password --> "{{ .Values.mongodb.password }}" # The port and password in the yaml file need to be enclosed in double quotes.
databases --> "{{ .Values.mongodb.databases }}" # The value type of database is a map. You can get the database using {{ .Values.mongodb.databases.<dbname> }}. The <dbname> is the name you configured in OlaresManifest, specified in middleware.mongodb.databases[i].name

MinIO

Example

yaml
middleware:
  minio:
    username: miniouser
    buckets:
    - name: mybucket

Use the middleware information in deployment YAML

yaml
# For MinIO, the corresponding value is as follows
- env:
  - name: MINIO_ENDPOINT
    value: '{{ .Values.minio.host }}:{{ .Values.minio.port }}'
  - name: MINIO_PORT
    value: "{{ .Values.minio.port }}"
  - name: MINIO_ACCESS_KEY
    value: {{ .Values.minio.username }}
  - name: MINIO_SECRET_KEY
    value: {{ .Values.minio.password }}
  - name: MINIO_BUCKET
    value: {{ .Values.minio.buckets.mybucket }}

RabbitMQ

Example

yaml
middleware:  
  rabbitmq:
    username: rabbitmquser
    vhosts:
    - name: aaa

Use the middleware information in deployment YAML

yaml
# For RabbitMQ, the corresponding value is as follows
- env:
  - name: RABBITMQ_HOST
    value: '{{ .Values.rabbitmq.host }}'
  - name: RABBITMQ_PORT
    value: "{{ .Values.rabbitmq.port }}"
  - name: RABBITMQ_USER
    value: "{{ .Values.rabbitmq.username }}"
  - name: RABBITMQ_PASSWORD
    value: "{{ .Values.rabbitmq.password }}"
  - name: RABBITMQ_VHOST
    value: "{{ .Values.rabbitmq.vhosts.aaa }}"    

user := os.Getenv("RABBITMQ_USER")
password := os.Getenv("RABBITMQ_PASSWORD")
vhost := os.Getenv("RABBITMQ_VHOST")
host := os.Getenv("RABBITMQ_HOST")
portMQ := os.Getenv("RABBITMQ_PORT")
url := fmt.Sprintf("amqp://%s:%s@%s:%s/%s", user, password, host, portMQ, vhost)

MariaDB

Example

yaml
middleware:  
  mariadb:
    username: mariadbclient
    databases:
    - name: aaa

Use the middleware information in deployment YAML

yaml
# For MariaDB, the corresponding value is as follows
- env:
  - name: MDB_HOST
    value: '{{ .Values.mariadb.host }}'
  - name: MDB_PORT
    value: "{{ .Values.mariadb.port }}"
  - name: MDB_USER
    value: "{{ .Values.mariadb.username }}"
  - name: MDB_PASSWORD
    value: "{{ .Values.mariadb.password }}"
  - name: MDB_DB
    value: "{{ .Values.mariadb.databases.aaa }}"

MySQL

Example

yaml
middleware:  
  mysql:
    username: mysqlclient
    databases:
    - name: aaa

Use the middleware information in deployment YAML

yaml
# For MySQL, the corresponding value is as follows
- env:
  - name: MDB_HOST
    value: '{{ .Values.mysql.host }}'
  - name: MDB_PORT
    value: "{{ .Values.mysql.port }}"
  - name: MDB_USER
    value: "{{ .Values.mysql.username }}"
  - name: MDB_PASSWORD
    value: "{{ .Values.mysql.password }}"
  - name: MDB_DB
    value: "{{ .Values.mysql.databases.aaa }}"

Options

Configure Olares OS related options here.

policies

  • Type: list<map>
  • Optional

Define detailed access control for subdomains of the app.

Example

yaml
options:
  policies:
    - uriRegex: /$
      level: two_factor
      oneTime: false
      validDuration: 3600s
      entranceName: gitlab

appScope

  • Type: map
  • Optional

Specifies whether the app should be installed for all users in the Olares cluster. For shared apps, set clusterScoped to true and provide the current app's name in the appRef field.

Example of ollamav2

yaml
metadata:
  name: ollamav2
options:
  appScope:
  {{- if and .Values.admin .Values.bfl.username (eq .Values.admin .Values.bfl.username) }}  # Only the administrator installs the shared service
    clusterScoped: true
    appRef:
      - ollamav2 # the name of current app specified in metadata.name
  {{- else }}
    clusterScoped: false
  {{- end }}
  dependencies:
    - name: olares
      version: '>=1.12.3-0'
      type: system
  {{- if and .Values.admin .Values.bfl.username (eq .Values.admin .Values.bfl.username) }}
  {{- else }}
      type: application
      version: '>=1.0.1'
      mandatory: true   # Other users install the client, depend on the shared service installed by the admin
  {{- end }}

dependencies

  • Type: list<map>

Specify the dependencies and requirements for your application. It includes other applications that your app depends on, as well as any specific operating system (OS) version requirements.

If this application requires other dependent applications for proper installation, you should set the mandatory field to true.

Example

yaml
options:
  dependencies:
    - name: olares
      version: ">=1.0.0-0"
      type: system
    - name: mongodb
      version: ">=6.0.0-0"
      type: middleware
      mandatory: true # Set this field to true if the dependency needs to be installed first.

conflicts

  • Type: list<map>
  • Optional

List other applications that conflict with this app here. Conflicting apps must be uninstalled before this app can be installed.

Example

yaml
options:
  conflicts:
  - name: comfyui
    type: application
  - name: comfyuiclient
    type: application

mobileSupported

  • Type: boolean
  • Default: false
  • Optional

Determine whether the application is compatible with mobile web browsers and can be displayed on the mobile version of Olares Desktop. Enable this option if the app is optimized for mobile web browsers. This will make the app visible and accessible on the mobile version of Olares Desktop.

Example

yaml
mobileSupported: true

oidc

  • Type: map
  • Optional

The Olares includes a built-in OpenID Connect authentication component to simplify identity verification of users. Enable this option to use OpenID in your app.

yaml
# OpenID related variables in yaml
{{ .Values.oidc.client.id }}
{{ .Values.oidc.client.secret }}
{{ .Values.oidc.issuer }}

Example

yaml
oidc:
  enabled: true
  redirectUri: /path/to/uri
  entranceName: navidrome

apiTimeout

  • Type: int
  • Optional

Specifies the timeout limit for API providers in seconds. The default value is 15. Use 0 to allow an unlimited API connection.

Example

yaml
apiTimeout: 0

allowedOutboundPorts

  • Type: list<int>
  • Optional

​​The specified ports will be opened to allow external access via non-HTTP protocols, such as SMTP.

Example

yaml
allowedOutboundPorts:
  - 465
  - 587

allowMultipleInstall

  • Type: boolean
  • Default: false
  • Optional

This application supports deploying multiple independent instances within the same Olares cluster. This setting does not apply to paid applications or clients of shared applications.

Envs

Declare the environment variables required for your application to run here. You can allow users to manually enter these values or reference existing system environment variables directly.

NOTE

This configuration requires Olares OS version 1.12.2 or later to take effect.

Example

yaml
envs:
  - envName: ENV_NAME
    # This key will be injected as .Values.olaresEnv.ENV_NAME during deployment.

    required: true
    # Specifies whether a value is required for installation. If set to true and no default is provided, users must input a value, and the value cannot be deleted.

    default: "DEFAULT"
    # The default value of the environment variable; set by the developer and not editable by users

    type: string
    # The data type of the environment variable. Supported types: int, bool, url, ip, domain, email, string, password. If specified, system will validate user input accordingly.

    editable: true
    # Specifies whether the environment variable can be edited after the application is deployed.

    options:
    - title: Windows11
      value: "11"
    - title: Windows10
      value: "10"
    # List of allowed values. Users can only select value from these options.
    # "title" is a user-friendly label, while "value" is what's actually set in the system.

    remoteOptions: https://xxx.xxx/xx
    # URL providing a list of accepted options. The response body should be a JSON-encoded options list.

    regex: '^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$'
    # The value must match this regular expression.

    valueFrom:
      envName: OLARES_SYSTEM_CLUSTER_DNS_SERVICE
    # Reference the value from a system environment variable. When this is used, manual input is not allowed.
    # All declarable fields  (type, editable, etc.) will be overridden by the referenced variable's attributes; default/value fields are also ignored.
    
    applyOnChange: true
    # Whether to automatically redeploy the app when this variable changes. 
    # If set to false, changes take effect only on upgrade/reinstallation, not on restart.

    description: "DESCRIPTION"
    # Description of this environment variable.

To use the values of environment variables in your deployment YAML file, simply use .Values.olaresEnv.ENV_NAME in the appropriate place. The system will automatically inject the olaresEnv variables into the Values.yaml during deployment. For example:

deployment.yaml

yaml
  BACKEND_MAIL_HOST: "{{ .Values.olaresEnv.MAIL_HOST }}"
  BACKEND_MAIL_PORT: "{{ .Values.olaresEnv.MAIL_PORT }}"
  BACKEND_MAIL_AUTH_USER: "{{ .Values.olaresEnv.MAIL_AUTH_USER }}"
  BACKEND_MAIL_AUTH_PASS: "{{ .Values.olaresEnv.MAIL_AUTH_PASS }}"
  BACKEND_MAIL_SECURE: "{{ .Values.olaresEnv.MAIL_SECURE }}"
  BACKEND_MAIL_SENDER: "{{ .Values.olaresEnv.MAIL_SENDER }}"

Provider

Declare the interfaces that this application exposes to other applications here. The system will automatically generate a Service for each declared interface, enabling other applications within the cluster to access them through the internal network. If another application needs to access these interfaces, it must first request permission for the specific provider in the permissions section.

Example

yaml
provider:
- name: bazarr
  entrance: bazarr-svc   # The entry name of the service
  paths: ["/api*"]       # API paths to expose; cannot consist of * only
  verbs: ["*"]           # Supported: post, get, put, delete, patch; "*" allows all methods