mirror of
https://github.com/ferdzo/fs.git
synced 2026-04-04 20:36:25 +00:00
f57c7b8390844a7286e25cf7335ae20c49c79483
fs
An experimental Object Storage written in Go that should be partially compatible with S3
Running
Single binary, two modes:
fs(no subcommand) starts the server (backward compatible)fs serverstarts the server explicitlyfs admin ...runs admin CLI commands
Features
Bucket operations:
PUT /{bucket}HEAD /{bucket}DELETE /{bucket}GET /(list buckets)
Object operations:
PUT /{bucket}/{key}GET /{bucket}/{key}HEAD /{bucket}/{key}DELETE /{bucket}/{key}GET /{bucket}?list-type=2&prefix=...(ListObjectsV2-style)
Multipart upload:
POST /{bucket}/{key}?uploads(initiate)PUT /{bucket}/{key}?uploadId=...&partNumber=N(upload part)GET /{bucket}/{key}?uploadId=...(list parts)POST /{bucket}/{key}?uploadId=...(complete)DELETE /{bucket}/{key}?uploadId=...(abort)
Multi-object delete:
POST /{bucket}?deletewith S3-style XML body
AWS SigV4 streaming payload decoding for uploads (aws-chunked request bodies)
Authentication:
- AWS SigV4 request verification (header and presigned URL forms)
- Local credential/policy store in bbolt
- Bootstrap access key/secret via environment variables
Admin API (JSON):
POST /_admin/v1/usersGET /_admin/v1/usersGET /_admin/v1/users/{accessKeyId}PUT /_admin/v1/users/{accessKeyId}/policyPUT /_admin/v1/users/{accessKeyId}/statusDELETE /_admin/v1/users/{accessKeyId}
Admin CLI:
fs admin user create --access-key backup-user --role readwritefs admin user listfs admin user get backup-userfs admin user set-status backup-user --status disabledfs admin user set-role backup-user --role readonly --bucket backup-bucket --prefix restic/fs admin user set-role backup-user --role readwrite --bucket backups-2(appends another statement)fs admin user set-role backup-user --role admin --replace(replaces all statements)fs admin user delete backup-userfs admin diag healthfs admin diag version
Auth Setup
Required when FS_AUTH_ENABLED=true:
FS_MASTER_KEYmust be base64 for 32 decoded bytes (AES-256 key), e.g.openssl rand -base64 32FS_ROOT_USERandFS_ROOT_PASSWORDdefine initial credentialsADMIN_API_ENABLED=trueenables/_admin/v1/*routes (bootstrap key only)
Reference: auth/README.md
Additional docs:
- Admin OpenAPI spec:
docs/admin-api-openapi.yaml - S3 compatibility matrix:
docs/s3-compatibility.md
CLI credential/env resolution for fs admin:
- Flags:
--access-key,--secret-key,--endpoint,--region - Env fallback:
FS_ROOT_USER/FS_ROOT_PASSWORD(same defaults as server bootstrap)FSCLI_ACCESS_KEY/FSCLI_SECRET_KEYAWS_ACCESS_KEY_ID/AWS_SECRET_ACCESS_KEYFSCLI_ENDPOINT(fallback toADDRESS+PORT, thenhttp://localhost:3000)FSCLI_REGION(fallbackFS_AUTH_REGION, defaultus-east-1)
Health:
GET /healthzHEAD /healthzGET /metrics(Prometheus exposition format)HEAD /metrics
Limitations
- Not full S3 API coverage.
- No versioning or lifecycle policies.
- Error and edge-case behavior is still being refined for client compatibility.
License
MIT License
Description
Languages
Go
99.8%
Dockerfile
0.2%