A modern, responsive web management console for RustFS distributed file system, built with Vue 3 + Nuxt 4 + TypeScript + Tailwind CSS v4 and TypeScript. https://rustfs.com
Find a file
Vu Van eebeb45b04 Add Vietnamese (vi-VN) language support (#72)
* feat(i18n): add Vietnamese support and language switcher

* Update vi-VN.json

* Update vi-VN.json
2026-03-06 18:15:38 +08:00
.github remove: auto-fix flow 2026-02-27 18:57:38 +08:00
app fix: image previre rustf/rustfs#2091 2026-03-06 18:08:39 +08:00
assets chore: replace codebase with Next.js version (console-new) (#46) 2026-02-01 21:23:31 +08:00
components Add Vietnamese (vi-VN) language support (#72) 2026-03-06 18:15:38 +08:00
config fix: status home redirect (#47) 2026-02-04 21:42:11 +08:00
contexts fix: remove permanentStore ,generateTemporaryUrl use auth Credentials 2026-03-02 12:53:30 +08:00
hooks fix:Admin not allow change password 2026-03-04 15:32:58 +08:00
i18n/locales Add Vietnamese (vi-VN) language support (#72) 2026-03-06 18:15:38 +08:00
lib Add Vietnamese (vi-VN) language support (#72) 2026-03-06 18:15:38 +08:00
public chore: replace codebase with Next.js version (console-new) (#46) 2026-02-01 21:23:31 +08:00
scripts remove: auto-fix flow 2026-02-27 18:57:38 +08:00
types fix:Redirect loop in console rustfs/rustfs#1941 2026-02-26 15:39:22 +08:00
.env.example chore: add .env.example for environment configuration template 2026-02-01 21:53:33 +08:00
.gitignore fmt : .gitignore 2026-02-02 08:29:58 +08:00
.prettierignore fmt: prettier 2026-02-02 09:31:26 +08:00
.prettierrc fix : 403 check Unauthorized 2026-02-02 15:43:58 +08:00
AGENTS.md fix: status home redirect (#47) 2026-02-04 21:42:11 +08:00
components.json add Arabic (RTL) language support (#58) 2026-02-21 09:20:07 +08:00
eslint.config.mjs fix: eslint prettier 2026-02-02 10:11:48 +08:00
LICENSE chore: add Apache-2.0 license to package.json and update README with license details 2026-02-04 22:32:18 +08:00
next.config.ts fix: make static export work under php base path 2026-02-09 16:03:06 +08:00
package.json fix: make static export work under php base path 2026-02-09 16:03:06 +08:00
pnpm-lock.yaml fix: lockfile 2026-02-02 10:01:48 +08:00
pnpm-workspace.yaml chore: replace codebase with Next.js version (console-new) (#46) 2026-02-01 21:23:31 +08:00
postcss.config.mjs fix: status home redirect (#47) 2026-02-04 21:42:11 +08:00
README.md add Arabic (RTL) language support (#58) 2026-02-21 09:20:07 +08:00
tsconfig.json chore: replace codebase with Next.js version (console-new) (#46) 2026-02-01 21:23:31 +08:00

RustFS Console

A modern, responsive web management console for RustFS distributed file system, built with Next.js 16 (App Router) + React 19 + TypeScript + Tailwind CSS v4 + shadcn/ui.

Features

Core Features

  • File Browser - Visual file/object management interface with upload, download, delete operations
  • Access Keys Management - Create and manage service account access keys
  • Policy Management - Configure and manage IAM policies for fine-grained access control
  • User Management - Create, edit, enable/disable, and delete user accounts
  • User Groups Management - Create and manage user groups to simplify permission assignment

Advanced Features

  • Import/Export - Import and export system configurations
  • Performance Monitoring - Real-time system status, server information, and performance metrics
  • Tiered Storage - Configure and manage tiered storage policies
  • Event Destinations - Configure event destinations for event notifications
  • SSE Settings - Server-side encryption configuration
  • License Management - View and manage system license information

🛠️ Tech Stack

Core Framework

UI & Styling

Data Management

Other Tools

📁 Project Structure

console/
├── app/                    # Next.js App Router pages and layouts
│   ├── (auth)/            # Authentication pages
│   └── (dashboard)/       # Dashboard pages
├── components/             # React components
│   ├── ui/                # shadcn/ui base components
│   └── ...                # Business components
├── hooks/                 # Custom React Hooks
├── contexts/              # React Context providers
├── lib/                   # Utility functions and library code
│   └── feedback/          # Global feedback APIs (toast, dialog)
├── types/                 # TypeScript type definitions
├── i18n/                  # Internationalization resource files
│   └── locales/          # Multi-language files (13 languages)
├── config/                # Configuration files
├── public/                # Static assets
└── tests/                 # Test files (mirror source structure)

🚀 Quick Start

Prerequisites

  • Node.js >= 20
  • pnpm >= 10.19.0 (recommended to use the version specified in the project)
  • Docker - For running RustFS service

Start RustFS Service

The RustFS service must be started before development. Run it using Docker:

# Create data directory
mkdir rustfs-data

# Run RustFS service
docker run -p 9000:9000 -p 9001:9001 -v ./rustfs-data:/data rustfs/rustfs:1.0.0-alpha.82

The service will start on the following ports:

  • 9000 - API port
  • 9001 - Console port

Install Dependencies

pnpm install

Development Mode

Note: Before starting the development server, ensure the RustFS service is running (see "Start RustFS Service" section above).

Start the development server (with hot reload):

pnpm dev

Visit http://localhost:3000 to view the application.

Build for Production

pnpm build

Run Production Build

pnpm start

💻 Development Guide

Code Quality Checks

Before committing code, ensure all checks pass:

1. Lockfile Sync Check

pnpm install --frozen-lockfile

Ensure pnpm-lock.yaml is in sync with package.json. After modifying package.json, you must run pnpm install and commit the updated lockfile.

2. TypeScript Type Check

pnpm type-check
# or
pnpm build

3. ESLint Check

pnpm lint

4. Code Formatting Check

pnpm format:check

5. Auto-fix Formatting Issues

pnpm lint:fix
# or
pnpm format

Naming Conventions

  • Component files: Use kebab-case (e.g., bucket-selector.tsx)
  • Component names: Use PascalCase (e.g., <BucketSelector />)
  • Directory structure: Group by feature/domain, use plural forms (e.g., buckets/, users/)
  • File naming: Don't repeat directory name in filename (e.g., buckets/info.tsx instead of buckets/bucket-info.tsx)

UI Component Usage

  • Declarative UI: Use base components from @/components/ui/*
  • Imperative feedback: Use @/lib/feedback/message and @/lib/feedback/dialog for global toast and dialog prompts

Testing

When tests are configured:

  • Test files should be placed in tests/ directory, mirroring source structure
  • Use *.spec.ts or *.test.ts naming
  • Run tests: pnpm test:run

🌍 Internationalization

The project supports multiple languages. Currently supported languages:

  • العربية (AR-MA)
  • 中文(简体)(Chinese Simplified)
  • English (US)
  • Deutsch (DE)
  • Español (ES)
  • Français (FR)
  • Bahasa Indonesia (ID)
  • Italiano (IT)
  • 日本語 (JP)
  • 한국어 (KR)
  • Português (BR)
  • Русский (RU)
  • Türkçe (TR)

Language files are located in the i18n/locales/ directory.

📦 Build & Deployment

Environment Variables

Configure necessary environment variables according to your deployment environment (e.g., API endpoints, authentication configuration).

Build Configuration

The project uses Next.js default build configuration. Custom configuration can be done via next.config.ts.

Deployment

The project can be deployed to any platform that supports Next.js:

  • Vercel (Recommended) - Zero-config deployment
  • Docker - Using official Next.js Docker image
  • Self-hosted - Run pnpm build && pnpm start

🤝 Contributing

Commit Guidelines

  • Use conventional commit messages (Conventional Commits)
  • Ensure all code quality checks pass before committing
  • Each PR should include a clear description and related issue links

Code Review

  • Keep PR scope focused; coordinate large refactors in advance
  • Commit messages and PR titles must be in English
  • UI-related work should include screenshots

📄 License

Licensed under the Apache License 2.0. See LICENSE for details.

🔗 Resources

📝 Development Notes

  • Follow the guidelines in AGENTS.md
  • Keep code simple, readable, and maintainable
  • Prefer using existing project tools and patterns
  • Consider internationalization support when adding new features
  • Ensure all changes pass type checking