OpenClaw용 Google Meet 참가자 지원은 설계상 Plugin이 명시적으로 동작합니다.Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
- 명시적인
https://meet.google.com/...URL에만 참여합니다. - Google Meet API를 통해 새 Meet 공간을 만든 다음 반환된 URL에 참여할 수 있습니다.
agent는 기본 응답 음성 모드입니다. 실시간 전사가 수신하고, 구성된 OpenClaw agent가 답변하며, 일반 OpenClaw TTS가 Meet에서 말합니다.bidi는 직접 실시간 음성 모델 모드의 폴백으로 계속 사용할 수 있습니다.- Agent는
mode로 참여 동작을 선택합니다. 실시간 듣기/응답에는agent, 직접 실시간 음성 폴백에는bidi, 응답 음성 브리지 없이 브라우저에 참여/제어하려면transcribe를 사용합니다. - 인증은 개인 Google OAuth 또는 이미 로그인된 Chrome 프로필로 시작합니다.
- 자동 동의 안내는 없습니다.
- 기본 Chrome 오디오 백엔드는
BlackHole 2ch입니다. - Chrome은 로컬에서 실행하거나 페어링된 Node 호스트에서 실행할 수 있습니다.
- Twilio는 전화 접속 번호와 선택적 PIN 또는 DTMF 시퀀스를 받지만, Meet URL로 직접 전화를 걸 수는 없습니다.
- CLI 명령은
googlemeet입니다.meet는 더 넓은 agent 원격 회의 워크플로용으로 예약되어 있습니다.
빠른 시작
로컬 오디오 종속성을 설치하고 실시간 전사 제공자와 일반 OpenClaw TTS를 구성합니다. OpenAI가 기본 전사 제공자입니다. Google Gemini Live도realtime.voiceProvider: "google"과 함께 별도의 bidi 음성 폴백으로 동작합니다.
blackhole-2ch는 BlackHole 2ch 가상 오디오 장치를 설치합니다. Homebrew 설치 프로그램은 macOS가 장치를 노출하기 전에 재부팅을 요구합니다.
--mode transcribe로 동일한 전송을 확인합니다. 이 모드는 브리지를 통해 듣거나 말하지 않으므로 실시간 오디오 전제 조건을 건너뜁니다.
voice-call Plugin, Twilio 자격 증명, 공개 Webhook 노출 준비 여부도 보고합니다. Agent에게 참여를 요청하기 전에 확인된 전송과 모드에 대해 ok: false 확인은 모두 차단 요인으로 처리합니다. 스크립트나 기계가 읽을 수 있는 출력에는 openclaw googlemeet setup --json을 사용합니다. Agent가 시도하기 전에 특정 전송을 사전 점검하려면 --transport chrome, --transport chrome-node, 또는 --transport twilio를 사용합니다.
Twilio의 경우 기본 전송이 Chrome이면 항상 전송을 명시적으로 사전 점검합니다.
voice-call 연결, Twilio 자격 증명, 또는 접근할 수 없는 Webhook 노출을 잡아낼 수 있습니다.
회의에 참여합니다.
google_meet 도구를 통해 참여하도록 합니다.
google_meet 도구는 macOS가 아닌 호스트에서도 아티팩트, 캘린더, 설정, 전사, Twilio, chrome-node 흐름에 계속 사용할 수 있습니다. 로컬 Chrome 응답 음성 작업은 현재 번들 Chrome 오디오 경로가 macOS BlackHole 2ch에 의존하므로 해당 호스트에서 차단됩니다. Linux에서는 Chrome 응답 음성 참여에 mode: "transcribe", Twilio 전화 접속, 또는 macOS chrome-node 호스트를 사용합니다.
새 회의를 만들고 참여합니다.
SpaceConfig.accessType을 사용합니다.
OPEN은 Meet URL이 있는 누구나 노크 없이 참여할 수 있게 합니다. TRUSTED는 호스트 조직의 신뢰할 수 있는 사용자, 초대된 외부 사용자, 전화 접속 사용자가 노크 없이 참여할 수 있게 합니다. RESTRICTED는 노크 없는 입장을 초대받은 사람으로 제한합니다. 이 설정은 공식 Google Meet API 생성 경로에만 적용되므로 OAuth 자격 증명을 구성해야 합니다.
이 옵션이 제공되기 전에 Google Meet을 인증했다면 Google OAuth 동의 화면에 meetings.space.settings 범위를 추가한 뒤 openclaw googlemeet auth login --json을 다시 실행합니다.
참여하지 않고 URL만 만듭니다.
googlemeet create에는 두 가지 경로가 있습니다.
- API 생성: Google Meet OAuth 자격 증명이 구성된 경우 사용됩니다. 가장 결정적인 경로이며 브라우저 UI 상태에 의존하지 않습니다.
- 브라우저 폴백: OAuth 자격 증명이 없을 때 사용됩니다. OpenClaw는 고정된 Chrome Node를 사용하고,
https://meet.google.com/new를 열고, Google이 실제 회의 코드 URL로 리디렉션할 때까지 기다린 다음 해당 URL을 반환합니다. 이 경로에서는 Node의 OpenClaw Chrome 프로필이 이미 Google에 로그인되어 있어야 합니다. 브라우저 자동화는 Meet 자체의 최초 실행 마이크 프롬프트를 처리합니다. 해당 프롬프트는 Google 로그인 실패로 처리되지 않습니다. 참여 및 생성 흐름은 새 탭을 열기 전에 기존 Meet 탭도 재사용하려고 시도합니다. 매칭은authuser같은 무해한 URL 쿼리 문자열을 무시하므로, agent 재시도는 두 번째 Chrome 탭을 만들기보다 이미 열린 회의에 포커스해야 합니다.
source 필드(api 또는 browser)가 포함됩니다. create는 기본적으로 새 회의에 참여하며 joined: true와 참여 세션을 반환합니다. URL만 만들려면 CLI에서 create --no-join을 사용하거나 도구에 "join": false를 전달합니다.
또는 agent에게 다음처럼 지시합니다. “Google Meet을 만들고, agent 응답 음성 모드로 참여한 다음, 링크를 보내줘.” Agent는 action: "create"로 google_meet를 호출한 다음 반환된 meetingUri를 공유해야 합니다.
"mode": "transcribe"를 설정합니다. 이 모드는 양방향 실시간 음성 브리지를 시작하지 않고, BlackHole이나 SoX가 필요하지 않으며, 회의에서 응답하지 않습니다. 이 모드의 Chrome 참여는 OpenClaw의 마이크/카메라 권한 부여와 Meet 마이크 사용 경로도 피합니다. Meet이 오디오 선택 중간 화면을 표시하면 자동화가 마이크 없는 경로를 시도하고, 그렇지 않으면 로컬 마이크를 열지 않고 수동 작업을 보고합니다. 전사 모드에서 관리형 Chrome 전송은 최선의 Meet 캡션 관찰자도 설치합니다. googlemeet status --json 및 googlemeet doctor는 captioning, captionsEnabledAttempted, transcriptLines, lastCaptionAt, lastCaptionSpeaker, lastCaptionText, 그리고 짧은 recentTranscript 꼬리를 표시하여 운영자가 브라우저가 통화에 참여했는지, Meet 캡션이 텍스트를 생성하는지 확인할 수 있게 합니다.
예/아니요 프로브가 필요할 때는 openclaw googlemeet test-listen <meet-url> --transport chrome-node를 사용합니다. 이 명령은 전사 모드로 참여하고, 새 캡션 또는 전사 변화가 생길 때까지 기다린 뒤 listenVerified, listenTimedOut, 수동 작업 필드, 최신 캡션 상태를 반환합니다.
실시간 세션 중 google_meet 상태에는 inCall, manualActionRequired, providerConnected, realtimeReady, audioInputActive, audioOutputActive, 마지막 입력/출력 타임스탬프, 바이트 카운터, 브리지 닫힘 상태 같은 브라우저 및 오디오 브리지 상태가 포함됩니다. 안전한 Meet 페이지 프롬프트가 나타나면 브라우저 자동화가 가능한 경우 이를 처리합니다. 로그인, 호스트 입장 승인, 브라우저/OS 권한 프롬프트는 agent가 전달할 수 있도록 이유와 메시지가 포함된 수동 작업으로 보고됩니다. 관리형 Chrome 세션은 브라우저 상태가 inCall: true를 보고한 뒤에만 인트로나 테스트 문구를 내보냅니다. 그렇지 않으면 agent가 회의에서 말한 척하지 않고 상태가 speechReady: false를 보고하며 말하기 시도가 차단됩니다.
로컬 Chrome은 로그인된 OpenClaw 브라우저 프로필을 통해 참여합니다. 실시간 모드에는 OpenClaw가 사용하는 마이크/스피커 경로를 위해 BlackHole 2ch가 필요합니다. 깨끗한 양방향 오디오를 위해서는 별도의 가상 장치나 Loopback 스타일 그래프를 사용합니다. 단일 BlackHole 장치도 첫 스모크 테스트에는 충분하지만 에코가 발생할 수 있습니다.
로컬 Gateway + Parallels Chrome
VM이 Chrome을 소유하게 하려고 macOS VM 내부에 전체 OpenClaw Gateway나 모델 API 키가 필요하지는 않습니다. Gateway와 agent를 로컬에서 실행한 다음, VM에서 Node 호스트를 실행합니다. VM에서 번들 Plugin을 한 번 활성화하여 Node가 Chrome 명령을 광고하게 합니다. 각 위치에서 실행되는 항목:- Gateway 호스트: OpenClaw Gateway, agent 작업 영역, 모델/API 키, 실시간 제공자, Google Meet Plugin 구성.
- Parallels macOS VM: OpenClaw CLI/Node 호스트, Google Chrome, SoX, BlackHole 2ch, Google에 로그인된 Chrome 프로필.
- VM에 필요하지 않은 항목: Gateway 서비스, agent 구성, OpenAI/GPT 키, 또는 모델 제공자 설정.
BlackHole 2ch를 노출하도록 VM을 재부팅합니다.
<gateway-host>가 LAN IP이고 TLS를 사용하지 않는 경우, 해당 신뢰된 사설 네트워크에 명시적으로 동의하지 않으면 Node가 평문 WebSocket을 거부합니다.
OPENCLAW_ALLOW_INSECURE_PRIVATE_WS=1은 프로세스 환경이며 openclaw.json 설정이 아닙니다. openclaw node install은 설치 명령에 해당 변수가 있으면 LaunchAgent 환경에 저장합니다.
Gateway 호스트에서 Node를 승인합니다.
googlemeet.chrome 및 브라우저 기능/browser.proxy를 모두 광고하는지 확인합니다.
transport: "chrome-node"로 google_meet 도구를 사용하라고 요청합니다.
세션을 만들거나 재사용하고, 알려진 문구를 말한 뒤, 세션 상태를 출력하는 단일 명령 스모크 테스트:
manualActionRequired: true와 함께 manualActionReason 및
manualActionMessage를 보고합니다. 에이전트는 참여 재시도를 중지하고, 해당
정확한 메시지와 현재 browserUrl/browserTitle을 보고한 뒤, 수동 브라우저
작업이 완료된 후에만 다시 시도해야 합니다.
chromeNode.node가 생략되면, 정확히 하나의 연결된 Node가
googlemeet.chrome과 브라우저 제어를 모두 알릴 때만 OpenClaw가 자동 선택합니다.
여러 개의 가능한 Node가 연결되어 있으면 chromeNode.node를 Node ID,
표시 이름 또는 원격 IP로 설정하세요.
일반적인 실패 확인:
Configured Google Meet node ... is not usable: offline: 고정된 Node는 Gateway에 알려져 있지만 사용할 수 없습니다. 에이전트는 해당 Node를 사용할 수 있는 Chrome 호스트가 아니라 진단 상태로 취급해야 하며, 사용자가 요청하지 않은 한 다른 전송으로 대체하지 말고 설정 차단 요인을 보고해야 합니다.No connected Google Meet-capable node: VM에서openclaw node run을 시작하고, 페어링을 승인한 뒤, VM에서openclaw plugins enable google-meet및openclaw plugins enable browser가 실행되었는지 확인하세요. 또한 Gateway 호스트가gateway.nodes.allowCommands: ["googlemeet.chrome", "browser.proxy"]로 두 Node 명령을 모두 허용하는지 확인하세요.BlackHole 2ch audio device not found: 확인 중인 호스트에blackhole-2ch를 설치하고 로컬 Chrome 오디오를 사용하기 전에 재부팅하세요.BlackHole 2ch audio device not found on the node: VM에blackhole-2ch를 설치하고 VM을 재부팅하세요.- Chrome이 열리지만 참여할 수 없음: VM 안의 브라우저 프로필에 로그인하거나,
게스트 참여를 위해
chrome.guestName을 설정된 상태로 유지하세요. 게스트 자동 참여는 Node 브라우저 프록시를 통한 OpenClaw 브라우저 자동화를 사용합니다. Node 브라우저 구성이 원하는 프로필을 가리키는지 확인하세요. 예:browser.defaultProfile: "user"또는 이름이 지정된 기존 세션 프로필. - 중복 Meet 탭:
chrome.reuseExistingTab: true를 활성화된 상태로 두세요. OpenClaw는 새 탭을 열기 전에 같은 Meet URL의 기존 탭을 활성화하며, 브라우저 회의 생성은 다른 탭을 열기 전에 진행 중인https://meet.google.com/new또는 Google 계정 프롬프트 탭을 재사용합니다. - 오디오 없음: Meet에서 마이크/스피커를 OpenClaw가 사용하는 가상 오디오 장치 경로를 통해 라우팅하세요. 깨끗한 양방향 오디오를 위해 별도의 가상 장치 또는 Loopback 방식 라우팅을 사용하세요.
설치 참고 사항
Chrome talk-back 기본값은 두 가지 외부 도구를 사용합니다.sox: 명령줄 오디오 유틸리티입니다. Plugin은 기본 24 kHz PCM16 오디오 브리지를 위해 명시적인 CoreAudio 장치 명령을 사용합니다.blackhole-2ch: macOS 가상 오디오 드라이버입니다. Chrome/Meet가 라우팅할 수 있는BlackHole 2ch오디오 장치를 만듭니다.
LGPL-2.0-only AND GPL-2.0-only이고, BlackHole은 GPL-3.0입니다. BlackHole을
OpenClaw와 함께 번들로 포함하는 설치 프로그램이나 어플라이언스를 빌드하는 경우,
BlackHole의 업스트림 라이선스 조건을 검토하거나 Existential Audio에서 별도
라이선스를 받으세요.
전송
Chrome
Chrome 전송은 OpenClaw 브라우저 제어를 통해 Meet URL을 열고 로그인된 OpenClaw 브라우저 프로필로 참여합니다. macOS에서 Plugin은 실행 전에BlackHole 2ch를
확인합니다. 구성된 경우 Chrome을 열기 전에 오디오 브리지 상태 명령과 시작 명령도
실행합니다. Chrome/오디오가 Gateway 호스트에 있을 때는 chrome을 사용하고,
Chrome/오디오가 Parallels macOS VM 같은 페어링된 Node에 있을 때는 chrome-node를
사용하세요. 로컬 Chrome의 경우 browser.defaultProfile로 프로필을 선택하세요.
chrome.browserProfile은 chrome-node 호스트에 전달됩니다.
BlackHole 2ch가 설치되어 있지 않으면, 참여는 오디오 경로 없이 조용히 참여하는
대신 설정 오류와 함께 실패합니다.
Twilio
Twilio 전송은 Voice Call Plugin에 위임되는 엄격한 다이얼 플랜입니다. Meet 페이지에서 전화번호를 파싱하지 않습니다. Chrome 참여를 사용할 수 없거나 전화 접속 대체 경로가 필요할 때 사용하세요. Google Meet는 회의에 대한 전화 접속 번호와 PIN을 노출해야 합니다. OpenClaw는 Meet 페이지에서 이를 발견하지 않습니다. Voice Call Plugin은 Chrome Node가 아니라 Gateway 호스트에서 활성화하세요.openclaw.json 밖에 둘 수 있습니다.
OPENAI_API_KEY와 함께 realtime.provider: "openai"를 사용하세요.
voice-call을 활성화한 뒤 Gateway를 재시작하거나 다시 로드하세요. Plugin 구성
변경은 이미 실행 중인 Gateway 프로세스가 다시 로드되기 전까지 나타나지 않습니다.
그런 다음 확인하세요.
googlemeet setup에는 성공한
twilio-voice-call-plugin, twilio-voice-call-credentials,
twilio-voice-call-webhook 확인이 포함됩니다.
--dtmf-sequence를 사용하세요.
OAuth 및 사전 검사
googlemeet create가 브라우저 자동화로 대체될 수 있으므로 Meet 링크 생성에는
OAuth가 선택 사항입니다. 공식 API 생성, 스페이스 확인 또는 Meet Media API 사전
검사가 필요할 때 OAuth를 구성하세요.
Google Meet API 접근은 사용자 OAuth를 사용합니다. Google Cloud OAuth 클라이언트를
만들고, 필요한 범위를 요청하고, Google 계정을 승인한 다음, 결과 refresh token을
Google Meet Plugin 구성에 저장하거나 OPENCLAW_GOOGLE_MEET_* 환경 변수를
제공하세요.
OAuth는 Chrome 참여 경로를 대체하지 않습니다. Chrome 및 Chrome-node 전송은
브라우저 참여를 사용할 때 여전히 로그인된 Chrome 프로필, BlackHole/SoX 및 연결된
Node를 통해 참여합니다. OAuth는 공식 Google Meet API 경로에만 사용됩니다. 회의
스페이스 생성, 스페이스 확인 및 Meet Media API 사전 검사를 실행합니다.
Google 자격 증명 생성
Google Cloud Console에서:- Google Cloud 프로젝트를 만들거나 선택합니다.
- 해당 프로젝트에 Google Meet REST API를 활성화합니다.
-
OAuth 동의 화면을 구성합니다.
- Internal은 Google Workspace 조직에 가장 간단합니다.
- External은 개인/테스트 설정에 사용할 수 있습니다. 앱이 Testing 상태인 동안 앱을 승인할 각 Google 계정을 테스트 사용자로 추가하세요.
-
OpenClaw가 요청하는 범위를 추가합니다.
https://www.googleapis.com/auth/meetings.space.createdhttps://www.googleapis.com/auth/meetings.space.readonlyhttps://www.googleapis.com/auth/meetings.space.settingshttps://www.googleapis.com/auth/meetings.conference.media.readonly
-
OAuth 클라이언트 ID를 만듭니다.
- 애플리케이션 유형: Web application.
-
승인된 리디렉션 URI:
- 클라이언트 ID와 클라이언트 보안 비밀을 복사합니다.
meetings.space.created는 Google Meet spaces.create에 필요합니다.
meetings.space.readonly를 사용하면 OpenClaw가 Meet URL/코드를 스페이스로 확인할
수 있습니다. meetings.space.settings를 사용하면 OpenClaw가 API 방 생성 중
accessType 같은 SpaceConfig 설정을 전달할 수 있습니다.
meetings.conference.media.readonly는 Meet Media API 사전 검사와 미디어 작업을
위한 것입니다. 실제 Media API 사용에는 Google이 Developer Preview 등록을 요구할
수 있습니다. 브라우저 기반 Chrome 참여만 필요하다면 OAuth를 완전히 건너뛰세요.
refresh token 발급
oauth.clientId와 선택적으로 oauth.clientSecret을 구성하거나 환경 변수로 전달한
다음 실행하세요.
oauth 구성 블록을 출력합니다. PKCE,
http://localhost:8085/oauth2callback의 localhost 콜백, 그리고 --manual을 통한
수동 복사/붙여넣기 흐름을 사용합니다.
예:
oauth 객체를 Google Meet Plugin 구성 아래에 저장하세요.
meetings.space.created 범위가 있도록 openclaw googlemeet auth login --json을
다시 실행하세요.
doctor로 OAuth 확인
빠르고 비밀 값을 노출하지 않는 상태 확인이 필요할 때 OAuth doctor를 실행하세요.ok, configured, tokenSource, expiresAt 및 확인
메시지 같은 상태 필드만 포함됩니다. access token, refresh token 또는 클라이언트
보안 비밀은 출력하지 않습니다.
일반적인 결과:
| 검사 | 의미 |
|---|---|
oauth-config | oauth.clientId와 oauth.refreshToken, 또는 캐시된 액세스 토큰이 있습니다. |
oauth-token | 캐시된 액세스 토큰이 아직 유효하거나, 리프레시 토큰이 새 액세스 토큰을 발급했습니다. |
meet-spaces-get | 선택적 --meeting 검사가 기존 Meet 스페이스를 확인했습니다. |
meet-spaces-create | 선택적 --create-space 검사가 새 Meet 스페이스를 만들었습니다. |
spaces.create 범위도 증명하려면 부작용이 있는
생성 검사를 실행하세요.
--create-space는 임시 Meet URL을 만듭니다. Google Cloud 프로젝트에서 Meet API가
활성화되어 있고, 승인된 계정에 meetings.space.created 범위가 있는지 확인해야 할 때 사용하세요.
기존 회의 스페이스에 대한 읽기 액세스를 증명하려면 다음을 실행하세요.
doctor --oauth --meeting과 resolve-space는 승인된 Google 계정이 액세스할 수 있는
기존 스페이스에 대한 읽기 액세스를 증명합니다. 이 검사에서 403이 반환되면
보통 Google Meet REST API가 비활성화되어 있거나, 동의한 리프레시 토큰에 필요한
범위가 없거나, Google 계정이 해당 Meet 스페이스에 액세스할 수 없다는 뜻입니다.
리프레시 토큰 오류는 openclaw googlemeet auth login --json을 다시 실행하고
새 oauth 블록을 저장해야 한다는 뜻입니다.
브라우저 대체 경로에는 OAuth 자격 증명이 필요하지 않습니다. 이 모드에서는 Google
인증이 OpenClaw 구성에서 오지 않고, 선택한 Node에서 로그인된 Chrome 프로필에서 옵니다.
다음 환경 변수를 대체값으로 사용할 수 있습니다.
OPENCLAW_GOOGLE_MEET_CLIENT_ID또는GOOGLE_MEET_CLIENT_IDOPENCLAW_GOOGLE_MEET_CLIENT_SECRET또는GOOGLE_MEET_CLIENT_SECRETOPENCLAW_GOOGLE_MEET_REFRESH_TOKEN또는GOOGLE_MEET_REFRESH_TOKENOPENCLAW_GOOGLE_MEET_ACCESS_TOKEN또는GOOGLE_MEET_ACCESS_TOKENOPENCLAW_GOOGLE_MEET_ACCESS_TOKEN_EXPIRES_AT또는GOOGLE_MEET_ACCESS_TOKEN_EXPIRES_ATOPENCLAW_GOOGLE_MEET_DEFAULT_MEETING또는GOOGLE_MEET_DEFAULT_MEETINGOPENCLAW_GOOGLE_MEET_PREVIEW_ACK또는GOOGLE_MEET_PREVIEW_ACK
spaces/{id}를 spaces.get을 통해 확인합니다.
--meeting을 사용하면 artifacts와 attendance는 기본적으로 최신 컨퍼런스 레코드를
사용합니다. 해당 회의에 보존된 모든 레코드가 필요하면 --all-conference-records를
전달하세요.
Meet 아티팩트를 읽기 전에 Calendar 조회로 Google Calendar에서 회의 URL을 확인할 수 있습니다.
--today는 오늘의 primary Calendar에서 Google Meet 링크가 있는 Calendar 이벤트를
검색합니다. 일치하는 이벤트 텍스트를 검색하려면 --event <query>를 사용하고,
기본이 아닌 Calendar에는 --calendar <id>를 사용하세요. Calendar 조회에는 Calendar
이벤트 읽기 전용 범위를 포함하는 새 OAuth 로그인이 필요합니다. calendar-events는
일치하는 Meet 이벤트를 미리 보여 주고 latest, artifacts, attendance, 또는
export가 선택할 이벤트를 표시합니다.
컨퍼런스 레코드 ID를 이미 알고 있다면 직접 지정하세요.
spaces.endActiveConference를 호출하며, 승인된 계정이 관리할 수 있는
스페이스에 대해 meetings.space.created 범위가 있는 OAuth가 필요합니다.
OpenClaw는 Meet URL, 회의 코드, 또는 spaces/{id} 입력을 받아 활성 컨퍼런스를
종료하기 전에 API 스페이스 리소스로 확인합니다. 이는 googlemeet leave와 별개입니다.
leave는 OpenClaw의 로컬/세션 참여를 중지하지만, end-active-conference는
Google Meet에 해당 스페이스의 활성 컨퍼런스를 종료하도록 요청합니다.
읽기 쉬운 보고서를 작성하세요.
artifacts는 Google이 해당 회의에 대해 제공하는 경우 컨퍼런스 레코드 메타데이터와
참가자, 녹화, 스크립트, 구조화된 스크립트 항목, 스마트 노트 리소스 메타데이터를 반환합니다.
큰 회의에서 항목 조회를 건너뛰려면 --no-transcript-entries를 사용하세요. attendance는
참가자를 참가자 세션 행으로 확장하며, 최초/마지막 확인 시간, 총 세션 지속 시간,
지각/조기 퇴장 플래그, 로그인 사용자 또는 표시 이름 기준으로 병합된 중복 참가자 리소스를
포함합니다. 원시 참가자 리소스를 별도로 유지하려면 --no-merge-duplicates를 전달하고,
지각 감지를 조정하려면 --late-after-minutes, 조기 퇴장 감지를 조정하려면
--early-before-minutes를 전달하세요.
export는 summary.md, attendance.csv, transcript.md, artifacts.json,
attendance.json, manifest.json이 포함된 폴더를 작성합니다. manifest.json은
선택된 입력, 내보내기 옵션, 컨퍼런스 레코드, 출력 파일, 개수, 토큰 소스, 사용된 경우
Calendar 이벤트, 그리고 부분 검색 경고를 기록합니다. 폴더 옆에 이동 가능한 아카이브도
작성하려면 --zip을 전달하세요. 연결된 스크립트와 스마트 노트 Google Docs 텍스트를
Google Drive files.export를 통해 내보내려면 --include-doc-bodies를 전달하세요.
여기에는 Drive Meet 읽기 전용 범위를 포함하는 새 OAuth 로그인이 필요합니다.
--include-doc-bodies가 없으면 내보내기에는 Meet 메타데이터와 구조화된 스크립트 항목만
포함됩니다. Google이 스마트 노트 목록, 스크립트 항목, 또는 Drive 문서 본문 오류 같은
부분 아티팩트 실패를 반환하면 전체 내보내기를 실패시키는 대신 요약과 매니페스트에
경고가 유지됩니다. 폴더나 ZIP을 만들지 않고 같은 아티팩트/참석 데이터를 가져와
매니페스트 JSON을 출력하려면 --dry-run을 사용하세요. 큰 내보내기를 작성하기 전이나
에이전트에 개수, 선택된 레코드, 경고만 필요할 때 유용합니다.
에이전트는 google_meet 도구를 통해 같은 번들을 만들 수도 있습니다.
"dryRun": true를 설정하세요.
에이전트는 명시적인 액세스 정책으로 API 기반 방을 만들 수도 있습니다.
test_listen을
사용해야 합니다.
OPENCLAW_LIVE_TEST=1은 보호된 라이브 테스트를 활성화합니다.OPENCLAW_GOOGLE_MEET_LIVE_MEETING은 보존된 Meet URL, 코드, 또는spaces/{id}를 가리킵니다.OPENCLAW_GOOGLE_MEET_CLIENT_ID또는GOOGLE_MEET_CLIENT_ID는 OAuth 클라이언트 ID를 제공합니다.OPENCLAW_GOOGLE_MEET_REFRESH_TOKEN또는GOOGLE_MEET_REFRESH_TOKEN은 리프레시 토큰을 제공합니다.- 선택 사항:
OPENCLAW_GOOGLE_MEET_CLIENT_SECRET,OPENCLAW_GOOGLE_MEET_ACCESS_TOKEN, 그리고OPENCLAW_GOOGLE_MEET_ACCESS_TOKEN_EXPIRES_AT은OPENCLAW_접두사가 없는 같은 대체 이름을 사용합니다.
https://www.googleapis.com/auth/meetings.space.readonly와
https://www.googleapis.com/auth/meetings.conference.media.readonly가 필요합니다.
Calendar 조회에는 https://www.googleapis.com/auth/calendar.events.readonly가 필요합니다.
Drive 문서 본문 내보내기에는
https://www.googleapis.com/auth/drive.meet.readonly가 필요합니다.
새 Meet 스페이스를 만드세요.
meeting uri, 소스, 참여 세션을 출력합니다. OAuth 자격 증명이 있으면
공식 Google Meet API를 사용합니다. OAuth 자격 증명이 없으면 고정된 Chrome Node의
로그인된 브라우저 프로필을 대체 경로로 사용합니다. 에이전트는 action: "create"와 함께
google_meet 도구를 사용해 한 단계로 만들고 참여할 수 있습니다. URL만 만들려면
"join": false를 전달하세요.
브라우저 대체 경로의 예시 JSON 출력:
google_meet 도구는 일반 문자열 대신
구조화된 세부 정보를 반환합니다.
manualActionRequired: true를 보면 manualActionMessage와 브라우저
Node/탭 컨텍스트를 보고하고, 운영자가 브라우저 단계를 완료할 때까지 새 Meet 탭을
열지 않아야 합니다.
API 생성의 예시 JSON 출력:
manualActionRequired: true 또는 브라우저 폴백 오류를 보고하고, 다시 시도하기 전에 운영자에게 Google 로그인을 완료하라고 요청합니다.
Cloud 프로젝트, OAuth 주체, 회의 참가자가 Meet 미디어 API용 Google Workspace Developer Preview Program에 등록되어 있음을 확인한 후에만 preview.enrollmentAcknowledged: true를 설정하세요.
구성
공통 Chrome 에이전트 경로에는 Plugin 활성화, BlackHole, SoX, 실시간 전사 제공자 키, 구성된 OpenClaw TTS 제공자만 필요합니다. OpenAI가 기본 전사 제공자입니다. 기본 에이전트 모드 전사 제공자를 변경하지 않고bidi 모드에서 Google Gemini Live를 사용하려면 realtime.voiceProvider를 "google"로, realtime.model을 설정하세요.
plugins.entries.google-meet.config 아래에 Plugin 구성을 설정하세요.
defaultTransport: "chrome"defaultMode: "agent"("realtime"은"agent"의 레거시 호환성 별칭으로만 허용됩니다. 새 도구 호출은"agent"라고 해야 합니다.)chromeNode.node:chrome-node의 선택적 노드 id/이름/IPchrome.audioBackend: "blackhole-2ch"chrome.guestName: "OpenClaw Agent": 로그아웃된 Meet 게스트 화면에서 사용되는 이름chrome.autoJoin: true:chrome-node에서 OpenClaw 브라우저 자동화를 통해 최선의 방식으로 게스트 이름을 채우고 Join Now를 클릭합니다.chrome.reuseExistingTab: true: 중복으로 열지 않고 기존 Meet 탭을 활성화합니다.chrome.waitForInCallMs: 20000: 되말하기 소개가 트리거되기 전에 Meet 탭이 통화 중이라고 보고할 때까지 기다립니다.chrome.audioFormat: "pcm16-24khz": 명령 쌍 오디오 형식입니다. 여전히 전화 통신 오디오를 내보내는 레거시/사용자 지정 명령 쌍에만"g711-ulaw-8khz"를 사용하세요.chrome.audioBufferBytes: 4096: 생성된 Chrome 명령 쌍 오디오 명령용 SoX 처리 버퍼입니다. 이는 SoX 기본 8192바이트 버퍼의 절반으로, 사용량이 많은 호스트에서 늘릴 여지를 남기면서 기본 파이프 지연 시간을 줄입니다. SoX의 최소값보다 낮은 값은 17바이트로 고정됩니다.chrome.audioInputCommand: CoreAudioBlackHole 2ch에서 읽고chrome.audioFormat으로 오디오를 쓰는 SoX 명령chrome.audioOutputCommand:chrome.audioFormat으로 오디오를 읽고 CoreAudioBlackHole 2ch에 쓰는 SoX 명령chrome.bargeInInputCommand: 어시스턴트 재생이 활성 상태인 동안 사람의 끼어들기 감지를 위해 부호 있는 16비트 리틀 엔디언 모노 PCM을 쓰는 선택적 로컬 마이크 명령입니다. 현재 이는 Gateway가 호스팅하는chrome명령 쌍 브리지에 적용됩니다.chrome.bargeInRmsThreshold: 650:chrome.bargeInInputCommand에서 사람의 중단으로 간주되는 RMS 레벨chrome.bargeInPeakThreshold: 2500:chrome.bargeInInputCommand에서 사람의 중단으로 간주되는 피크 레벨chrome.bargeInCooldownMs: 900: 반복되는 사람 중단 해제 사이의 최소 지연 시간mode: "agent": 기본 되말하기 모드입니다. 참가자 음성은 구성된 실시간 전사 제공자가 전사하고, 회의별 하위 에이전트 세션의 구성된 OpenClaw 에이전트로 전송되며, 일반 OpenClaw TTS 런타임을 통해 다시 음성으로 출력됩니다.mode: "bidi": 폴백 직접 양방향 실시간 모델 모드입니다. 실시간 음성 제공자가 참가자 음성에 직접 응답하며, 더 깊거나 도구 기반인 답변을 위해openclaw_agent_consult를 호출할 수 있습니다.mode: "transcribe": 되말하기 브리지 없는 관찰 전용 모드입니다.realtime.provider: "openai": 아래의 범위 지정 제공자 필드가 설정되지 않았을 때 사용되는 호환성 폴백입니다.realtime.transcriptionProvider: "openai":agent모드에서 실시간 전사에 사용하는 제공자 id입니다.realtime.voiceProvider:bidi모드에서 직접 실시간 음성에 사용하는 제공자 id입니다. 에이전트 모드 전사는 OpenAI로 유지하면서 Gemini Live를 사용하려면 이를"google"로 설정하세요.realtime.toolPolicy: "safe-read-only"realtime.instructions: 더 깊은 답변에는openclaw_agent_consult를 사용하는 간단한 음성 답변realtime.introMessage: 실시간 브리지가 연결될 때의 짧은 음성 준비 확인입니다. 조용히 참여하려면 이를""로 설정하세요.realtime.agentId:openclaw_agent_consult용 선택적 OpenClaw 에이전트 id입니다. 기본값은main입니다.
messages.tts.providers.elevenlabs.voiceId에서 옵니다. TTS 모델 재정의가 활성화된 경우 에이전트 응답은 응답별 [[tts:voiceId=... model=eleven_v3]] 지시문도 사용할 수 있지만, 회의에서는 구성이 결정적인 기본값입니다. 참여 시 로그에는 transcriptionProvider=elevenlabs가 표시되어야 하며, 각 음성 응답은 provider=elevenlabs model=eleven_v3 voice=<voiceId>를 기록해야 합니다.
Twilio 전용 구성:
voiceCall.enabled의 기본값은 true입니다. Twilio 전송에서는 실제 PSTN 통화, DTMF, 소개 인사를 Voice Call Plugin에 위임합니다. Voice Call은 실시간 미디어 스트림을 열기 전에 DTMF 시퀀스를 재생한 다음, 저장된 소개 텍스트를 초기 실시간 인사로 사용합니다. voice-call이 활성화되어 있지 않으면 Google Meet는 여전히 다이얼 플랜을 검증하고 기록할 수 있지만 Twilio 통화를 걸 수는 없습니다.
도구
에이전트는google_meet 도구를 사용할 수 있습니다.
transport: "chrome"을 사용하세요. Chrome이 Parallels VM 같은 페어링된 노드에서 실행될 때는 transport: "chrome-node"를 사용하세요. 두 경우 모두 모델 제공자와 openclaw_agent_consult는 Gateway 호스트에서 실행되므로 모델 자격 증명은 그곳에 유지됩니다. 기본 mode: "agent"에서는 실시간 전사 제공자가 듣기를 처리하고, 구성된 OpenClaw 에이전트가 답변을 생성하며, 일반 OpenClaw TTS가 이를 Meet로 말합니다. 실시간 음성 모델이 직접 답변하게 하려면 mode: "bidi"를 사용하세요. 원시 mode: "realtime"은 mode: "agent"의 레거시 호환성 별칭으로 계속 허용되지만, 더 이상 에이전트 도구 스키마에 표시되지 않습니다. 에이전트 모드 로그에는 브리지 시작 시 해석된 전사 제공자/모델과 각 합성 응답 후의 TTS 제공자, 모델, 음성, 출력 형식, 샘플 속도가 포함됩니다.
활성 세션을 나열하거나 세션 ID를 검사하려면 action: "status"를 사용하세요. 실시간 에이전트가 즉시 말하게 하려면 sessionId와 message와 함께 action: "speak"를 사용하세요. 세션을 만들거나 재사용하고, 알려진 문구를 트리거하며, Chrome 호스트가 보고할 수 있을 때 inCall 상태를 반환하려면 action: "test_speech"를 사용하세요. test_speech는 항상 mode: "agent"를 강제하며, 관찰 전용 세션은 의도적으로 음성을 내보낼 수 없기 때문에 mode: "transcribe"로 실행하라는 요청을 받으면 실패합니다. 그 speechOutputVerified 결과는 이 테스트 호출 중 실시간 오디오 출력 바이트가 증가했는지를 기반으로 하므로, 이전 오디오가 있는 재사용된 세션은 새로 성공한 음성 확인으로 간주되지 않습니다. 세션을 종료됨으로 표시하려면 action: "leave"를 사용하세요.
status에는 사용 가능한 경우 Chrome 상태가 포함됩니다.
inCall: Chrome이 Meet 통화 안에 있는 것으로 보입니다.micMuted: 최선의 방식으로 확인한 Meet 마이크 상태manualActionRequired/manualActionReason/manualActionMessage: 음성이 작동하기 전에 브라우저 프로필에 수동 로그인, Meet 호스트 승인, 권한 또는 브라우저 제어 복구가 필요합니다.speechReady/speechBlockedReason/speechBlockedMessage: 관리되는 Chrome 음성이 지금 허용되는지 여부입니다.speechReady: false는 OpenClaw가 소개/테스트 문구를 오디오 브리지로 보내지 않았음을 의미합니다.providerConnected/realtimeReady: 실시간 음성 브리지 상태lastInputAt/lastOutputAt: 브리지에서 마지막으로 보거나 브리지로 보낸 오디오audioOutputRouted/audioOutputDeviceLabel: Meet 탭의 미디어 출력이 브리지에서 사용하는 BlackHole 장치로 능동적으로 라우팅되었는지 여부lastSuppressedInputAt/suppressedInputBytes: 어시스턴트 재생이 활성 상태인 동안 무시된 loopback 입력
에이전트 및 Bidi 모드
Chromeagent 모드는 “내 에이전트가 회의에 들어와 있는” 동작에 최적화되어 있습니다. 실시간 전사 제공자가 회의 오디오를 듣고, 최종 참가자 전사는 구성된 OpenClaw 에이전트로 라우팅되며, 답변은 일반 OpenClaw TTS 런타임을 통해 음성으로 출력됩니다. 실시간 음성 모델이 직접 답변하게 하려면 mode: "bidi"를 설정하세요. 가까운 최종 전사 조각들은 consult 전에 병합되어 한 번의 발화 턴이 여러 개의 오래된 부분 답변을 만들지 않도록 합니다. 대기 중인 어시스턴트 오디오가 아직 재생되는 동안에는 실시간 입력도 억제되며, 에이전트 consult 전에 최근의 어시스턴트와 유사한 전사 에코가 무시되어 BlackHole loopback 때문에 에이전트가 자기 자신의 말에 답하지 않도록 합니다.
| 모드 | 누가 답변을 결정하는가 | 음성 출력 경로 | 사용 시점 |
|---|---|---|---|
agent | 구성된 OpenClaw 에이전트 | 일반 OpenClaw TTS 런타임 | ”내 에이전트가 회의에 들어와 있는” 동작을 원할 때 |
bidi | 실시간 음성 모델 | 실시간 음성 제공자 오디오 응답 | 가장 낮은 지연 시간의 대화형 음성 루프를 원할 때 |
bidi 모드에서 실시간 모델에 더 깊은 추론, 최신 정보 또는 일반 OpenClaw 도구가 필요하면 openclaw_agent_consult를 호출할 수 있습니다.
consult 도구는 최근 회의 트랜스크립트 컨텍스트와 함께 일반 OpenClaw 에이전트를 백그라운드에서 실행하고 간결한 음성 답변을 반환합니다. agent 모드에서는 OpenClaw가 해당 답변을 TTS 런타임으로 직접 전송하고, bidi 모드에서는 실시간 음성 모델이 consult 결과를 회의에 다시 말할 수 있습니다. Voice Call과 동일한 공유 consult 메커니즘을 사용합니다.
기본적으로 consult는 main 에이전트를 대상으로 실행됩니다. Meet 레인이 전용 OpenClaw 에이전트 워크스페이스, 모델 기본값, 도구 정책, 메모리, 세션 기록을 consult해야 할 때는 realtime.agentId를 설정하세요.
에이전트 모드 consult는 회의별 agent:<id>:subagent:google-meet:<session> 세션 키를 사용하므로, 후속 질문은 구성된 에이전트의 일반 에이전트 정책을 상속하면서 회의 컨텍스트를 유지합니다.
realtime.toolPolicy는 consult 실행을 제어합니다.
safe-read-only: consult 도구를 노출하고 일반 에이전트를read,web_search,web_fetch,x_search,memory_search,memory_get으로 제한합니다.owner: consult 도구를 노출하고 일반 에이전트가 일반 에이전트 도구 정책을 사용하도록 합니다.none: 실시간 음성 모델에 consult 도구를 노출하지 않습니다.
라이브 테스트 체크리스트
무인 에이전트에 회의를 넘기기 전에 이 순서를 사용하세요.googlemeet setup이 모두 녹색입니다.- Chrome-node가 기본 전송이거나 노드가 고정된 경우
googlemeet setup에chrome-node-connected가 포함됩니다. nodes status에 선택된 노드가 연결된 것으로 표시됩니다.- 선택된 노드가
googlemeet.chrome와browser.proxy를 모두 광고합니다. - Meet 탭이 통화에 참가하고
test-speech가inCall: true와 함께 Chrome 상태를 반환합니다.
googlemeet setup에 녹색twilio-voice-call-plugin,twilio-voice-call-credentials,twilio-voice-call-webhook확인이 포함됩니다.- Gateway를 다시 로드한 뒤 CLI에서
voicecall을 사용할 수 있습니다. - 반환된 세션에
transport: "twilio"와twilio.voiceCallId가 있습니다. openclaw logs --follow에 실시간 TwiML 전에 DTMF TwiML이 제공되고, 이후 초기 인사말이 대기열에 들어간 실시간 브리지가 표시됩니다.googlemeet leave <sessionId>가 위임된 음성 통화를 끊습니다.
문제 해결
에이전트가 Google Meet 도구를 볼 수 없음
Gateway 구성에서 Plugin이 활성화되어 있는지 확인하고 Gateway를 다시 로드하세요.plugins.entries.google-meet를 편집했다면 Gateway를 재시작하거나 다시 로드하세요. 실행 중인 에이전트는 현재 Gateway 프로세스가 등록한 Plugin 도구만 볼 수 있습니다.
macOS가 아닌 Gateway 호스트에서는 에이전트용 google_meet 도구가 계속 표시되지만, 로컬 Chrome talk-back 작업은 오디오 브리지에 도달하기 전에 차단됩니다. 로컬 Chrome talk-back 오디오는 현재 macOS BlackHole 2ch에 의존하므로, Linux 에이전트는 기본 로컬 Chrome 에이전트 경로 대신 mode: "transcribe", Twilio 전화 접속 또는 macOS chrome-node 호스트를 사용해야 합니다.
연결된 Google Meet 지원 노드 없음
노드 호스트에서 실행하세요.googlemeet.chrome와 browser.proxy를 나열해야 합니다. Gateway 구성은 해당 노드 명령을 허용해야 합니다.
googlemeet setup이 chrome-node-connected에서 실패하거나 Gateway 로그가 gateway token mismatch를 보고하면, 현재 Gateway 토큰으로 노드를 다시 설치하거나 재시작하세요. LAN Gateway의 경우 일반적으로 다음을 의미합니다.
브라우저는 열리지만 에이전트가 참가할 수 없음
관찰 전용 참가의 경우googlemeet test-listen을 실행하거나 실시간 참가의 경우 googlemeet test-speech를 실행한 다음 반환된 Chrome 상태를 검사하세요. 두 프로브 중 하나가 manualActionRequired: true를 보고하면 운영자에게 manualActionMessage를 보여주고 브라우저 작업이 완료될 때까지 재시도를 중단하세요.
일반적인 수동 작업:
- Chrome 프로필에 로그인합니다.
- Meet 호스트 계정에서 게스트를 승인합니다.
- Chrome의 기본 권한 프롬프트가 나타나면 Chrome 마이크/카메라 권한을 부여합니다.
- 멈춘 Meet 권한 대화 상자를 닫거나 복구합니다.
회의 생성 실패
googlemeet create는 OAuth 자격 증명이 구성되어 있을 때 먼저 Google Meet API spaces.create 엔드포인트를 사용합니다. OAuth 자격 증명이 없으면 고정된 Chrome 노드 브라우저로 fallback합니다. 확인하세요.
- API 생성:
oauth.clientId와oauth.refreshToken이 구성되어 있거나, 일치하는OPENCLAW_GOOGLE_MEET_*환경 변수가 있어야 합니다. - API 생성: 새로 만들기 지원이 추가된 뒤 refresh token이 발급되었어야 합니다. 오래된 토큰에는
meetings.space.createdscope가 없을 수 있습니다.openclaw googlemeet auth login --json을 다시 실행하고 Plugin 구성을 업데이트하세요. - 브라우저 fallback:
defaultTransport: "chrome-node"와chromeNode.node가browser.proxy및googlemeet.chrome가 있는 연결된 노드를 가리켜야 합니다. - 브라우저 fallback: 해당 노드의 OpenClaw Chrome 프로필이 Google에 로그인되어 있고
https://meet.google.com/new를 열 수 있어야 합니다. - 브라우저 fallback: 재시도는 새 탭을 열기 전에 기존
https://meet.google.com/new또는 Google 계정 프롬프트 탭을 재사용합니다. 에이전트가 시간 초과되면 다른 Meet 탭을 수동으로 열지 말고 도구 호출을 재시도하세요. - 브라우저 fallback: 도구가
manualActionRequired: true를 반환하면 반환된browser.nodeId,browser.targetId,browserUrl,manualActionMessage를 사용해 운영자를 안내하세요. 해당 작업이 완료될 때까지 루프에서 재시도하지 마세요. - 브라우저 fallback: Meet에 “Do you want people to hear you in the meeting?”가 표시되면 탭을 열어 둡니다. OpenClaw는 브라우저 자동화를 통해 Use microphone 또는 생성 전용 fallback의 경우 Continue without microphone을 클릭하고 생성된 Meet URL을 계속 기다려야 합니다. 그럴 수 없다면 오류는
google-login-required가 아니라meet-audio-choice-required를 언급해야 합니다.
에이전트가 참가하지만 말하지 않음
실시간 경로를 확인하세요.mode: "agent"를 사용하고, 직접 실시간 음성 fallback에는 mode: "bidi"를 사용하세요. mode: "transcribe"는 의도적으로 talk-back 브리지를 시작하지 않습니다. 관찰 전용 디버깅의 경우 참가자가 말한 뒤 openclaw googlemeet status --json <session-id>를 실행하고 captioning, transcriptLines, lastCaptionText를 확인하세요. inCall이 true인데 transcriptLines가 0에 머무르면 Meet 자막이 비활성화되어 있거나, 관찰자가 설치된 뒤 아무도 말하지 않았거나, Meet UI가 변경되었거나, 해당 회의 언어/계정에서 실시간 자막을 사용할 수 없을 수 있습니다.
googlemeet test-speech는 항상 실시간 경로를 확인하고 해당 호출에서 브리지 출력 바이트가 관찰되었는지 보고합니다. speechOutputVerified가 false이고 speechOutputTimedOut이 true이면 실시간 제공자가 발화를 수락했을 수 있지만 OpenClaw가 Chrome 오디오 브리지에 도달하는 새 출력 바이트를 보지 못한 것입니다.
다음도 확인하세요.
- Gateway 호스트에서
OPENAI_API_KEY또는GEMINI_API_KEY같은 실시간 제공자 키를 사용할 수 있습니다. - Chrome 호스트에
BlackHole 2ch가 표시됩니다. - Chrome 호스트에
sox가 있습니다. - Meet 마이크와 스피커가 OpenClaw가 사용하는 가상 오디오 경로를 통해 라우팅됩니다. 로컬 Chrome 실시간 참가의 경우
doctor에meet output routed: yes가 표시되어야 합니다.
googlemeet doctor [session-id]는 세션, 노드, 통화 중 상태, 수동 작업 사유, 실시간 제공자 연결, realtimeReady, 오디오 입력/출력 활동, 마지막 오디오 타임스탬프, 바이트 카운터, 브라우저 URL을 출력합니다. 원시 JSON이 필요할 때는 googlemeet status [session-id] --json을 사용하세요. 토큰을 노출하지 않고 Google Meet OAuth refresh를 확인해야 할 때는 googlemeet doctor --oauth를 사용하고, Google Meet API 증명도 필요하면 --meeting 또는 --create-space를 추가하세요.
에이전트가 시간 초과되었고 Meet 탭이 이미 열려 있는 것이 보이면, 다른 탭을 열지 말고 해당 탭을 검사하세요.
recover_current_tab입니다. 선택된 전송의 기존 Meet 탭에 포커스를 맞추고 검사합니다. chrome에서는 Gateway를 통한 로컬 브라우저 제어를 사용하고, chrome-node에서는 구성된 Chrome 노드를 사용합니다. 새 탭을 열거나 새 세션을 만들지 않습니다. 로그인, 승인, 권한 또는 오디오 선택 상태 같은 현재 차단 요인을 보고합니다. CLI 명령은 구성된 Gateway와 통신하므로 Gateway가 실행 중이어야 합니다. chrome-node도 Chrome 노드가 연결되어 있어야 합니다.
Twilio 설정 확인 실패
twilio-voice-call-plugin은 voice-call이 허용되지 않았거나 활성화되지 않았을 때 실패합니다. 이를 plugins.allow에 추가하고 plugins.entries.voice-call을 활성화한 뒤 Gateway를 다시 로드하세요.
twilio-voice-call-credentials는 Twilio 백엔드에 계정 SID, 인증 토큰 또는 발신자 번호가 없을 때 실패합니다. Gateway 호스트에서 이를 설정하세요.
twilio-voice-call-webhook은 voice-call에 공개 Webhook 노출이 없거나 publicUrl이 local loopback 또는 사설 네트워크 공간을 가리킬 때 실패합니다. plugins.entries.voice-call.config.publicUrl을 공개 제공자 URL로 설정하거나 voice-call 터널/Tailscale 노출을 구성하세요.
Loopback 및 사설 URL은 통신사 콜백에 유효하지 않습니다. publicUrl로 localhost, 127.0.0.1, 0.0.0.0, 10.x, 172.16.x-172.31.x, 192.168.x, 169.254.x, fc00::/7, fd00::/8를 사용하지 마세요.
안정적인 공개 URL의 경우:
voicecall smoke는 기본적으로 준비 상태 확인 전용입니다. 특정 번호로 드라이런하려면:
--yes를 추가하세요.
Twilio 통화가 시작되지만 회의에 들어가지 않음
Meet 이벤트가 전화 접속 세부 정보를 노출하는지 확인하세요. 정확한 전화 접속 번호와 PIN 또는 사용자 지정 DTMF 시퀀스를 전달하세요.--dtmf-sequence에서 앞쪽에 w 또는 쉼표를 사용하세요.
전화 통화는 생성되었지만 Meet 명단에 전화 접속 참가자가 표시되지 않는 경우:
- 위임된 Twilio 통화 ID, DTMF가 대기열에 추가되었는지 여부, 인트로 인사말이 요청되었는지 여부를 확인하려면
openclaw googlemeet doctor <session-id>를 실행하세요. openclaw voicecall status --call-id <id>를 실행하고 통화가 아직 활성 상태인지 확인하세요.openclaw voicecall tail을 실행하고 Twilio Webhook이 Gateway에 도착하는지 확인하세요.openclaw logs --follow를 실행하고 Twilio Meet 시퀀스를 찾으세요. Google Meet가 참가를 위임하고, Voice Call이 사전 연결 DTMF TwiML을 저장하고 제공하며, Voice Call이 Twilio 통화용 실시간 TwiML을 제공한 다음, Google Meet가voicecall.speak로 인트로 음성을 요청합니다.openclaw googlemeet setup --transport twilio를 다시 실행하세요. 초록색 설정 확인은 필요하지만 회의 PIN 시퀀스가 올바르다는 것을 증명하지는 않습니다.- 전화 접속 번호가 PIN과 동일한 Meet 초대 및 지역에 속하는지 확인하세요.
- Meet가 느리게 응답하거나 사전 연결 DTMF가 전송된 뒤에도 통화 기록에 PIN을 요청하는 프롬프트가 계속 표시되면
voiceCall.dtmfDelayMs를 기본값 12초에서 늘리세요. - 참가자가 들어왔지만 인사말이 들리지 않는다면
openclaw logs --follow에서 DTMF 이후voicecall.speak요청과 미디어 스트림 TTS 재생 또는 Twilio<Say>폴백을 확인하세요. 통화 기록에 여전히 “enter the meeting PIN”이 포함되어 있다면 전화 구간이 아직 Meet 회의실에 들어오지 않은 것이므로 회의 참가자는 음성을 들을 수 없습니다.
plugins.entries.voice-call.config.publicUrl 또는 구성된 터널에 도달할 수 있어야 합니다.
Voice call 문제 해결을 참조하세요.
참고
Google Meet의 공식 미디어 API는 수신 중심이므로 Meet 통화에서 말하려면 여전히 참가자 경로가 필요합니다. 이 Plugin은 그 경계를 명확하게 유지합니다. Chrome은 브라우저 참여와 로컬 오디오 라우팅을 처리하고, Twilio는 전화 접속 참여를 처리합니다. Chrome talk-back 모드에는BlackHole 2ch와 다음 중 하나가 필요합니다.
chrome.audioInputCommand와chrome.audioOutputCommand: OpenClaw가 브리지를 소유하고, 해당 명령들과 선택한 제공자 사이에서chrome.audioFormat형식으로 오디오를 파이프합니다. 에이전트 모드는 실시간 전사와 일반 TTS를 사용하고, bidi 모드는 실시간 음성 제공자를 사용합니다. 기본 Chrome 경로는chrome.audioBufferBytes: 4096을 사용하는 24 kHz PCM16입니다. 8 kHz G.711 mu-law는 레거시 명령 쌍에서도 계속 사용할 수 있습니다.chrome.audioBridgeCommand: 외부 브리지 명령이 전체 로컬 오디오 경로를 소유하며, 데몬을 시작하거나 검증한 뒤 종료해야 합니다.agent모드는 TTS를 위해 명령 쌍에 직접 접근해야 하므로 이는bidi에서만 유효합니다.
google_meet 도구를 호출하면, 회의 컨설턴트 세션은 참가자 음성에 응답하기 전에 호출자의 현재 기록을 포크합니다. Meet 세션은 여전히 별도로 유지되므로(agent:<agentId>:subagent:google-meet:<sessionId>) 회의 후속 작업이 호출자 기록을 직접 변경하지 않습니다.
깨끗한 양방향 오디오를 위해 Meet 출력과 Meet 마이크를 별도의 가상 장치 또는 Loopback 스타일 가상 장치 그래프로 라우팅하세요. 하나의 공유 BlackHole 장치는 다른 참가자의 음성을 통화로 다시 에코할 수 있습니다.
명령 쌍 Chrome 브리지를 사용하면 chrome.bargeInInputCommand가 별도의 로컬 마이크를 수신하고 사람이 말하기 시작할 때 어시스턴트 재생을 지울 수 있습니다. 이렇게 하면 어시스턴트 재생 중 공유 BlackHole local loopback 입력이 일시적으로 억제되더라도 사람의 음성이 어시스턴트 출력보다 앞서 유지됩니다. chrome.audioInputCommand 및 chrome.audioOutputCommand와 마찬가지로 이는 운영자가 구성하는 로컬 명령입니다. 명시적으로 신뢰할 수 있는 명령 경로나 인수 목록을 사용하고, 신뢰할 수 없는 위치의 스크립트를 가리키지 마세요.
googlemeet speak는 Chrome 세션의 활성 talk-back 오디오 브리지를 트리거합니다. googlemeet leave는 해당 브리지를 중지합니다. Voice Call Plugin을 통해 위임된 Twilio 세션의 경우 leave는 기본 음성 통화도 끊습니다. API로 관리되는 공간의 활성 Google Meet 회의도 닫고 싶다면 googlemeet end-active-conference를 사용하세요.