2023-12-13 20:07:22 +01:00
|
|
|
package player
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
|
2024-01-16 09:27:04 +01:00
|
|
|
"forge.cadoles.com/arcad/arcast"
|
2023-12-13 20:07:22 +01:00
|
|
|
"forge.cadoles.com/arcad/arcast/pkg/browser/lorca"
|
2024-01-16 09:27:04 +01:00
|
|
|
"forge.cadoles.com/arcad/arcast/pkg/selfsigned"
|
2023-12-13 20:07:22 +01:00
|
|
|
"forge.cadoles.com/arcad/arcast/pkg/server"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
"gitlab.com/wpetit/goweb/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
func Run() *cli.Command {
|
|
|
|
defaults := lorca.NewOptions()
|
|
|
|
return &cli.Command{
|
|
|
|
Name: "run",
|
|
|
|
Flags: []cli.Flag{
|
|
|
|
&cli.StringSliceFlag{
|
|
|
|
Name: "additional-chrome-arg",
|
|
|
|
EnvVars: []string{"ARCAST_DESKTOP_ADDITIONAL_CHROME_ARGS"},
|
|
|
|
Value: cli.NewStringSlice("incognito"),
|
|
|
|
},
|
2024-01-12 17:09:19 +01:00
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "instance-id",
|
|
|
|
EnvVars: []string{"ARCAST_DESKTOP_INSTANCE_ID"},
|
|
|
|
Value: "",
|
|
|
|
},
|
2024-01-16 09:27:04 +01:00
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "address",
|
|
|
|
EnvVars: []string{"ARCAST_DESKTOP_ADDRESS"},
|
|
|
|
Value: ":",
|
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "tls-address",
|
|
|
|
EnvVars: []string{"ARCAST_DESKTOP_TLS_ADDRESS"},
|
|
|
|
Value: ":",
|
|
|
|
},
|
2023-12-13 20:07:22 +01:00
|
|
|
&cli.IntFlag{
|
2024-01-12 17:09:19 +01:00
|
|
|
Name: "window-height",
|
|
|
|
EnvVars: []string{"ARCAST_DESKTOP_WINDOW_HEIGHT"},
|
|
|
|
Value: defaults.Height,
|
2023-12-13 20:07:22 +01:00
|
|
|
},
|
2024-01-16 09:27:04 +01:00
|
|
|
&cli.BoolFlag{
|
|
|
|
Name: "apps",
|
|
|
|
EnvVars: []string{"ARCAST_DESKTOP_APPS"},
|
|
|
|
Value: false,
|
|
|
|
},
|
2023-12-13 20:07:22 +01:00
|
|
|
&cli.IntFlag{
|
2024-01-12 17:09:19 +01:00
|
|
|
Name: "window-width",
|
|
|
|
EnvVars: []string{"ARCAST_DESKTOP_WINDOW_WIDTH"},
|
|
|
|
Value: defaults.Width,
|
2023-12-13 20:07:22 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Action: func(ctx *cli.Context) error {
|
|
|
|
windowHeight := ctx.Int("window-height")
|
|
|
|
windowWidth := ctx.Int("window-width")
|
|
|
|
chromeArgs := addFlagsPrefix(ctx.StringSlice("additional-chrome-arg")...)
|
2024-01-16 09:27:04 +01:00
|
|
|
enableApps := ctx.Bool("apps")
|
|
|
|
serverAddress := ctx.String("address")
|
|
|
|
serverTLSAddress := ctx.String("tls-address")
|
2023-12-13 20:07:22 +01:00
|
|
|
|
|
|
|
browser := lorca.NewBrowser(
|
|
|
|
lorca.WithAdditionalChromeArgs(chromeArgs...),
|
|
|
|
lorca.WithWindowSize(windowWidth, windowHeight),
|
|
|
|
)
|
|
|
|
|
|
|
|
if err := browser.Start(); err != nil {
|
|
|
|
return errors.Wrap(err, "could not start browser")
|
|
|
|
}
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
browser.Wait()
|
|
|
|
logger.Warn(ctx.Context, "browser was closed")
|
|
|
|
os.Exit(1)
|
|
|
|
}()
|
|
|
|
|
|
|
|
defer func() {
|
|
|
|
logger.Info(ctx.Context, "stopping browser")
|
|
|
|
if err := browser.Stop(); err != nil {
|
|
|
|
logger.Error(ctx.Context, "could not stop browser", logger.CapturedE(errors.WithStack(err)))
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
2024-01-12 17:09:19 +01:00
|
|
|
instanceID := ctx.String("instance-id")
|
|
|
|
if instanceID == "" {
|
|
|
|
instanceID = server.NewRandomInstanceID()
|
|
|
|
}
|
|
|
|
|
2024-01-16 09:27:04 +01:00
|
|
|
cert, err := selfsigned.NewLANCert()
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrap(err, "could not generate self signed certificate")
|
|
|
|
}
|
|
|
|
|
|
|
|
server := server.New(browser,
|
|
|
|
server.WithInstanceID(instanceID),
|
|
|
|
server.WithAppsEnabled(enableApps),
|
|
|
|
server.WithDefaultApp("home"),
|
|
|
|
server.WithApps(arcast.DefaultApps...),
|
|
|
|
server.WithAddress(serverAddress),
|
|
|
|
server.WithTLSAddress(serverTLSAddress),
|
|
|
|
server.WithTLSCertificate(cert),
|
|
|
|
)
|
2023-12-13 20:07:22 +01:00
|
|
|
|
|
|
|
if err := server.Start(); err != nil {
|
|
|
|
return errors.Wrap(err, "could not start server")
|
|
|
|
}
|
|
|
|
|
|
|
|
defer func() {
|
|
|
|
if err := server.Stop(); err != nil {
|
|
|
|
logger.Error(ctx.Context, "could not stop server", logger.CapturedE(errors.WithStack(err)))
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
if err := server.Wait(); err != nil {
|
|
|
|
return errors.Wrap(err, "could not wait for server")
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func addFlagsPrefix(stripped ...string) []string {
|
|
|
|
flags := make([]string, len(stripped))
|
|
|
|
for i, s := range stripped {
|
|
|
|
flags[i] = fmt.Sprintf("--%s", s)
|
|
|
|
}
|
|
|
|
return flags
|
|
|
|
}
|