Skip to content

Commit

Permalink
Add support for Egress Image Output (#53)
Browse files Browse the repository at this point in the history
  • Loading branch information
biglittlebigben authored Feb 27, 2024
1 parent 45533a3 commit 59c553b
Show file tree
Hide file tree
Showing 2 changed files with 116 additions and 0 deletions.
89 changes: 89 additions & 0 deletions src/main/kotlin/io/livekit/server/EgressServiceClient.kt
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ data class EncodedOutputs(
val fileOutput: LivekitEgress.EncodedFileOutput?,
val streamOutput: LivekitEgress.StreamOutput?,
val segmentOutput: LivekitEgress.SegmentedFileOutput?,
val imageOutput: LivekitEgress.ImageOutput?,
)

class EgressServiceClient(
Expand Down Expand Up @@ -117,6 +118,32 @@ class EgressServiceClient(
)
}

@JvmOverloads
fun startRoomCompositeEgress(
roomName: String,
output: LivekitEgress.ImageOutput,
layout: String = "",
optionsPreset: LivekitEgress.EncodingOptionsPreset? = null,
optionsAdvanced: LivekitEgress.EncodingOptions? = null,
audioOnly: Boolean = false,
videoOnly: Boolean = false,
customBaseUrl: String = ""
): Call<LivekitEgress.EgressInfo> {
@Suppress("DEPRECATION")
val requestBuilder = LivekitEgress.RoomCompositeEgressRequest.newBuilder()
.addImageOutputs(output)
return startRoomCompositeEgressImpl(
requestBuilder,
roomName,
layout,
optionsPreset,
optionsAdvanced,
audioOnly,
videoOnly,
customBaseUrl
)
}

@JvmOverloads
fun startRoomCompositeEgress(
roomName: String,
Expand All @@ -138,6 +165,10 @@ class EgressServiceClient(
if (output.segmentOutput != null) {
requestBuilder.addSegmentOutputs(output.segmentOutput)
}
if (output.imageOutput != null) {
requestBuilder.addImageOutputs(output.imageOutput)
}

return startRoomCompositeEgressImpl(
requestBuilder,
roomName,
Expand Down Expand Up @@ -197,6 +228,10 @@ class EgressServiceClient(
if (output.segmentOutput != null) {
requestBuilder.addSegmentOutputs(output.segmentOutput)
}
if (output.imageOutput != null) {
requestBuilder.addImageOutputs(output.imageOutput)
}

return startParticipantEgressImpl(
requestBuilder,
roomName,
Expand Down Expand Up @@ -300,6 +335,28 @@ class EgressServiceClient(
)
}

@JvmOverloads
fun startTrackCompositeEgress(
roomName: String,
output: LivekitEgress.ImageOutput,
audioTrackId: String?,
videoTrackId: String?,
optionsPreset: LivekitEgress.EncodingOptionsPreset? = null,
optionsAdvanced: LivekitEgress.EncodingOptions? = null,
): Call<LivekitEgress.EgressInfo> {
@Suppress("DEPRECATION")
val requestBuilder = LivekitEgress.TrackCompositeEgressRequest.newBuilder()
.addImageOutputs(output)
return startTrackCompositeEgressImpl(
requestBuilder,
roomName,
audioTrackId,
videoTrackId,
optionsPreset,
optionsAdvanced,
)
}

@JvmOverloads
fun startTrackCompositeEgress(
roomName: String,
Expand All @@ -319,6 +376,10 @@ class EgressServiceClient(
if (output.segmentOutput != null) {
requestBuilder.addSegmentOutputs(output.segmentOutput)
}
if (output.imageOutput != null) {
requestBuilder.addImageOutputs(output.imageOutput)
}

return startTrackCompositeEgressImpl(
requestBuilder,
roomName,
Expand Down Expand Up @@ -459,6 +520,30 @@ class EgressServiceClient(
)
}

@JvmOverloads
fun startWebEgress(
url: String,
output: LivekitEgress.ImageOutput,
optionsPreset: LivekitEgress.EncodingOptionsPreset? = null,
optionsAdvanced: LivekitEgress.EncodingOptions? = null,
audioOnly: Boolean = false,
videoOnly: Boolean = false,
awaitStartSignal: Boolean = false
): Call<LivekitEgress.EgressInfo> {
@Suppress("DEPRECATION")
val requestBuilder = LivekitEgress.WebEgressRequest.newBuilder()
.addImageOutputs(output)
return startWebEgressImpl(
requestBuilder,
url,
optionsPreset,
optionsAdvanced,
audioOnly,
videoOnly,
awaitStartSignal
)
}

@JvmOverloads
fun startWebEgress(
url: String,
Expand All @@ -479,6 +564,10 @@ class EgressServiceClient(
if (output.segmentOutput != null) {
requestBuilder.addSegmentOutputs(output.segmentOutput)
}
if (output.imageOutput != null) {
requestBuilder.addImageOutputs(output.imageOutput)
}

return startWebEgressImpl(
requestBuilder,
url,
Expand Down
27 changes: 27 additions & 0 deletions src/test/kotlin/io/livekit/server/EgressServiceClientTest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ class EgressServiceClientTest {
fileOutput = LivekitEgress.EncodedFileOutput.getDefaultInstance(),
streamOutput = LivekitEgress.StreamOutput.getDefaultInstance(),
segmentOutput = LivekitEgress.SegmentedFileOutput.getDefaultInstance(),
imageOutput = LivekitEgress.ImageOutput.getDefaultInstance(),
)
}

Expand Down Expand Up @@ -77,6 +78,14 @@ class EgressServiceClientTest {
)
}

@Test
fun startRoomCompositeEgressImage() {
client.startRoomCompositeEgress(
roomName = "room",
output = LivekitEgress.ImageOutput.getDefaultInstance()
)
}

@Test
fun startRoomCompositeEgressEncodedOutputs() {
client.startRoomCompositeEgress(
Expand Down Expand Up @@ -115,6 +124,16 @@ class EgressServiceClientTest {
)
}

@Test
fun startTrackCompositeEgressImage() {
client.startTrackCompositeEgress(
roomName = "room",
output = LivekitEgress.ImageOutput.getDefaultInstance(),
audioTrackId = "audio",
videoTrackId = "video",
)
}

@Test
fun startTrackCompositeEgressEncodedOutputs() {
client.startTrackCompositeEgress(
Expand Down Expand Up @@ -149,6 +168,14 @@ class EgressServiceClientTest {
)
}

@Test
fun startWebEgressImage() {
client.startWebEgress(
url = "http://www.example.com",
output = LivekitEgress.ImageOutput.getDefaultInstance(),
)
}

@Test
fun startWebEgressEncodedOutputs() {
client.startWebEgress(
Expand Down

0 comments on commit 59c553b

Please sign in to comment.