mirror of
https://github.com/syssecfsu/witty.git
synced 2025-06-06 23:07:27 +02:00
wip
This commit is contained in:
parent
eedf025867
commit
aa283ec188
@ -12,11 +12,12 @@
|
|||||||
<script src="xterm-addon-attach.js"></script>
|
<script src="xterm-addon-attach.js"></script>
|
||||||
<script src="xterm-addon-fit.js"></script>
|
<script src="xterm-addon-fit.js"></script>
|
||||||
<script src="xterm-addon-web-links.js"></script>
|
<script src="xterm-addon-web-links.js"></script>
|
||||||
<script src="main.js"></script>
|
|
||||||
|
|
||||||
|
<script src="main.js"></script>
|
||||||
|
|
||||||
<link rel="stylesheet" href="xterm.css" />
|
<link rel="stylesheet" href="xterm.css" />
|
||||||
<link rel="stylesheet" href="main.css" />
|
<link rel="stylesheet" href="main.css" />
|
||||||
|
|
||||||
<title>Websocket Terminal</title>
|
<title>Websocket Terminal</title>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
@ -50,9 +51,6 @@
|
|||||||
].join('\n\r');
|
].join('\n\r');
|
||||||
|
|
||||||
term.writeln(str);
|
term.writeln(str);
|
||||||
term.writeln(str);
|
|
||||||
term.writeln(str);
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
|
@ -14,12 +14,15 @@
|
|||||||
.xterm-viewport.xterm-viewport {
|
.xterm-viewport.xterm-viewport {
|
||||||
scrollbar-width: thin;
|
scrollbar-width: thin;
|
||||||
}
|
}
|
||||||
|
|
||||||
.xterm-viewport::-webkit-scrollbar {
|
.xterm-viewport::-webkit-scrollbar {
|
||||||
width: 10px;
|
width: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.xterm-viewport::-webkit-scrollbar-track {
|
.xterm-viewport::-webkit-scrollbar-track {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.xterm-viewport::-webkit-scrollbar-thumb {
|
.xterm-viewport::-webkit-scrollbar-thumb {
|
||||||
min-height: 20px;
|
min-height: 20px;
|
||||||
background-color: #ffffff20;
|
background-color: #ffffff20;
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
function createTerminal() {
|
function createTerminal() {
|
||||||
// vscode-snazzy https://github.com/Tyriar/vscode-snazzy
|
// vscode-snazzy https://github.com/Tyriar/vscode-snazzy
|
||||||
|
// copied from xterm.js website
|
||||||
var baseTheme = {
|
var baseTheme = {
|
||||||
foreground: '#eff0eb',
|
foreground: '#eff0eb',
|
||||||
background: '#282a36',
|
background: '#282a36',
|
||||||
@ -23,16 +24,17 @@ function createTerminal() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const term = new Terminal({
|
const term = new Terminal({
|
||||||
fontFamily:`'Fira Code', monospace`,
|
fontFamily: `'Fira Code', monospace`,
|
||||||
fontSize:12,
|
fontSize: 12,
|
||||||
theme:baseTheme,
|
theme: baseTheme,
|
||||||
|
convertEol: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
term.open(document.getElementById('terminal_view'));
|
term.open(document.getElementById('terminal_view'));
|
||||||
term.resize(120, 36);
|
term.resize(120, 36);
|
||||||
|
|
||||||
const weblinksAddon = new WebLinksAddon.WebLinksAddon();
|
const weblinksAddon = new WebLinksAddon.WebLinksAddon();
|
||||||
term.loadAddon(weblinksAddon)
|
term.loadAddon(weblinksAddon);
|
||||||
|
|
||||||
// fit the xterm viewpoint to parent element
|
// fit the xterm viewpoint to parent element
|
||||||
const fitAddon = new FitAddon.FitAddon();
|
const fitAddon = new FitAddon.FitAddon();
|
||||||
@ -40,10 +42,9 @@ function createTerminal() {
|
|||||||
fitAddon.fit();
|
fitAddon.fit();
|
||||||
|
|
||||||
// create the websocket and connect to the server
|
// create the websocket and connect to the server
|
||||||
const ws_uri = "ws://" + window.location.host + "/ws"
|
const ws_uri = "ws://" + window.location.host + "/ws";
|
||||||
const socket = new WebSocket(ws_uri)
|
const socket = new WebSocket(ws_uri);
|
||||||
console.log("Attempting to connect to" + ws_uri);
|
const attachAddon = new AttachAddon.AttachAddon(socket);
|
||||||
const attachAddon = new AttachAddon.AttachAddon(socket)
|
|
||||||
term.loadAddon(attachAddon);
|
term.loadAddon(attachAddon);
|
||||||
|
|
||||||
return term;
|
return term;
|
||||||
|
21
main.go
21
main.go
@ -2,9 +2,10 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"strings"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
"github.com/gorilla/websocket"
|
"github.com/gorilla/websocket"
|
||||||
)
|
)
|
||||||
@ -12,11 +13,11 @@ import (
|
|||||||
var host *string = nil
|
var host *string = nil
|
||||||
|
|
||||||
var upgrader = websocket.Upgrader{
|
var upgrader = websocket.Upgrader{
|
||||||
ReadBufferSize : 4096,
|
ReadBufferSize: 4096,
|
||||||
WriteBufferSize: 4096,
|
WriteBufferSize: 4096,
|
||||||
CheckOrigin: func(r *http.Request) bool {
|
CheckOrigin: func(r *http.Request) bool {
|
||||||
org := r.Header.Get("Origin")
|
org := r.Header.Get("Origin")
|
||||||
h,err := url.Parse(org)
|
h, err := url.Parse(org)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return false
|
return false
|
||||||
@ -32,9 +33,9 @@ var upgrader = websocket.Upgrader{
|
|||||||
|
|
||||||
// handle websockets
|
// handle websockets
|
||||||
func wsHandler(w http.ResponseWriter, r *http.Request) {
|
func wsHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
conn, err := upgrader.Upgrade(w,r, nil)
|
conn, err := upgrader.Upgrade(w, r, nil)
|
||||||
|
|
||||||
if err!= nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -44,12 +45,12 @@ func wsHandler(w http.ResponseWriter, r *http.Request) {
|
|||||||
for {
|
for {
|
||||||
msgType, p, err := conn.ReadMessage()
|
msgType, p, err := conn.ReadMessage()
|
||||||
|
|
||||||
if err!= nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := conn.WriteMessage(msgType, p); err!= nil {
|
if err := conn.WriteMessage(msgType, p); err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -57,7 +58,7 @@ func wsHandler(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// return files
|
// return files
|
||||||
func fileHandler (c *gin.Context, fname string) {
|
func fileHandler(c *gin.Context, fname string) {
|
||||||
// if the URL has no fname, c.Param returns "/"
|
// if the URL has no fname, c.Param returns "/"
|
||||||
if fname == "/" {
|
if fname == "/" {
|
||||||
fname = "/index.html"
|
fname = "/index.html"
|
||||||
@ -76,13 +77,13 @@ func fileHandler (c *gin.Context, fname string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func main () {
|
func main() {
|
||||||
rt := gin.Default()
|
rt := gin.Default()
|
||||||
|
|
||||||
rt.SetTrustedProxies(nil)
|
rt.SetTrustedProxies(nil)
|
||||||
rt.LoadHTMLGlob("assets/*.html")
|
rt.LoadHTMLGlob("assets/*.html")
|
||||||
|
|
||||||
rt.GET("/*fname", func(c *gin.Context){
|
rt.GET("/*fname", func(c *gin.Context) {
|
||||||
fname := c.Param("fname")
|
fname := c.Param("fname")
|
||||||
|
|
||||||
// ws is a special case to create a new websocket
|
// ws is a special case to create a new websocket
|
||||||
|
Loading…
x
Reference in New Issue
Block a user