summaryrefslogtreecommitdiff
path: root/vendor/github.com/pion/interceptor/chain.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/pion/interceptor/chain.go')
-rw-r--r--vendor/github.com/pion/interceptor/chain.go75
1 files changed, 75 insertions, 0 deletions
diff --git a/vendor/github.com/pion/interceptor/chain.go b/vendor/github.com/pion/interceptor/chain.go
new file mode 100644
index 0000000..d53c307
--- /dev/null
+++ b/vendor/github.com/pion/interceptor/chain.go
@@ -0,0 +1,75 @@
+package interceptor
+
+// Chain is an interceptor that runs all child interceptors in order.
+type Chain struct {
+ interceptors []Interceptor
+}
+
+// NewChain returns a new Chain interceptor.
+func NewChain(interceptors []Interceptor) *Chain {
+ return &Chain{interceptors: interceptors}
+}
+
+// BindRTCPReader lets you modify any incoming RTCP packets. It is called once per sender/receiver, however this might
+// change in the future. The returned method will be called once per packet batch.
+func (i *Chain) BindRTCPReader(reader RTCPReader) RTCPReader {
+ for _, interceptor := range i.interceptors {
+ reader = interceptor.BindRTCPReader(reader)
+ }
+
+ return reader
+}
+
+// BindRTCPWriter lets you modify any outgoing RTCP packets. It is called once per PeerConnection. The returned method
+// will be called once per packet batch.
+func (i *Chain) BindRTCPWriter(writer RTCPWriter) RTCPWriter {
+ for _, interceptor := range i.interceptors {
+ writer = interceptor.BindRTCPWriter(writer)
+ }
+
+ return writer
+}
+
+// BindLocalStream lets you modify any outgoing RTP packets. It is called once for per LocalStream. The returned method
+// will be called once per rtp packet.
+func (i *Chain) BindLocalStream(ctx *StreamInfo, writer RTPWriter) RTPWriter {
+ for _, interceptor := range i.interceptors {
+ writer = interceptor.BindLocalStream(ctx, writer)
+ }
+
+ return writer
+}
+
+// UnbindLocalStream is called when the Stream is removed. It can be used to clean up any data related to that track.
+func (i *Chain) UnbindLocalStream(ctx *StreamInfo) {
+ for _, interceptor := range i.interceptors {
+ interceptor.UnbindLocalStream(ctx)
+ }
+}
+
+// BindRemoteStream lets you modify any incoming RTP packets. It is called once for per RemoteStream. The returned method
+// will be called once per rtp packet.
+func (i *Chain) BindRemoteStream(ctx *StreamInfo, reader RTPReader) RTPReader {
+ for _, interceptor := range i.interceptors {
+ reader = interceptor.BindRemoteStream(ctx, reader)
+ }
+
+ return reader
+}
+
+// UnbindRemoteStream is called when the Stream is removed. It can be used to clean up any data related to that track.
+func (i *Chain) UnbindRemoteStream(ctx *StreamInfo) {
+ for _, interceptor := range i.interceptors {
+ interceptor.UnbindRemoteStream(ctx)
+ }
+}
+
+// Close closes the Interceptor, cleaning up any data if necessary.
+func (i *Chain) Close() error {
+ var errs []error
+ for _, interceptor := range i.interceptors {
+ errs = append(errs, interceptor.Close())
+ }
+
+ return flattenErrs(errs)
+}