Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add missing S3 parameters #614

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion charts/nextcloud/Chart.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
apiVersion: v2
name: nextcloud
version: 6.0.1
version: 6.1.0
appVersion: 30.0.0
description: A file sharing server that puts the control and security of your own data back into your hands.
keywords:
Expand Down
7 changes: 7 additions & 0 deletions charts/nextcloud/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -287,6 +287,13 @@ Here are all the values you can currently configure in this helm chart to config
| `nextcloud.objectStore.s3.autoCreate` | auto-create the S3 bucket | `false` |
| `nextcloud.objectStore.s3.storageClass` | S3 storage class to use | `STANDARD` |
| `nextcloud.objectStore.s3.sse_c_key` | S3 server side encryption key. | `''` |
| `nextcloud.objectStore.s3.concurrency` | S3 maximum number of concurrent multipart uploads. | `5` |
| `nextcloud.objectStore.s3.proxy` | S3 proxy enabled or not. | `false` |
| `nextcloud.objectStore.s3.timeout` | S3 timeout in seconds. | `15` |
| `nextcloud.objectStore.s3.uploadPartSize` | S3 max upload size, in bytes. | `524288000` |
| `nextcloud.objectStore.s3.putSizeLimit` | S3 max PUT size, in bytes. | `104857600` |
| `nextcloud.objectStore.s3.version` | S3 version to use. | `'latest'` |
| `nextcloud.objectStore.s3.verify_bucket_exists` | S3 param to check if bucket already exists on startup. | `true` |
| `nextcloud.objectStore.s3.existingSecret` | Use an existing Kubernetes Secret to fetch auth credentials | `''` |
| `nextcloud.objectStore.s3.secretKeys.host` | if using s3.existingSecret, secret key to use for the host | `''` |
| `nextcloud.objectStore.s3.secretKeys.accessKey` | if using s3.existingSecret, secret key to use for the accessKeyID | `''` |
Expand Down
9 changes: 8 additions & 1 deletion charts/nextcloud/files/defaultConfigs/s3.config.php.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,14 @@ if (getenv('OBJECTSTORE_S3_BUCKET')) {
// required for some non Amazon S3 implementations
'use_path_style' => $use_path == true && strtolower($use_path) !== 'false',
// required for older protocol versions
'legacy_auth' => $use_legacyauth == true && strtolower($use_legacyauth) !== 'false'
'legacy_auth' => $use_legacyauth == true && strtolower($use_legacyauth) !== 'false',
'concurrency' => getenv('OBJECTSTORE_S3_CONCURRENCY'),
'proxy' => getenv('OBJECTSTORE_S3_PROXY'),
'timeout' => getenv('OBJECTSTORE_S3_TIMEOUT'),
'uploadPartSize' => getenv('OBJECTSTORE_S3_UPLOADPARTSIZE'),
'putSizeLimit' => getenv('OBJECTSTORE_S3_PUTSIZELIMIT'),
'version' => getenv('OBJECTSTORE_S3_VERSION'),
'verify_bucket_exists' => getenv('OBJECTSTORE_S3_VERIFY_BUCKET_EXISTS')
)
)
);
Expand Down
18 changes: 17 additions & 1 deletion charts/nextcloud/templates/_helpers.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -247,8 +247,24 @@ S3 as primary object store env vars
value: {{ .Values.nextcloud.objectStore.s3.usePathStyle | quote }}
{{- with .Values.nextcloud.objectStore.s3.legacyAuth }}
- name: OBJECTSTORE_S3_LEGACYAUTH
value: {{ . }}
value: {{ . | quote }}
{{- end }}
- name: OBJECTSTORE_S3_CONCURRENCY
value: {{ .Values.nextcloud.objectStore.s3.concurrency | quote }}
{{- with .Values.nextcloud.objectStore.s3.proxy }}
- name: OBJECTSTORE_S3_PROXY
value: {{ . | quote }}
{{- end }}
- name: OBJECTSTORE_S3_TIMEOUT
value: {{ .Values.nextcloud.objectStore.s3.timeout | quote }}
- name: OBJECTSTORE_S3_UPLOADPARTSIZE
value: {{ .Values.nextcloud.objectStore.s3.uploadPartSize | quote }}
- name: OBJECTSTORE_S3_PUTSIZELIMIT
value: {{ .Values.nextcloud.objectStore.s3.putSizeLimit | quote }}
- name: OBJECTSTORE_S3_VERSION
value: {{ .Values.nextcloud.objectStore.s3.version | quote }}
- name: OBJECTSTORE_S3_VERIFY_BUCKET_EXISTS
value: {{ .Values.nextcloud.objectStore.s3.verify_bucket_exists | quote }}
- name: OBJECTSTORE_S3_AUTOCREATE
value: {{ .Values.nextcloud.objectStore.s3.autoCreate | quote }}
- name: OBJECTSTORE_S3_REGION
Expand Down
10 changes: 10 additions & 0 deletions charts/nextcloud/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,16 @@ nextcloud:
storageClass: "STANDARD"
# server side encryption key. learn more: https://docs.nextcloud.com/server/latest/admin_manual/configuration_files/primary_storage.html#s3-sse-c-encryption-support
sse_c_key: ""
# defines the maximum number of concurrent multipart uploads
concurrency: 5
proxy: false
timeout: 15
uploadPartSize: 524288000
putSizeLimit: 104857600
version: "latest"
# Setting this to false after confirming the bucket has been created may provide a performance benefit,
# but may not be possible in multibucket scenarios.
verify_bucket_exists: true
# use an existingSecret for S3 credentials. If set, we ignore the following under nextcloud.objectStore.s3
# endpoint, accessKey, secretKey
existingSecret: ""
Expand Down