Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Appserver improvements. #357

Merged
merged 19 commits into from
May 15, 2020
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,15 @@ stop: ## Stop running skywire-visor on host
config: ## Generate skywire.json
-./skywire-cli visor gen-config -o ./skywire.json -r

install-generate: ## Installs required execs for go generate.
${OPTS} go install github.com/mjibson/esc
${OPTS} go install github.com/vektra/mockery/cmd/mockery
# If the following does not work, you may need to run:
# git config --global [email protected]:.insteadOf https://github.com/
# Source: https://stackoverflow.com/questions/27500861/whats-the-proper-way-to-go-get-a-private-repository
# We are using 'go get' instead of 'go install' here, because we don't have a git tag in which 'readmegen' is already implemented.
${OPTS} go get -u github.com/SkycoinPro/skywire-services/cmd/readmegen@master

generate: ## Generate mocks and config README's
go generate ./...

Expand Down
24 changes: 9 additions & 15 deletions cmd/apps/helloworld/helloworld.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@ simple client server app for skywire visor testing
package main

import (
"log"
"os"

"github.com/sirupsen/logrus"

evanlinjin marked this conversation as resolved.
Show resolved Hide resolved
"github.com/SkycoinProject/dmsg/cipher"
"github.com/SkycoinProject/skycoin/src/util/logging"

"github.com/SkycoinProject/skywire-mainnet/pkg/app"
"github.com/SkycoinProject/skywire-mainnet/pkg/app/appnet"
Expand All @@ -20,25 +20,19 @@ const (
netType = appnet.TypeSkynet
)

var log = logrus.New()

func main() {
appC := app.NewClient()
defer appC.Close()

if _, err := buildinfo.Get().WriteTo(log.Writer()); err != nil {
log.Printf("Failed to output build info: %v", err)
}

clientConfig, err := app.ClientConfigFromEnv()
if err != nil {
log.Fatalf("Error getting client config: %v\n", err)
}

app, err := app.NewClient(logging.MustGetLogger("helloworld"), clientConfig)
if err != nil {
log.Fatalf("Error creating app client: %v\n", err)
}
defer app.Close()

if len(os.Args) == 1 {
port := routing.Port(1024)
l, err := app.Listen(netType, port)
l, err := appC.Listen(netType, port)
if err != nil {
log.Fatalf("Error listening network %v on port %d: %v\n", netType, port, err)
}
Expand Down Expand Up @@ -72,7 +66,7 @@ func main() {
log.Fatal("Failed to construct PubKey: ", err, os.Args[1])
}

conn, err := app.Dial(appnet.Addr{
conn, err := appC.Dial(appnet.Addr{
Net: netType,
PubKey: remotePK,
Port: 10,
Expand Down
53 changes: 21 additions & 32 deletions cmd/apps/skychat/chat.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,13 @@ import (
"fmt"
"net"
"net/http"
"os"
"sync"
"time"

"github.com/sirupsen/logrus"

evanlinjin marked this conversation as resolved.
Show resolved Hide resolved
"github.com/SkycoinProject/dmsg/cipher"
"github.com/SkycoinProject/skycoin/src/util/logging"

"github.com/SkycoinProject/skywire-mainnet/internal/netutil"
"github.com/SkycoinProject/skywire-mainnet/pkg/app"
Expand All @@ -25,7 +27,6 @@ import (
)

const (
appName = "skychat"
netType = appnet.TypeSkynet
port = routing.Port(1)
)
Expand All @@ -34,40 +35,28 @@ var addr = flag.String("addr", ":8001", "address to bind")
var r = netutil.NewRetrier(50*time.Millisecond, 5, 2)

var (
chatApp *app.Client
clientCh chan string
chatConns map[cipher.PubKey]net.Conn
connsMu sync.Mutex
log *logging.MasterLogger
log = logrus.New()
nkryuchkov marked this conversation as resolved.
Show resolved Hide resolved
appC *app.Client
clientCh chan string
conns map[cipher.PubKey]net.Conn // Chat connections
connsMu sync.Mutex
)

func main() {
log = app.NewLogger(appName)
flag.Parse()
appC = app.NewClient()
defer appC.Close()

if _, err := buildinfo.Get().WriteTo(log.Writer()); err != nil {
if _, err := buildinfo.Get().WriteTo(os.Stdout); err != nil {
log.Printf("Failed to output build info: %v", err)
}

clientConfig, err := app.ClientConfigFromEnv()
if err != nil {
log.Fatalf("Error getting client config: %v\n", err)
}

// TODO: pass `log`?
a, err := app.NewClient(logging.MustGetLogger(fmt.Sprintf("app_%s", appName)), clientConfig)
if err != nil {
log.Fatal("Setup failure: ", err)
}
defer a.Close()
log.Println("Successfully created skychat app")

chatApp = a
flag.Parse()
log.Println("Successfully started skychat.")

clientCh = make(chan string)
defer close(clientCh)

chatConns = make(map[cipher.PubKey]net.Conn)
conns = make(map[cipher.PubKey]net.Conn)
go listenLoop()

http.Handle("/", http.FileServer(FS(false)))
Expand All @@ -79,7 +68,7 @@ func main() {
}

func listenLoop() {
l, err := chatApp.Listen(netType, port)
l, err := appC.Listen(netType, port)
if err != nil {
log.Printf("Error listening network %v on port %d: %v\n", netType, port, err)
return
Expand All @@ -96,7 +85,7 @@ func listenLoop() {

raddr := conn.RemoteAddr().(appnet.Addr)
connsMu.Lock()
chatConns[raddr.PubKey] = conn
conns[raddr.PubKey] = conn
connsMu.Unlock()
log.Printf("Accepted skychat conn on %s from %s\n", conn.LocalAddr(), raddr.PubKey)

Expand All @@ -113,7 +102,7 @@ func handleConn(conn net.Conn) {
log.Println("Failed to read packet:", err)
raddr := conn.RemoteAddr().(appnet.Addr)
connsMu.Lock()
delete(chatConns, raddr.PubKey)
delete(conns, raddr.PubKey)
connsMu.Unlock()
return
}
Expand Down Expand Up @@ -150,13 +139,13 @@ func messageHandler(w http.ResponseWriter, req *http.Request) {
Port: 1,
}
connsMu.Lock()
conn, ok := chatConns[pk]
conn, ok := conns[pk]
connsMu.Unlock()

if !ok {
var err error
err = r.Do(func() error {
conn, err = chatApp.Dial(addr)
conn, err = appC.Dial(addr)
return err
})
if err != nil {
Expand All @@ -165,7 +154,7 @@ func messageHandler(w http.ResponseWriter, req *http.Request) {
}

connsMu.Lock()
chatConns[pk] = conn
conns[pk] = conn
connsMu.Unlock()

go handleConn(conn)
Expand All @@ -176,7 +165,7 @@ func messageHandler(w http.ResponseWriter, req *http.Request) {
http.Error(w, err.Error(), http.StatusBadRequest)

connsMu.Lock()
delete(chatConns, pk)
delete(conns, pk)
connsMu.Unlock()

return
Expand Down
64 changes: 32 additions & 32 deletions cmd/apps/skychat/static.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

29 changes: 9 additions & 20 deletions cmd/apps/skysocks-client/skysocks-client.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,13 @@ package main

import (
"flag"
"fmt"
"io"
"net"
"time"

"github.com/sirupsen/logrus"

evanlinjin marked this conversation as resolved.
Show resolved Hide resolved
"github.com/SkycoinProject/dmsg/cipher"
"github.com/SkycoinProject/skycoin/src/util/logging"

"github.com/SkycoinProject/skywire-mainnet/internal/netutil"
"github.com/SkycoinProject/skywire-mainnet/internal/skysocks"
Expand All @@ -23,11 +23,12 @@ import (
)

const (
appName = "skysocks-client"
netType = appnet.TypeSkynet
socksPort = routing.Port(3)
)

var log = logrus.New()

var r = netutil.NewRetrier(time.Second, 0, 1)

func dialServer(appCl *app.Client, pk cipher.PubKey) (net.Conn, error) {
Expand All @@ -49,8 +50,10 @@ func dialServer(appCl *app.Client, pk cipher.PubKey) (net.Conn, error) {
}

func main() {
log := app.NewLogger(appName)
skysocks.Log = log.PackageLogger("skysocks")
appC := app.NewClient()
defer appC.Close()

skysocks.Log = log

if _, err := buildinfo.Get().WriteTo(log.Writer()); err != nil {
log.Printf("Failed to output build info: %v", err)
Expand All @@ -60,20 +63,6 @@ func main() {
var serverPK = flag.String("srv", "", "PubKey of the server to connect to")
flag.Parse()

config, err := app.ClientConfigFromEnv()
if err != nil {
log.Fatalf("Error getting client config: %v\n", err)
}

socksApp, err := app.NewClient(logging.MustGetLogger(fmt.Sprintf("app_%s", appName)), config)

if err != nil {
log.Fatal("Setup failure: ", err)
}
defer func() {
socksApp.Close()
}()

if *serverPK == "" {
log.Warn("Empty server PubKey. Exiting")
return
Expand All @@ -85,7 +74,7 @@ func main() {
}

for {
conn, err := dialServer(socksApp, pk)
conn, err := dialServer(appC, pk)
if err != nil {
log.Fatalf("Failed to dial to a server: %v", err)
}
Expand Down
Loading