Files
anyclip-video-manager/CLAUDE.md
Varun Shah e32d475aa9 Add AnyClip integration tools and extracted source code
- Add authentication scripts with SubtleCrypto password encryption
- Add sourcemap extraction pipeline (update-urls, download-sourcemaps, extract-sources)
- Add Playwright API interception script for monetization endpoints
- Document two-step auth flow with JWT tokens and dual cookies
- Move extracted source from root to anyclip/ directory
- Add project configuration (.env.example, .gitignore, CLAUDE.md)
2026-01-21 10:36:51 +08:00

4.0 KiB

description, globs, alwaysApply
description globs alwaysApply
AnyClip integration tools - use Bun, understand the scripts *.ts, *.tsx, *.html, *.css, *.js, *.jsx, package.json true

Project: AnyClip Integration

Tools for integrating with AnyClip's Video Manager API and extracting source code from sourcemaps.

Key Scripts

Script Purpose
scripts/auth.ts Authenticate with AnyClip, returns session cookies
scripts/crypto-subtle.ts Password encryption (AES-256-GCM, matches AnyClip's client)
scripts/update-urls.ts Fetch JS URLs from build manifest → urls.txt
scripts/download-sourcemaps.ts Download .map files for URLs in urls.txt
scripts/extract-sources.ts Extract source from sourcemaps → anyclip/

Authentication Flow

  1. Password encrypted client-side with AES-256-GCM (salt: $2b$04$wwky7rvtr6BFNaCqntwyie)
  2. POST to videomanager-api.anyclip.com/public/auth/login → returns anyclip_2020 cookie + JWT
  3. POST to videomanager.anyclip.com/api/auth/login → returns session cookie
  4. Both cookies required for authenticated requests

Source Extraction Workflow

bun scripts/update-urls.ts        # Scrape build manifest for JS URLs
bun scripts/download-sourcemaps.ts # Download .map files
bun scripts/extract-sources.ts    # Extract to anyclip/

Directory Structure

  • anyclip/ - Extracted source (committed)
  • sourcemaps/ - Raw .map files (gitignored)
  • urls.txt - JS URLs to download
  • session.json - Auth session (gitignored)

Bun Usage

Default to using Bun instead of Node.js.

  • Use bun <file> instead of node <file> or ts-node <file>
  • Use bun test instead of jest or vitest
  • Use bun build <file.html|file.ts|file.css> instead of webpack or esbuild
  • Use bun install instead of npm install or yarn install or pnpm install
  • Use bun run <script> instead of npm run <script> or yarn run <script> or pnpm run <script>
  • Use bunx <package> <command> instead of npx <package> <command>
  • Bun automatically loads .env, so don't use dotenv.

APIs

  • Bun.serve() supports WebSockets, HTTPS, and routes. Don't use express.
  • bun:sqlite for SQLite. Don't use better-sqlite3.
  • Bun.redis for Redis. Don't use ioredis.
  • Bun.sql for Postgres. Don't use pg or postgres.js.
  • WebSocket is built-in. Don't use ws.
  • Prefer Bun.file over node:fs's readFile/writeFile
  • Bun.$ls instead of execa.

Testing

Use bun test to run tests.

import { test, expect } from "bun:test";

test("hello world", () => {
  expect(1).toBe(1);
});

Frontend

Use HTML imports with Bun.serve(). Don't use vite. HTML imports fully support React, CSS, Tailwind.

Server:

import index from "./index.html"

Bun.serve({
  routes: {
    "/": index,
    "/api/users/:id": {
      GET: (req) => {
        return new Response(JSON.stringify({ id: req.params.id }));
      },
    },
  },
  // optional websocket support
  websocket: {
    open: (ws) => {
      ws.send("Hello, world!");
    },
    message: (ws, message) => {
      ws.send(message);
    },
    close: (ws) => {
      // handle close
    }
  },
  development: {
    hmr: true,
    console: true,
  }
})

HTML files can import .tsx, .jsx or .js files directly and Bun's bundler will transpile & bundle automatically. <link> tags can point to stylesheets and Bun's CSS bundler will bundle.

<html>
  <body>
    <h1>Hello, world!</h1>
    <script type="module" src="./frontend.tsx"></script>
  </body>
</html>

With the following frontend.tsx:

import React from "react";
import { createRoot } from "react-dom/client";

// import .css files directly and it works
import './index.css';

const root = createRoot(document.body);

export default function Frontend() {
  return <h1>Hello, world!</h1>;
}

root.render(<Frontend />);

Then, run index.ts

bun --hot ./index.ts

For more information, read the Bun API docs in node_modules/bun-types/docs/**.mdx.