implement ipc
This commit is contained in:
parent
23e0935d33
commit
d7e10c88bb
1 changed files with 52 additions and 1 deletions
53
main.go
53
main.go
|
|
@ -1,12 +1,23 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"net"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type MPVRequest struct {
|
||||||
|
Command []string `json:"command"`
|
||||||
|
}
|
||||||
|
type MPVResponse struct {
|
||||||
|
Data string `json:"data"`
|
||||||
|
}
|
||||||
|
|
||||||
type MPV struct {
|
type MPV struct {
|
||||||
cmd *exec.Cmd
|
cmd *exec.Cmd
|
||||||
socketPath string
|
socketPath string
|
||||||
|
|
@ -20,12 +31,43 @@ func NewMPV(streamUrl string, socketPath string) MPV {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (mpv *MPV) Spawn() error {
|
func (mpv *MPV) Spawn() error {
|
||||||
mpv.cmd.Stdout = os.Stdout
|
mpv.cmd.Stdout = io.Discard
|
||||||
mpv.cmd.Stderr = os.Stderr
|
mpv.cmd.Stderr = os.Stderr
|
||||||
|
|
||||||
return mpv.cmd.Start()
|
return mpv.cmd.Start()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (mpv *MPV) Stop() error {
|
||||||
|
return mpv.cmd.Process.Kill()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mpv *MPV) ExecuteIPC(req *MPVRequest) ([]byte, error) {
|
||||||
|
reqBytes, err := json.Marshal(req)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
reqBytes = append(reqBytes, byte('\n'))
|
||||||
|
|
||||||
|
conn, err := net.Dial("unix", mpv.socketPath)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
defer conn.Close()
|
||||||
|
|
||||||
|
_, err = conn.Write(reqBytes)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
resBytes := make([]byte, 1024)
|
||||||
|
n, err := conn.Read(resBytes)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return resBytes[:n], nil
|
||||||
|
}
|
||||||
|
|
||||||
var testUrl string
|
var testUrl string
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
@ -34,4 +76,13 @@ func main() {
|
||||||
|
|
||||||
mpv := NewMPV(testUrl, "/tmp/mptv3.sock")
|
mpv := NewMPV(testUrl, "/tmp/mptv3.sock")
|
||||||
mpv.Spawn()
|
mpv.Spawn()
|
||||||
|
defer mpv.Stop()
|
||||||
|
|
||||||
|
time.Sleep(time.Second * 2)
|
||||||
|
fmt.Println("EXECUTING IPC!!!!")
|
||||||
|
res, err := mpv.ExecuteIPC(&MPVRequest{
|
||||||
|
Command: []string{"get_property", "playback-time"},
|
||||||
|
})
|
||||||
|
|
||||||
|
fmt.Println(res, err)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue