homebridge-smartthings-ac-km81-patch-automode
v2.3.0-auto-hotfix-1
Published
SmartThings 에어컨을 HomeKit에 연동하는 고기능 커스텀 플러그인 (CLI 기반 OAuth2 자동 인증 지원)
Maintainers
Readme
Homebridge SmartThings AC (KM81)
https://github.com/Km81/homebridge-smartthings-ac-km81 를 하드포크한 리포지토리입니다. km81님이 만드신 환경은 "제습" 이 기본모드라 삼성 에어컨을 "자동" 모드로 사용하는 제 환경에 적합하게 "자동" 으로 변경한 코드입니다.
삼성 시스템 에어컨을 SmartThings API를 통해 HomeKit에 연동하기 위한 Homebridge 플러그인입니다. 이 플러그인은 HomeKit 환경에서 에어컨을 더 단순하고 직관적으로 사용하고자 하는 목적에 맞춰져 있으며, 특히 냉방/제습 위주의 사용에 최적화되어 있습니다.
주요 기능
- HomeKit을 통한 삼성 시스템 에어컨 제어: 전원, 온도 설정 등 기본적인 제어가 가능합니다.
- 단순화된 제어 모드: HomeKit UI의 복잡성을 줄이기 위해 제어 모드를 **'냉방'과 '끔'**으로 제한했습니다. '난방' 및 '자동' 모드는 UI에 표시되지 않습니다.
- 제습 모드 연동: HomeKit에서 '냉방' 모드를 선택하면, 실제 에어컨은 '제습(Dry)' 모드로 동작합니다. 여름철 습도 관리에 유용합니다.
- 통합된 '냉방 중' 상태: 에어컨의 실제 동작 모드(냉방, 제습, 송풍 등)와 관계없이, **전원이 켜져 있다면 HomeKit에서는 항상 '냉방 중'**으로 상태가 표시됩니다.
- 부가 기능 지원:
- 무풍 모드: HomeKit의 '스윙' 기능으로 켜고 끌 수 있습니다.
- 자동 건조 모드: HomeKit의 '물리 제어 잠금' 기능으로 켜고 끌 수 있습니다.
- 안전한 인증: SmartThings의 공식 OAuth 2.0 인증 방식을 사용하여 안전하게 계정을 연동합니다.
- 간편한 최초 인증: 플러그인이 로컬 인증 서버를 잠시 구동하여 복잡한 과정 없이 토큰을 발급받을 수 있습니다.
사전 준비
- Homebridge가 설치되어 있어야 합니다. (Homebridge UI 사용을 권장합니다.)
- Node.js 18.0.0 이상 버전이 필요합니다.
- SmartThings 계정이 있어야 하며, 제어하려는 에어컨이 SmartThings 앱에 정상적으로 등록되어 있어야 합니다.
설치
Homebridge UI의 '플러그인' 탭에서 homebridge-smartthings-ac-km81을 검색하여 설치하거나, 터미널에서 아래 명령어를 직접 실행합니다.
npm install -g homebridge-smartthings-ac-km81설정 (리버스 프록시 필수)
SmartThings의 보안 정책 변경으로 인해, 이제 https 프로토콜을 사용하는 주소만 인증을 위한 Redirect URI로 등록할 수 있습니다. 따라서 외부에서 https로 접속할 수 있는 환경을 만들고, 이를 내부 Homebridge의 http 주소로 전달해주는 리버스 프록시(Reverse Proxy) 설정이 필수입니다.
1단계: 리버스 프록시 설정 및 HTTPS 주소 준비
가장 먼저 외부에서 접속 가능한 https 주소를 준비해야 합니다. Synology NAS, Nginx Proxy Manager 등 다양한 도구를 사용할 수 있습니다.
리버스 프록시 개념
- 외부 주소 (SmartThings 등록용,
https):https://<나의도메인>:<외부포트> - 내부 주소 (플러그인 리스닝용,
http):http://<홈브릿지IP>:8999
이 플러그인은 내부적으로 항상 8999 포트에서 인증 요청을 기다립니다. 따라서 리버스 프록시의 목적지 포트는 반드시 8999로 지정해야 합니다.
설정 예시 (Synology NAS 기준)
- Synology 제어판 > 로그인 포털 > 고급 > 리버스 프록시로 이동하여
생성을 클릭합니다. - 리버스 프록시 규칙 설정:
- 소스 (Source):
- 프로토콜:
HTTPS - 호스트 이름: 나의 DDNS 주소 (예:
myhome.myds.me) - 포트: 외부에서 사용할 포트 (예:
9002)
- 프로토콜:
- 대상 (Destination):
- 프로토콜:
HTTP - 호스트 이름: Homebridge가 설치된 기기의 내부 IP 주소 (예:
192.168.1.10) - 포트:
8999(고정)
- 프로토콜:
- 소스 (Source):
- 설정을 저장합니다.
- 이제 외부 주소인
https://myhome.myds.me:9002를 다음 단계에서 사용합니다.
2단계: SmartThings API Key 발급 (CLI 방식)
SmartThings CLI 설치 터미널 앱을 열고 아래 명령어를 실행합니다.
npm install -g @smartthings/cli개인용 액세스 토큰(PAT) 발급
- SmartThings 개인용 액세스 토큰 페이지에 접속합니다.
- **'Generate new token'**을 클릭하고, 모든 권한을 체크한 후 토큰을 생성하고 값을 복사합니다.
터미널에서 CLI 인증 아래 명령어를 실행하여 발급받은 PAT를 환경 변수로 등록합니다.
# "YOUR_PAT_TOKEN" 부분을 위에서 복사한 토큰 값으로 변경하세요. export SMARTTHINGS_TOKEN="YOUR_PAT_TOKEN"OAuth App 생성 및 Client ID/Secret 발급 아래 명령어를 터미널에 입력합니다.
smartthings apps:create명령어 실행 후 나타나는 질문에 아래 예시를 참고하여 입력하세요.
Display Name:Homebridge AC ControlDescription:Homebridge AC ControlIcon Image URL/Target URL: 그냥 엔터를 눌러 넘어갑니다.Select Scopes: 스페이스바를 눌러 아래 3가지 권한을 모두 선택하고 엔터를 누릅니다.r:devices:*w:devices:*x:devices:*
Add or edit Redirect URIs: 'Add Redirect URI' 를 선택합니다.Redirect URI: 1단계에서 준비한 리버스 프록시의 외부https주소를 입력합니다.- 예시:
https://myhome.myds.me:9002 - 이후
config.json에 입력할redirectUri값과 정확히 일치해야 합니다.
- 예시:
Add or edit Redirect URIs: 'Finish editing Redirect URIs' 를 선택합니다.Choose an action: 'Finish and create OAuth-In SmartApp' 을 선택합니다.
결과 확인 및 정보 저장 모든 절차가 완료되면 터미널에
OAuth Client Id와OAuth Client Secret값이 출력됩니다. 이 정보는 다시 확인할 수 없으므로 반드시 지금 복사하여 저장해야 합니다.
3단계: Homebridge config.json 설정
Homebridge UI 또는 config.json 파일을 직접 수정하여 아래 내용을 추가합니다.
{
"platform": "SmartThingsAC-KM81",
"name": "SmartThings AC",
"clientId": "YOUR_CLIENT_ID",
"clientSecret": "YOUR_CLIENT_SECRET",
"redirectUri": "[https://myhome.myds.me:9002](https://myhome.myds.me:9002)",
"devices": [
{
"deviceLabel": "거실 에어컨"
},
{
"deviceLabel": "안방 에어컨"
}
]
}platform:SmartThingsAC-KM81로 고정합니다.clientId: 2단계에서 발급받은 OAuth Client Id를 입력합니다.clientSecret: 2단계에서 발급받은 OAuth Client Secret을 입력합니다.redirectUri: 1, 2단계에서 설정한 리버스 프록시의 외부https주소를 정확히 동일하게 입력합니다.devices: SmartThings 앱에 표시되는 에어컨의 이름과 정확히 일치해야 합니다.
4단계: 플러그인 최초 인증
- 설정 저장이 완료되면 Homebridge를 재시작합니다.
- Homebridge 로그(Log)를 확인하면,
[스마트싱스 인증 필요]라는 문구와 함께 인증 URL이 나타납니다. - 로그에 표시된
인증 URL전체를 복사하여 웹 브라우저 주소창에 붙여넣고 접속합니다. - SmartThings 계정으로 로그인하고, 생성한 앱에 대한 권한을 '허용(Authorize)' 합니다.
- "인증 성공!" 메시지가 브라우저에 표시되면 정상적으로 완료된 것입니다.
- 다시 Homebridge를 재시작하면 플러그인이 에어컨 장치를 인식하고 HomeKit에 추가합니다.
상세 기능 설명
| HomeKit 기능 | 실제 에어컨 동작 | 비고 |
| :------------------------ | :-------------------------------------------------------------------------------- | :----------------------------------------------------------------------- |
| 상태 (State) | 꺼짐: 비활성(Inactive) 켜짐: 냉방 중(Cooling) | 에어컨이 켜져 있으면 실제 모드와 관계없이 항상 '냉방 중'으로 표시됩니다. |
| 모드 (Mode) | UI에 '냉방(Cool)'만 표시 '냉방' 선택 시 제습(Dry) 모드로 설정 | 난방/자동 모드는 UI에서 제거되어 선택할 수 없습니다. |
| 온도 설정 (Temp) | 희망 온도(18°C ~ 30°C) 설정 | 일반적인 온도 제어와 동일합니다. |
| 스윙 (Swing) | 켜짐: 무풍(Wind-Free) 모드 On 꺼짐: 무풍(Wind-Free) 모드 Off | HomeKit의 스윙 토글을 이용해 무풍 모드를 제어합니다. |
| 물리 제어 잠금 (Lock) | 켜짐: 자동 건조(Auto Clean) 모드 On 꺼짐: 자동 건조(Auto Clean) 모드 Off | HomeKit의 부가 기능 토글을 재활용하여 자동 건조 기능을 제어합니다. |
문제 해결 (Troubleshooting)
- "장치를 찾지 못했습니다" 로그가 표시될 경우:
config.json의deviceLabel이 SmartThings 앱의 장치 이름과 완전히 동일한지 확인하세요. (띄어쓰기 포함)- SmartThings 앱 생성 시 'devices' 관련 권한 3가지(
r:devices:*,w:devices:*,x:devices:*)를 모두 체크했는지 확인하세요.
- 인증이 실패하거나 "invalid_grant" 오류가 발생할 경우:
config.json의clientId,clientSecret,redirectUri값이 올바르게 입력되었는지 다시 한번 확인하세요.- Homebridge 서버가 실행 중인 기기의 방화벽이
8999포트를 차단하고 있지 않은지, 그리고 리버스 프록시 설정이 올바른지 확인하세요.
