mirror of
https://github.com/pion/webrtc.git
synced 2025-10-05 07:06:51 +08:00
Remove examples/internal
Users find it frustrating that example code doesn't work out of tree. This makes copying the examples out of the repo easier. Relates to #1981
This commit is contained in:
@@ -7,14 +7,19 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"encoding/base64"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"io"
|
||||
"os"
|
||||
"strings"
|
||||
"syscall/js"
|
||||
"time"
|
||||
|
||||
"github.com/pion/randutil"
|
||||
"github.com/pion/webrtc/v4"
|
||||
|
||||
"github.com/pion/webrtc/v4/examples/internal/signal"
|
||||
)
|
||||
|
||||
const messageSize = 15
|
||||
@@ -95,7 +100,7 @@ func main() {
|
||||
})
|
||||
peerConnection.OnICECandidate(func(candidate *webrtc.ICECandidate) {
|
||||
if candidate != nil {
|
||||
encodedDescr := signal.Encode(peerConnection.LocalDescription())
|
||||
encodedDescr := encode(peerConnection.LocalDescription())
|
||||
el := getElementByID("localSessionDescription")
|
||||
el.Set("value", encodedDescr)
|
||||
}
|
||||
@@ -126,7 +131,7 @@ func main() {
|
||||
}
|
||||
|
||||
descr := webrtc.SessionDescription{}
|
||||
signal.Decode(sd, &descr)
|
||||
decode(sd, &descr)
|
||||
if err := peerConnection.SetRemoteDescription(descr); err != nil {
|
||||
handleError(err)
|
||||
}
|
||||
@@ -155,13 +160,15 @@ func ReadLoop(d io.Reader) {
|
||||
// WriteLoop shows how to write to the datachannel directly
|
||||
func WriteLoop(d io.Writer) {
|
||||
for range time.NewTicker(5 * time.Second).C {
|
||||
message := signal.RandSeq(messageSize)
|
||||
log(fmt.Sprintf("Sending %s \n", message))
|
||||
|
||||
_, err := d.Write([]byte(message))
|
||||
message, err := randutil.GenerateCryptoRandomString(messageSize, "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")
|
||||
if err != nil {
|
||||
handleError(err)
|
||||
}
|
||||
|
||||
log(fmt.Sprintf("Sending %s \n", message))
|
||||
if _, err := d.Write([]byte(message)); err != nil {
|
||||
handleError(err)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -178,3 +185,45 @@ func handleError(err error) {
|
||||
func getElementByID(id string) js.Value {
|
||||
return js.Global().Get("document").Call("getElementById", id)
|
||||
}
|
||||
|
||||
// Read from stdin until we get a newline
|
||||
func readUntilNewline() (in string) {
|
||||
var err error
|
||||
|
||||
r := bufio.NewReader(os.Stdin)
|
||||
for {
|
||||
in, err = r.ReadString('\n')
|
||||
if err != nil && !errors.Is(err, io.EOF) {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
if in = strings.TrimSpace(in); len(in) > 0 {
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
fmt.Println("")
|
||||
return
|
||||
}
|
||||
|
||||
// JSON encode + base64 a SessionDescription
|
||||
func encode(obj *webrtc.SessionDescription) string {
|
||||
b, err := json.Marshal(obj)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
return base64.StdEncoding.EncodeToString(b)
|
||||
}
|
||||
|
||||
// Decode a base64 and unmarshal JSON into a SessionDescription
|
||||
func decode(in string, obj *webrtc.SessionDescription) {
|
||||
b, err := base64.StdEncoding.DecodeString(in)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
if err = json.Unmarshal(b, obj); err != nil {
|
||||
panic(err)
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user