-
-
Notifications
You must be signed in to change notification settings - Fork 170
/
Copy pathreturn-audio-example.ts
50 lines (42 loc) · 1.32 KB
/
return-audio-example.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import 'dotenv/config'
import { RingApi } from 'ring-client-api'
import { cleanOutputDirectory } from './util.ts'
import * as path from 'path'
/**
* This example takes an audio clip from examples/example.mp4 and pipes it to a ring camera
**/
async function example() {
const ringApi = new RingApi({
// Replace with your refresh token
refreshToken: process.env.RING_REFRESH_TOKEN!,
debug: true,
}),
cameras = await ringApi.getCameras(),
camera = cameras[0]
if (!camera) {
console.log('No cameras found')
return
}
// clean/create the output directory
await cleanOutputDirectory()
console.log(`Starting Return Audio to ${camera.name}...`)
const call = await camera.startLiveCall(),
__dirname = new URL('.', import.meta.url).pathname
console.log('Call started, activating return audio...')
await Promise.all([
call.transcodeReturnAudio({
// You can specify any normal ffmpeg input here. In this case, we are just playing from a file
input: [path.join(__dirname, 'example.mp4')],
}),
// We need to manually tell the speaker to activate when we are ready to play audio out of the speaker
call.activateCameraSpeaker(),
])
setTimeout(() => {
call.stop()
process.exit(0)
}, 10000)
}
example().catch((e) => {
console.error(e)
process.exit(1)
})