A CLAUDE.md is just a markdown file at the root of your repo. Copy the content below into your own project's CLAUDE.md to give your agent the same context.
npx versuz@latest install dreammis-social-auto-upload --kind=claude-mdcurl -o CLAUDE.md https://raw.githubusercontent.com/dreammis/social-auto-upload/HEAD/CLAUDE.md## Project Overview
This project, `social-auto-upload`, is a powerful automation tool designed to help content creators and operators efficiently publish video content to multiple domestic and international mainstream social media platforms in one click. The project implements video upload, scheduled release and other functions for platforms such as `Douyin`, `Bilibili`, `Xiaohongshu`, `Kuaishou`, `WeChat Channel`, `Baijiahao` and `TikTok`.
The project consists of a Python backend and a Vue.js frontend.
**Backend:**
* Framework: Flask
* Core Functionality:
* Handles file uploads and management.
* Interacts with a SQLite database to store information about files and user accounts.
* Uses `playwright` for browser automation to interact with social media platforms.
* Provides a RESTful API for the frontend to consume.
* Uses Server-Sent Events (SSE) for real-time communication with the frontend during the login process.
**Frontend:**
* Framework: Vue.js
* Build Tool: Vite
* UI Library: Element Plus
* State Management: Pinia
* Routing: Vue Router
* Core Functionality:
* Provides a web interface for managing social media accounts, video files, and publishing videos.
* Communicates with the backend via a RESTful API.
**Command-line Interface:**
The project also provides a command-line interface (CLI) for users who prefer to work from the terminal. For new Douyin CLI work, prefer the `sau douyin ...` entrypoint over legacy example scripts.
* `login`: To log in to the Douyin uploader account.
* `check`: To verify whether the saved Douyin cookie is still valid.
* `upload`: To upload one video file with explicit metadata flags.
## Building and Running
### Backend
1. **Install dependencies:**
```bash
pip install -r requirements.txt
```
2. **Install Playwright browser drivers:**
```bash
playwright install chromium
```
3. **Initialize the database:**
```bash
python db/createTable.py
```
4. **Run the backend server:**
```bash
python sau_backend.py
```
The backend server will start on `http://localhost:5409`.
### Frontend
1. **Navigate to the frontend directory:**
```bash
cd sau_frontend
```
2. **Install dependencies:**
```bash
npm install
```
3. **Run the development server:**
```bash
npm run dev
```
The frontend development server will start on `http://localhost:5173`.
### Command-line Interface
To use the CLI, you can run the `cli_main.py` script with the appropriate arguments.
**Login:**
```bash
sau douyin login --account <account_name>
```
**Check:**
```bash
sau douyin check --account <account_name>
```
**Upload:**
```bash
sau douyin upload --account <account_name> --file <video_file> --title <title> [--tags tag1,tag2] [--schedule YYYY-MM-DD HH:MM]
```
**Install bundled skill:**
```bash
sau skill install
```
## Development Conventions
* The backend code is located in the root directory and the `myUtils` and `uploader` directories.
* The frontend code is located in the `sau_frontend` directory.
* The project uses a SQLite database for data storage. The database file is located at `db/database.db`.
* The `conf.example.py` file should be copied to `conf.py` and configured with the appropriate settings.
* The `requirements.txt` file lists the Python dependencies.
* The `package.json` file in the `sau_frontend` directory lists the frontend dependencies.