minio-config-cli is a MinIO utility to ensure the desired configuration state for a server based on a JSON/YAML file. Store and handle the configuration files inside git just like normal code. A MinIO restart isn't required to apply the configuration.
Inspired by keycloak-config-cli.
minio-config-cli import MINIO_URL ACCESS_KEY SECRET_KEY --import-file-location=CONFIG_FILE1 --import-file-location=CONFIG_FILE2Assuming you have a MinIO server running on http://localhost:9000 with an
admin access key of minioadmin, a secret key of minioadmin, and a config
file at /tmp/config.yaml, you can import the config file with the following
command:
minio-config-cli import http://localhost:9000 minioadmin minioadmin --import-file-location=/tmp/config.yamlConfig files list resources to import into MinIO. An example config file is shown below:
# yaml-language-server: $schema=https://raw.githubusercontent.com/yardenshoham/minio-config-cli/refs/heads/main/pkg/validation/schema.json
policies:
- name: read-foobar-bucket
policy:
Version: "2012-10-17"
Statement:
- Effect: Allow
Action: [s3:GetObject]
Resource: [arn:aws:s3:::foobar/*]
- name: admin-reports-bucket
policy:
Version: "2012-10-17"
Statement:
- Effect: Allow
Action: ["*"]
Resource: [arn:aws:s3:::admin-reports/*]
users:
- accessKey: iamenabled
secretKey: mypasswordisnice
status: enabled
policies: [read-foobar-bucket]
- accessKey: iamdisabled
secretKey: mypasswordisawesome
status: disabled
- accessKey: iamprettysureiamenabled
secretKey: mypasswordisnicemypasswordisnicemypasswordisnice
buckets:
- name: foobar
lifecycle:
Rules:
- ID: rule1
Status: Enabled
Expiration:
Days: 14
- name: admin-reports
quota:
size: 10737418240 # 10Gi
- name: static-assets-public
policy:
Version: "2012-10-17"
Statement:
- Effect: Allow
Action:
- s3:GetObject
- s3:ListBucket
Resource: "arn:aws:s3:::*"
Principal:
AWS:
- "*"
- name: versioned-bucket
versioning:
Status: Enabled # Enable bucket versioning
- name: versioned-with-exclusions
versioning:
Status: Enabled
ExcludedPrefixes: # Exclude specific prefixes from versioning
- Prefix: "logs/"
- Prefix: "tmp/"
ExcludeFolders: true # Exclude folders from versioningWe provide a JSON schema file for correct creation of the config file. The schema is available at pkg/validation/schema.json. As a URL:
https://raw.githubusercontent.com/yardenshoham/minio-config-cli/refs/heads/main/pkg/validation/schema.json
go buildWe use testcontainers so we test against an actual MinIO server.
go test ./...Run a local instance of the MinIO server on port 9000:
docker run --rm -p 9000:9000 -p 9001:9001 minio/minio server /data --console-address ":9001"before performing the following command:
minio-config-cli import http://localhost:9000 minioadmin minioadmin \
--import-file-location=./testdata/config.yamlDocker images are available at DockerHub (docker.io/yardenshoham/minio-config-cli).
Available docker tags
| Tag | Description |
|---|---|
latest |
latest available release of minio-config-cli. |
va.b.c |
minio-config-cli version a.b.c . |
a.b.c |
minio-config-cli version a.b.c . |
docker run \
-v <your config path>:/config \
yardenshoham/minio-config-cli:latest import http://host.docker.internal:9000 minioadmin minioadmin \
--import-file-location=/config/*You can build an own docker image by running
CGO_ENABLED=0 go build && docker build -t minio-config-cli .We provide a helm chart here.
Since it makes no sense to deploy minio-config-cli as standalone application, you could add it as dependency to your chart deployment.
Checkout helm docs about chart dependencies!