neko/server/internal/api/room/screen.go

102 lines
2.7 KiB
Go
Raw Normal View History

2020-10-30 10:23:30 +13:00
package room
2020-10-31 06:16:21 +13:00
import (
"net/http"
2021-02-15 02:40:17 +13:00
"strconv"
2020-10-31 06:16:21 +13:00
"github.com/demodesk/neko/pkg/auth"
"github.com/demodesk/neko/pkg/types"
"github.com/demodesk/neko/pkg/types/event"
"github.com/demodesk/neko/pkg/types/message"
"github.com/demodesk/neko/pkg/utils"
2020-10-31 07:56:22 +13:00
)
2020-10-31 06:16:21 +13:00
2021-09-17 10:58:50 +12:00
func (h *RoomHandler) screenConfiguration(w http.ResponseWriter, r *http.Request) error {
screenSize := h.desktop.GetScreenSize()
2020-10-31 06:16:21 +13:00
return utils.HttpSuccess(w, screenSize)
2020-10-31 06:16:21 +13:00
}
2021-09-17 10:58:50 +12:00
func (h *RoomHandler) screenConfigurationChange(w http.ResponseWriter, r *http.Request) error {
auth, _ := auth.GetSession(r)
data := &types.ScreenSize{}
2021-09-17 10:58:50 +12:00
if err := utils.HttpJsonRequest(w, r, data); err != nil {
return err
2020-10-31 07:56:22 +13:00
}
size, err := h.desktop.SetScreenSize(types.ScreenSize{
Width: data.Width,
Height: data.Height,
Rate: data.Rate,
})
if err != nil {
2021-09-17 10:58:50 +12:00
return utils.HttpUnprocessableEntity("cannot set screen size").WithInternalErr(err)
2020-10-31 07:56:22 +13:00
}
h.sessions.Broadcast(event.SCREEN_UPDATED, message.ScreenSizeUpdate{
ID: auth.ID(),
ScreenSize: size,
})
2020-10-31 07:56:22 +13:00
2021-09-17 10:58:50 +12:00
return utils.HttpSuccess(w, data)
2020-10-31 06:16:21 +13:00
}
// TODO: remove.
2021-09-17 10:58:50 +12:00
func (h *RoomHandler) screenConfigurationsList(w http.ResponseWriter, r *http.Request) error {
configurations := h.desktop.ScreenConfigurations()
return utils.HttpSuccess(w, configurations)
2020-10-31 06:16:21 +13:00
}
2021-01-22 08:44:09 +13:00
2021-09-17 10:58:50 +12:00
func (h *RoomHandler) screenShotGet(w http.ResponseWriter, r *http.Request) error {
2021-01-26 05:31:24 +13:00
quality, err := strconv.Atoi(r.URL.Query().Get("quality"))
if err != nil {
quality = 90
2021-01-22 08:44:09 +13:00
}
img := h.desktop.GetScreenshotImage()
bytes, err := utils.CreateJPGImage(img, quality)
if err != nil {
2021-09-17 10:58:50 +12:00
return utils.HttpInternalServerError().WithInternalErr(err)
2021-01-22 08:44:09 +13:00
}
2021-01-24 03:23:10 +13:00
w.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
2021-01-22 08:44:09 +13:00
w.Header().Set("Content-Type", "image/jpeg")
2021-09-17 10:58:50 +12:00
_, err = w.Write(bytes)
return err
2021-01-22 08:44:09 +13:00
}
2021-01-23 06:13:32 +13:00
2021-09-17 10:58:50 +12:00
func (h *RoomHandler) screenCastGet(w http.ResponseWriter, r *http.Request) error {
2022-03-27 11:20:38 +13:00
// display fallback image when private mode is enabled even if screencast is not
if session, ok := auth.GetSession(r); ok && session.PrivateModeEnabled() {
if h.privateModeImage != nil {
w.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
w.Header().Set("Content-Type", "image/jpeg")
_, err := w.Write(h.privateModeImage)
return err
}
return utils.HttpBadRequest("private mode is enabled but no fallback image available")
}
2021-01-23 06:13:32 +13:00
screencast := h.capture.Screencast()
if !screencast.Enabled() {
2021-09-17 10:58:50 +12:00
return utils.HttpBadRequest("screencast pipeline is not enabled")
2021-01-23 06:13:32 +13:00
}
2021-01-24 03:17:52 +13:00
bytes, err := screencast.Image()
if err != nil {
2021-09-17 10:58:50 +12:00
return utils.HttpInternalServerError().WithInternalErr(err)
2021-01-24 03:17:52 +13:00
}
2021-01-23 06:13:32 +13:00
w.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
w.Header().Set("Content-Type", "image/jpeg")
2021-09-17 10:58:50 +12:00
_, err = w.Write(bytes)
return err
2021-01-23 06:13:32 +13:00
}