Metadata-Version: 2.4
Name: octoprint-factor-plugin
Version: 2.6.7
Summary: FACTOR Plugin - Remote monitoring and camera integration for OctoPrint
Home-page: https://github.com/kangbyounggwan/octoprint-factor-plugin
Author: FACTOR
Author-email: FACTOR Team <tlvh109@gmail.com>
License: AGPLv3
Project-URL: Homepage, https://factor.io.kr
Project-URL: Repository, https://github.com/kangbyounggwan/octoprint-factor-plugin
Project-URL: Issues, https://github.com/kangbyounggwan/octoprint-factor-plugin/issues
Keywords: octoprint,plugin,3dprinting,mqtt,monitoring,camera
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: End Users/Desktop
Classifier: License :: OSI Approved :: GNU Affero General Public License v3
Classifier: Natural Language :: English
Classifier: Natural Language :: Korean
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: System :: Monitoring
Classifier: Topic :: Printing
Requires-Python: >=3.8,<4
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: OctoPrint>=1.4.0
Requires-Dist: paho-mqtt>=2.0.0
Dynamic: author
Dynamic: home-page
Dynamic: license-file
Dynamic: requires-python

# FACTOR × OctoPrint — 외부 모니터링 & 카메라 연동

<div align="center">

<img src="docs/logo.png" alt="FACTOR Logo" width="150"/>

**3D 프린터를 어디서든 모니터링하세요**

하루 종일 출력 돌려놓고 집에 오니 **스파게티/익스트루더 꼬임**…
그래서 **OctoPrint와 연동되는 외부 모니터링 플랫폼 'FACTOR'**를 만들었습니다.

[![status](https://img.shields.io/badge/status-beta-blue)](https://github.com/kangbyounggwan/octoprint-factor-plugin)
[![platform](https://img.shields.io/badge/OctoPrint-plugin-green)](https://plugins.octoprint.org)
[![license](https://img.shields.io/badge/license-AGPLv3-lightgrey)](LICENSE)
[![language](https://img.shields.io/badge/language-한국어-red)](README.md)
[![language](https://img.shields.io/badge/language-English-blue)](README_EN.md)

**[🌐 웹사이트](https://factor.io.kr)** •
**[📦 다운로드](https://github.com/kangbyounggwan/octoprint-factor-plugin/archive/main.zip)** •
**[📖 문서](https://factor.io.kr/docs)** •
**[💬 이슈 제보](https://github.com/kangbyounggwan/octoprint-factor-plugin/issues)**

</div>

---

## 📋 목차

- [주요 기능](#-주요-기능)
- [빠른 시작](#-빠른-시작)
  - [1단계: 회원가입](#1단계-회원가입)
  - [2단계: 플러그인 설치](#2단계-플러그인-설치)
  - [3단계: 플러그인에서 로그인](#3단계-플러그인에서-로그인)
  - [4단계: 설비 등록](#4단계-설비-등록)
  - [5단계: 웹에서 최종 설정](#5단계-웹에서-최종-설정)
- [문제 해결](#-문제-해결)
- [기여하기](#-기여하기)
- [라이선스](#-라이선스)

---

## ✨ 주요 기능

<table>
<tr>
<td width="50%">

### 🖥️ 실시간 모니터링
- 출력 진행률 및 상태 확인
- 온도, 프린트 시간 추적
- 여러 프린터 동시 모니터링

</td>
<td width="50%">

### 📹 카메라 연동
- MJPEG/WebRTC/RTSP/HLS 지원
- 기존 스트림 URL 그대로 사용
- 실시간 비디오 스트리밍

</td>
</tr>
<tr>
<td width="50%">

### 🔒 보안 강화
- MQTT TLS/SSL 암호화 지원
- Rate limiting 및 입력 검증
- 안전한 명령 실행

</td>
<td width="50%">

### ⚡ 간편한 설치
- 5-10분 내 설정 완료
- 플러그인 자동 업데이트
- 직관적인 UI

</td>
</tr>
</table>

---

## 🚀 빠른 시작

### 📝 사전 요구사항

- OctoPrint 1.4.0 이상
- Python 3.8 이상
- 인터넷 연결

### 1단계: 회원가입

<div align="center">

<img src="docs/1단계.png" alt="회원가입" width="600"/>

</div>

1. **웹사이트 접속**: [https://factor.io.kr](https://factor.io.kr)
2. **회원가입 진행**:
   - 우측 상단 **로그인** 클릭
   - **회원가입** 탭 선택
   - 이메일, 사용자명, 비밀번호 입력
   - **Sign Up** 버튼 클릭
3. **이메일 인증**: 메일함에서 인증 링크 클릭

> 💡 **팁**: 이메일이 오지 않는다면 스팸 폴더를 확인하세요.

---

### 2단계: 플러그인 설치

<div align="center">

<img src="docs/2단계.png" alt="플러그인 관리자" width="600"/>

</div>

1. **OctoPrint 설정 열기**:
   - 우측 상단 **🔧 스패너 아이콘** 클릭
   - **Plugin Manager** 선택

<div align="center">

<img src="docs/2-1단계.png" alt="URL로 설치" width="600"/>

</div>

2. **URL로 설치**:
   - **Get More…** 버튼 클릭
   - **…from URL** 선택
   - 아래 URL 붙여넣기:
   ```
   https://github.com/kangbyounggwan/octoprint-factor-plugin/archive/main.zip
   ```
   - **Install** 클릭
3. **OctoPrint 재시작**: 설치 완료 후 프롬프트에 따라 재시작

> ⚠️ **주의**: 재시작하지 않으면 플러그인이 활성화되지 않습니다.

---

### 3단계: 플러그인에서 로그인

<div align="center">

<img src="docs/3단계.png" alt="로그인" width="600"/>

</div>

1. **플러그인 실행**:
   - 좌측 메뉴에서 **FACTOR MQTT** 클릭
   - 1단계에서 생성한 **이메일/비밀번호** 입력
   - **로그인** 버튼 클릭

---

### 4단계: 설비 등록

<div align="center">

<img src="docs/3-1단계.png" alt="장비 등록" width="600"/>

</div>

1. **Device UUID 생성**:
   - **생성** 버튼 클릭
   - 자동 생성된 Device UUID 확인 및 복사

2. **카메라 설정** (선택사항):
   - 스트림 URL 입력 (예: `http://192.168.1.100:8080/stream`)
   - **테스트** 버튼으로 연결 확인
   - **저장** 클릭

3. **등록 완료**:
   - **등록** 버튼 클릭

> 💡 **지원 카메라 형식**: MJPEG, WebRTC, RTSP, HLS

---

### 5단계: 웹에서 최종 설정

1. **웹사이트로 이동**:
   - 플러그인에서 **FACTOR 웹사이트로 이동** 버튼 클릭
   - 또는 직접 [https://factor.io.kr](https://factor.io.kr) 접속

2. **프린터 등록**:
   - 4단계에서 생성한 **Device UUID** 입력
   - 프린터 이름, 설명 등 설정
   - **등록 완료** 클릭

3. **모니터링 시작**:
   - 대시보드에서 프린터 상태 실시간 확인
   - MQTT 자동 연결 및 데이터 전송 시작

<div align="center">

<img src="docs/결과.png" alt="완료" width="600"/>

**🎉 설치 완료! 이제 웹사이트에서 프린터를 모니터링하세요.**

</div>

---

## 🛠️ 문제 해결

### MQTT 연결 실패

**증상**: "연결 테스트" 실패

**해결 방법**:
1. 네트워크 연결 확인
2. 브로커 호스트/포트 재확인
3. 방화벽 설정 확인
4. OctoPrint 로그 확인: `Settings > Logging > octoprint.plugins.factor_mqtt`

### 카메라 스트림이 보이지 않음

**증상**: 웹사이트에서 카메라 피드 없음

**해결 방법**:
1. 스트림 URL이 올바른지 확인
2. HTTPS 사이트에서 HTTP 스트림은 차단될 수 있음 (Mixed Content)
3. 브라우저 콘솔에서 에러 확인 (F12)
4. ffmpeg 프로세스 상태 확인

### 로그 확인하기

```bash
# OctoPrint 로그 위치
~/.octoprint/logs/octoprint.log

# 실시간 로그 모니터링
tail -f ~/.octoprint/logs/octoprint.log | grep MQTT
```

### 일반적인 에러 코드

| 코드 | 의미 | 해결 방법 |
|------|------|----------|
| `rc=1` | 잘못된 프로토콜 버전 | 브로커 설정 확인 |
| `rc=2` | 클라이언트 ID 거부 | Instance ID 재생성 |
| `rc=3` | 서버 이용 불가 | 브로커 상태 확인 |
| `rc=4` | 잘못된 사용자명/비밀번호 | 인증 정보 재확인 |
| `rc=5` | 권한 없음 | 계정 권한 확인 |

---

## 🤝 기여하기

버그 리포트, 기능 제안, 풀 리퀘스트 환영합니다!

1. 이 저장소를 Fork 하세요
2. Feature 브랜치 생성 (`git checkout -b feature/AmazingFeature`)
3. 변경사항 커밋 (`git commit -m 'Add some AmazingFeature'`)
4. 브랜치에 Push (`git push origin feature/AmazingFeature`)
5. Pull Request 생성

### 개발 환경 설정

```bash
# 저장소 클론
git clone https://github.com/kangbyounggwan/octoprint-factor-plugin.git
cd octoprint-factor-plugin

# 가상환경 생성
python -m venv venv
source venv/bin/activate  # Windows: venv\Scripts\activate

# 의존성 설치
pip install -r requirements.txt

# 개발 모드로 설치
pip install -e .
```

---

## 📄 라이선스

이 프로젝트는 [AGPLv3 라이선스](LICENSE) 하에 배포됩니다.

---

## 🙏 감사의 말

- [OctoPrint](https://octoprint.org/) - 멋진 3D 프린터 제어 소프트웨어
- [Paho MQTT](https://www.eclipse.org/paho/) - MQTT 클라이언트 라이브러리
- 모든 베타 테스터분들께 감사드립니다!

---

<div align="center">

**[⬆ 맨 위로](#factor--octoprint--외부-모니터링--카메라-연동)**

Made with ❤️ by FACTOR Team

</div>
