기본 콘텐츠로 건너뛰기

게이트맨 연동기와 도어센서로 HA에 현관문 리모컨 구현하기

이번에 저희 집이 게이트맨 도어락을 구입해서 설치했습니다.

설치한김에 게이트맨 연동기로 HA에서 현관문을 열 수 있는 기능을 구현한 것을 공유해보고자 합니다.

초보는 검색도 힘들고.. 말해도 말귀도 어두워서..

막상 해보면 별거 없는데.. 그래도 혹시나 자신 없어 하시는 분들을 위해.. 남겨봅니다.

우선 준비물이 필요합니다.

HA는 당연히 있어야 할거고요..

ESP32로 구현하시는 분들도 계시던데.. 저는 직비로 할 예정이기 때문에.. 직비 코디네이터는 있으셔야 하고.. HA에 Z2M은 설치되어 있으셔야 합니다.(여기서부터.. 절대 초보자가 따라 할 수 없는 수준인것 같은 느낌이지만.. 직비는 HA에 알아서 구현해보세용.. 여기서는 그 정도는 당연히 되어 있다고 가정하고 진행하겠습니다.)

그 다음에 게이트맨 연동기를 조작할 직비 릴레이가 필요합니다. 저는 이걸 구매했습니다.

https://ko.aliexpress.com/item/1005002306870803.html?spm=a2g0s.9042311.0.0.663e4c4dcH88wQ

저도 몰랐는데.. 전원에 연결되는 직비 장치는 라우터 기능이 대부분 들어있다고 합니다. 이 릴레이도 라우터 기능이 포함되어 있습니다.

그렇잖아도 라우터가 하나 필요했는데.. 득템했네요.

그 다음에 스마트폰 충전 케이블과 어뎁터가 있으셔야 하고요.

게이트맨 연동기가 있어야겠죠.

저는 여기서 구매했는데요..

https://shop.11st.co.kr/stores/228714/search?searchKwd=%25EA%25B2%258C%25EC%259D%25B4%25ED%258A%25B8%25EB%25A7%25A8

본인의 도어락이 어떤걸 지원하는지 꼭 확인해보시고.. 자신 없으시면 게이트맨 고객센터에 전화해서 꼭 확인해보시기 바랍니다.

저는 처음에 홈케어로 잘못 구매해서 교환 받았습니다. ㅠㅠ

덕분에 연동기가 하나 더 생겼네요..

그 다음에 저희 집은 그 흔한 월패드 하나 없는 구축 중에 구축 아파트입니다. 그래서 버튼이 하나 필요할 거 같아서..

이것도 구매했습니다.

https://www.ikea.com/kr/ko/p/tradfri-shortcut-button-white-80356384/

이제 준비물이 준비되었으면..

구현해볼까요?

우선.. 최종 구현한 사진입니다.

게이트맨 연동기와 직비 릴레이 크기는 생각보다 작습니다. 가로 10cm, 세로 10cm, 높이 5cm 정도 되는 명함 케이스면 쏙 들어갑니다.

게이트맨 연동기에는 전선이 4가닥 있습니다.

빨간색과 검은색이 전원선입니다.

게이트맨 연동기는 스마트폰 충전기로도 충분히 동작합니다.

직비 릴레이도 스마트폰 충전기로 동작하기 때문에..

저는 아래처럼 전원을 공급하도록 했습니다. 스마트폰 충전기 어뎁처 중에 포트가 2개 있는 어뎁터가 있는데 거기에 케이블 2개를 꼽고 하나는 연동기로 하나는 직비 릴레이로 연결했습니다. 케이블 하나로 2개 장치에 모두 전원을 공급하셔도 되는데.. 저는 그냥 깔끔하게 따로 따로 연결했습니다.


빨간색과 검은색을 전원에 연결하시고 연동기를 도어락에 등록을 하신 다음에 나머지 하얀색과 노란색을 쇼트시켜서 도어락이 정상으로 열리는지 확인해 보시기 바랍니다.

연동기가 제대로 동작하면 이제 하얀색 선과 노란색 선을 직비 릴레이의 3번과 4번에 연결하시면 됩니다.

그 다음에 2번 버튼이 페어링 버튼입니다. 꾹 눌러서 LED 가 번쩍이면 Z2M에 등록하시면 됩니다.

1번 버튼이 모드 버튼입니다. 한번 누르면 스위치 모드이고 다시 한번 누르면 인칭 모드라고 해서 딸깍 켜졌다가 바로 딸깍 꺼지는 모드입니다. 저희는 인칭 모드를 쓸거기 때문에 Z2M에 등록하신 다음에 스위치를 동작해서 확인해 보시고 인칭 모드로 설정하시기 바랍니다.

자.. 이제 연동기와 직비 릴레이가 HA에 등록이 되었으면.. 문 열림 상태에 따른 자동화를 추가해보겠습니다.

그래서 도어 센서가 하나 필요합니다. 도어 센서는 구매하셔서 현관문에 잘 설치해주시고 Z2M에 등록해두시기 바랍니다.

그래서 연동기를 동작시키고 현관문이 열리지 않으면 도어를 잠금 상태로 유지하고 현관문이 열리면 열림 상태로 표현하는 자동화를 구현하겠습니다. 그리고 위에서 얘기한 버튼 관련된 자동화도 하나로 구현했습니다.

먼저 구성하기 > 도우미 에 들어가셔서 토글을 하나 추가해주시기 바랍니다. 이름은 적당히..

다음에 자동화로 가셔서 자동화를 추가하시기 바랍니다.

저는 아래처럼 구현했습니다.

alias: 현관문

description: ''

trigger:

  - type: opened

    platform: device

    device_id: *****

    entity_id: binary_sensor.maindoor_sensor_contact // 도어 센서입니다.

    domain: binary_sensor

    id: open

  - type: not_opened

    platform: device

    device_id: *****

    entity_id: binary_sensor.maindoor_sensor_contact

    domain: binary_sensor

    id: close

  - platform: device

    type: turned_on

    device_id: *****

    entity_id: switch.main_door // 직비 릴레이 스위치입니다.

    domain: switch

    id: switch

  - platform: device

    domain: mqtt

    device_id: ***** // 이케아 직비 버튼입니다.

    type: action

    subtype: 'on'

    discovery_id: ***** action_on

    id: switch2

condition: []

action:

  - choose:

      - conditions:

          - condition: trigger

            id: close

        sequence:

          - service: input_boolean.turn_off // 도우미에서 등록한 토글입니다.

            target:

              entity_id: input_boolean.door

      - conditions:

          - condition: trigger

            id: switch

        sequence:

          - service: input_boolean.turn_on

            target:

              entity_id:

                - input_boolean.door

          - delay:

              hours: 0

              minutes: 0

              seconds: 5 // 시간은 도어락이 자동으로 잠금 상태로 변경되는 시간을 감안해서 조정하시면 됩니다.

              milliseconds: 0

          - type: is_not_open

            condition: device

            device_id: *****

            entity_id: binary_sensor.maindoor_sensor_contact

            domain: binary_sensor

          - service: input_boolean.turn_off

            target:

              entity_id: input_boolean.door

      - conditions:

          - condition: trigger

            id: switch2

        sequence:

          - type: turn_on

            device_id: *****

            entity_id: switch.main_door

            domain: switch

    default:

      - condition: trigger

        id: open

      - service: input_boolean.turn_on

        target:

          entity_id: input_boolean.door

mode: parallel

max: 10

그 다음에 이 도어락을 구글 홈에 등록하기 원하시면 configuration.yaml에

lock:

  - platform: template

    name: 현관

    value_template: "{{ is_state('input_boolean.door', 'off') }}"

    lock:

      - service: input_boolean.turn_off

        target:

          entity_id: input_boolean.door

    unlock:

      - service: switch.turn_on

        target:

          entity_id: switch.main_door

      - service: input_boolean.turn_on

        target:

          entity_id: input_boolean.door

을 추가해주시고 google_assistant: 의 exposed_domains: 에 - lock 을 추가해주시면 구글 홈에서 도어락이 등록되는걸 보실 수 있습니다.

그리고 네스트 허브나 네스트 허브 맥스에서 스위치가 아니라 잠금 장치로 도어락을 제어하시려면

google_assistant: 에 secure_devices_pin: 을 추가하신 다음에 원하는 비밀번호를 입력하시면 됩니다.

구글 홈에 잠금 장치를 추가하는건 옵션이고.. 그냥 직비 릴레이 스위치 등록하셔서 제어하시는게 더 간편하긴 합니다.

혹시 궁금하신거나 더 좋은 아이디어 있으시면 댓글 남겨주시면 고맙겠습니다.

댓글

이 블로그의 인기 게시물

테스트 케이스와 체크리스트의 차이가 뭐여?

테스트 실무에서 가장 혼돈되어 사용되는 용어 중 하나가 테스트 케이스와 체크리스트입니다. 많은 경우 체크리스트를 테스트 케이스로 사용하는 경우가 많습니다. 실제로 인터넷 커뮤니티나 블로그, ISO, IEEE, ISTQB 등등을 검색해보시면 테스트 케이스와 체크리스트에 대한 구분이 다 제각각입니다. 각각에 대한 정의가 다 제각각입니다. 사정이 이러하다보니 많은 사람들이 테스트 케이스와 체크리스트를 잘 구분하지 못하고 혼동해서 사용하는 경우가 많습니다. 물과 기름처럼 테스트 케이스와 체크리스트를 정확하게 구분할 수는 없겠지만.. ISTQB를 기준으로 말씀드리면 설계 기법을 통해 도출된 것은 테스트 케이스 그렇지 않은 것은 체크리스트라고 생각하시면 쉽습니다. 예를 들면 아래는 결정 테이블 테스팅 기법을 통해 도출된 테스트 케이스의 예제입니다. 실제 테스트 케이스는 위보다 복잡하겠지만 어쨌든 얘기하고 싶은 것은 위와 같이 설계 기법을 통해서 도출된 것은 테스트 케이스라고 합니다. 그런데 딱 보시면 아시겠지만 실제 테스트에서는 저 정도로는 테스트 커버리지를 충분히 만족했다고 얘기하기 힘듭니다. 그렇습니다. 어떤 분들은 테스트 케이스가 전가의 보도, 은 총알 쯤으로 생각하시는데.. 테스트 케이스는 일종의 마지노 선이라고 보시면 됩니다. 최소한 제품을 테스트 할때 이정도는 해줘야 한다는 최후의 방어선 정도라고 보시면 됩니다. 전쟁에서 최후의 방어선은 물러설 수 없는 마지막 보루입니다. 하지만 최후의 방어선만 지킨다고 전쟁에서 승리할 수는 없습니다. 프랑스는 마지노 요새만 믿고 있다가 독일에게 깔끔하게 발렸던 과거가 있지요. 전쟁에서 승리하려면 앞으로 나가야하고 치밀한 전략과 전술이 뒷받침 되어야 합니다. 더 높은 커버리지를 도달하고, 충분히 좋은 테스트가 수행되려면 테스트 케이스는 기본이 되어야 하고 거기에 더해서 체크리스트가 따라와 줘야 합니다. 이러한 체크리스트는 팀의 경험과 과거 프로젝트의 데이

비츠 스튜디오 버즈 플러스(투명) 사용 후기

제 내자분은 아직도 유선 이어폰을 쓰고 있습니다. 그게 좋다고 하시더라구요. 작년에 혹시나 해서 앤커 사운드코어 라이프Q35를 구매해서 조공해봤지만 결국은 안쓰시더라구요. 그래서 작년 추운 겨울에 제가 귀마게 용으로 잘 사용해왔는데.. 여름이 되니.. 와.. 이건 너무 덥고 무거워서 못쓰겠더라구요. 아이폰도 사고 애플 워치도 샀으니.. 다음은 에어팟인데.... 노이즈 캔슬링이 된다는 에어팟 프로 2는 ... 네... 너무 비싸더라구요... 이건 내자분께 얘기해봐야 결제가 될리가 없어서... 고민하고 있던차에.. 네.. 저는 봐버리고 말았습니다. 비츠 스튜디오 버즈 플러스의 그 영롱한 투명 버전의 자태를... 급 뽐뿌가 왔지만.. 여전히 20만원의 고가더라구요... 초기 출시 시기에 이벤트로 16만원 정도 했던거 같은데.. 그정도 가격이면 선 결제 후 보고 하면 될거 같은데.. 20만원은 너무 너무 비싸서 침만 삼키던 차에.. 당근에 15만원에 올라온 물건을 덥석 물었습니다. 애플 뮤직 6개월 프로모션 코드도 사용하지 않은 따끈따끈한 제품이라서 그냥 질렀습니다. 이상하게 인터넷이 실제 리뷰 게시물을 찾기 힘들어서.. 고민을 잠깐 했지만.. 그 투명하고 영롱한 자태에 그만... 어쨌든 구매하고 한달 정도 사용해본 후기를 간단하게 남겨봅니다. 1. 노이즈 캔슬링은 기대한 것과는 좀 다르고 앤커 사운드코어 라이프Q35 정도 되는 것 같습니다. 노이즈 캔슬링은 활성화하면 이게 소리를 막아준다기보다는 주변의 작은 소음만 제거해준다고 생각하시면 됩니다. 그러니까 옆에서 소근 거리는 소리나 선풍기 바람 소리 같은 작은 소리들이 사라지고 음악 같은 내가 듣고자 하는 소리가 굉장히 뚜렸해지만 지하철 안내 방송 같은 조금 큰 소리는 그냥 들립니다. 그래서 주변음 허용 모드를 켜보면 너무 시끄러워서 안쓰게 되더라구요. 전 에어팟 프로 2를 사용해 본적이 없어서 비교할 수는 없지만.. 아주 못쓸 정도의 성능은 아니라고 생각됩니다. 2. 저는 귓구멍이 너무 작아서 XS 사이즈의 이어팁

탐색적 테스팅의 역사

이 글은 James Bach 의 ' Exploratory Testing 3.0 '을 번역한 글입니다. 이번 글은 의미를 전달하는데 무리가 없는 선에서 대부분 의역으로 번역되었습니다. 때문에 잘못 번역된 부분은 댓글로 남겨주시면 수정하도록 하겠습니다.(읽어보시면 시제나 문체가 시시각각으로 변합니다. 감안해서 읽어주시면 고맙겠습니다.) 이 글은 James Bach의 허락을 얻은 후 번역한 글로 다른 곳에 퍼가실때는 반드시 원 출처와 본 블로그를 같이 언급해주시기 바랍니다. ----- [저자 주: 다른 글에서 이미 탐색적 테스팅을 이제는 테스팅으로 불러야 한다는 것을 얘기했다. 사실 Michael은 2009년에 테스트에 대해 얘기했었고, James는 테스터에 대해 얘기했던 것을 2010년에 블로그에 작성했다. Aaron Hodder는 2011년에 직접적으로 언급했고 Paul Gerrard 역시 그러했다.우리는 모든 테스팅은 탐색적이라는 것을 깊이 이해하고 가르쳤지만(여기에 James가 작년에 한 학생과 대화를 나눈 예가 있다.), "탐색적 테스팅"이라는 용어를 더이상 사용하지 않을 준비가 되어 있지 않다. 지금도 우리는 탐색적 테스팅이라는 용어를 사용하지 말아야 한다고 주장하지는 않는다. 다만 테스팅이 탐색을 어느 정도 포함한 스크립트 테스팅을 의미하는 것이 아니라 테스팅이 곧 탐색적 테스팅이라는 것이다.] By James Bach and Michael Bolton 태초에 테스팅이 있었다. 아무도 탐색과 스크립트 테스팅을 구별하지 못했다. Jerry Weinberg는 1961년 Computer Programming Fundamentals에서 테스팅의 형식화(formalizing)에 주의를 표명하고 테스팅은 본질적으로 탐색이라고 설명했다. 그는 책에서 "프로그래머의 의도에 대한 많은 정보 없이 프로그램과 프로그래머의 의도가 얼마나 일치하는지 기계적으로 검사하는 것은 어렵다. 만약 검사를 위해 컴퓨터에 간단