Homepage • Demo • Discussion • Documents • Download • Telegram Group • License
- ☁️ Support storing files into Local storage, Remote storage, Qiniu, Aliyun OSS, Tencent COS, Upyun, OneDrive, S3 compatible API.
- 📤 Upload/Download in directly transmission with speed limiting support.
- 💾 Integrate with Aria2 to download files offline, use multiple download nodes to share the load.
- 📚 Compress/Extract files, download files in batch.
- 💻 WebDAV support covering all storage providers.
- ⚡Drag&Drop to upload files or folders, with streaming upload processing.
- 🗃️ Drag & Drop to manage your files.
- 👩👧👦 Multi-users with multi-groups.
- 🔗 Create share links for files and folders with expiration date.
- 👁️🗨️ Preview videos, images, audios, texts, Office documents, ePub files online.
- 🎨 Customize theme colors, dark mode, PWA application, SPA, i18n.
- 🚀 All-In-One packing, with all features out-of-the-box.
- 🌈 ... ...
Download the main binary for your target machine OS, CPU architecture and run it directly.
# Extract Cloudreve binary
tar -zxvf cloudreve_VERSION_OS_ARCH.tar.gz
# Grant execute permission
chmod +x ./cloudreve
# Start Cloudreve
./cloudreve
The above is a minimum deploy example, you can refer to Getting started for a completed deployment.
You need to have Go >= 1.18
, node.js
, yarn
, zip
and other necessary dependencies before you can build it yourself.
git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git
# Enter frontend sub-module
cd assets
# Install dependencies
yarn install
# Start building
yarn run build
# Delete unused map files
cd build
find . -name "*.map" -type f -delete
# Return to main folder to pack static files
cd ../../
zip -r - assets/build >assets.zip
# Obtain version number, commit SHA
export COMMIT_SHA=$(git rev-parse --short HEAD)
export VERSION=$(git describe --tags)
# Compile
go build -a -o cloudreve -ldflags "-s -w -X 'github.com/cloudreve/Cloudreve/v3/pkg/conf.BackendVersion=$VERSION' -X 'github.com/cloudreve/Cloudreve/v3/pkg/conf.LastCommit=$COMMIT_SHA'"
You can also start a quick build using build.sh
in the project root directory:
./build.sh [-a] [-c] [-b] [-r]
a - Build assets
c - Build binary backend
b - Build both assets and backend
r - Cross-compilation for final release
- Go + Gin
- React + Redux + Material-UI
GPL V3