라프텔의 애니메이션 데이터를 탐색하고, 재생 환경을 제공하는 커스텀 웹 플레이어 및 메타데이터 서버입니다.
-
커스텀 플레이어 엔진: Dedicated Worker 기반의 MSE와 AES-CTR 복호화 로직을 통해 iOS 환경에서도 클리어키 재생을 지원합니다.
-
오프라인 메타데이터 동기화: IndexedDB를 활용해 수만 개의 작품 정보를 로컬에 저장하며, 네트워크 없이도 빠르게 검색하고 탐색할 수 있습니다.
- Bun — 런타임 및 빌드 도구
- Go — 백엔드 서버
- Python 3.10+ — CDM 서버
# 의존성 설치
bun install
# 프론트엔드 빌드
ln -sf ../THIRD-PARTY-NOTICES.md public/
bun build.mjs
# 백엔드 빌드
go build -o bin/lafdb .
go build -o bin/scraper ./cmd/scraper
go build -o bin/drm ./cmd/drm
# Python 가상환경 설정 (CDM 서버용)
cd scripts
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
# 서버 실행 (상호작용형)
./run_server.sh| 플래그 | 설명 |
|---|---|
--port 4003 |
서버가 사용할 포트를 설정합니다. |
--cf-csp |
Cloudflare 환경에 맞게 CSP 헤더를 자동으로 조정합니다. |
--rebuild-cache |
laftel/의 JSON 파일을 다시 스캔해 data.bin 인덱스를 재생성합니다. |
--no-cache |
인덱스를 사용하지 않고 요청 시 JSON을 직접 읽어 메모리 사용량을 줄입니다. |
go run cmd/scraper/main.go [flags]| 플래그 | 설명 |
|---|---|
--proxies <path> |
프록시 리스트 파일 경로 (ip:port:user:pass) |
--daemon |
수집 → DRM 갱신 → 인덱싱 과정을 계속 반복 실행합니다 |
--no-skip |
기존 데이터를 무시하고 강제로 다시 수집합니다 |
go run cmd/drm/main.go [flags]| 플래그 | 설명 |
|---|---|
--token <token> |
Laftel API 인증 토큰 (DRM 키 획득에 필요) |
--decrypt <url> |
CDM 서버 주소 (기본값: http://127.0.0.1:3040/api/decrypt) |
--sleep <duration> |
요청 사이의 대기 시간(밀리초). 차단 방지를 위해 16000 이상을 권장합니다. |
--skip-failed |
이전에 실패한 에피소드를 건너뜁니다. |
자세한 플래그는 grep ':= flag.' internal/server/server.go cmd/*/main.go로 확인할 수 있습니다.
/etc/default/lafdb 파일을 생성하고 다음을 설정합니다.
LAFDB_HOME=/path/to/lafdb
LAFTEL_TOKEN=<token># 서비스 파일 복사
sudo cp services/*.service /etc/systemd/system/
# 서비스 등록 및 실행
sudo systemctl daemon-reload
sudo systemctl enable --now lafdb-cdm.service
sudo systemctl enable --now lafdb-drm.service
sudo systemctl enable --now lafdb.servicelocalhost, mediacloud.localhost, streaming-bp.localhost, thumbnail.localhost {
@preflight method OPTIONS
handle @preflight {
header {
Access-Control-Allow-Origin *
Access-Control-Allow-Methods "GET, OPTIONS"
Access-Control-Allow-Headers *
Access-Control-Expose-Headers "Content-Length, Content-Range, Accept-Ranges"
}
respond 204
}
header {
Access-Control-Allow-Origin *
Access-Control-Allow-Methods "GET, OPTIONS"
Access-Control-Allow-Headers *
Access-Control-Expose-Headers "Content-Length, Content-Range, Accept-Ranges"
}
reverse_proxy localhost:4003
}bin/ # 컴파일된 Go 바이너리
cmd/ # Go 서브커맨드 (scraper, drm 등)
internal/ # 백엔드 핵심 로직 (server, indexer, drm)
laftel/ # Laftel API 클라이언트
src/ # TypeScript 프론트엔드
public/ # 정적 리소스 및 빌드 결과물
scripts/ # Python CDM 서버 (FastAPI)
services/ # systemd 서비스 설정 파일이 프로젝트는 다음 10가지 라이선스 중 하나를 선택해 적용하는 데카 멀티 라이선스로 배포됩니다.
- The Unlicense: 퍼블릭 도메인으로 제공되며, 어떠한 제한도 없습니다.
- GLWTPL: 어떠한 보증도 제공되지 않으며, 사용에 따른 모든 책임은 사용자에게 있습니다.
- MIT License: 최소한의 조건으로 자유로운 사용을 허용합니다.
- Apache License 2.0: 특허 권한을 포함한 자유로운 사용을 허용합니다.
- Mozilla Public License 2.0: 수정된 파일에 한해 copyleft가 적용됩니다.
- ISC License: MIT와 유사하게 최소한의 조건으로 자유로운 사용을 허용합니다.
- Boost Software License 1.0: 매우 자유로운 사용을 허용하며, 간단한 고지 의무만 요구됩니다.
- zlib License: 매우 간단한 조건으로 수정 및 재배포를 허용하며, 출처 표시 정도만 요구됩니다.
- BSD 2-Clause License: MIT와 유사하게 자유로운 사용을 허용하며, 저작권 고지 유지가 필요합니다.
- BSD 3-Clause License: BSD 2-Clause와 유사하지만, 저작권자의 이름을 이용한 홍보를 금지하는 추가 조건이 있습니다.
사용자는 반드시 하나의 라이선스를 선택하여 그 조건만을 준수해야 합니다. 자세한 내용은 라이선스 파일을 참고하세요.
이 프로젝트는 다음과 같은 제3자 오픈소스 라이브러리를 사용합니다. 상세한 라이선스 전문은 THIRD-PARTY-NOTICES.md 파일에서 확인할 수 있습니다.