GithubHelp home page GithubHelp logo

nyura95 / nyusocket Goto Github PK

View Code? Open in Web Editor NEW
0.0 2.0 0.0 62 KB

nyusocket is a module golang for make a socket server simply and compatible with the native socket of any browser

License: MIT License

Go 83.81% HTML 16.19%
golang socket easy client-server-example

nyusocket's Introduction

NyuSocket

go get github.com/Nyura95/nyusocket

Next step of development

  • Change the creation of events to make it more 'user frendly'

Basic usage

Sending Message

Server

package main

import "fmt"
import "os"
import "github.com/Nyura95/nyusocket"
import "context"

func main() {
	socket := nyusocket.NewServer(nyusocket.Options{Addr: "127.0.0.1:3001"})
	events := socket.GetEvents()

	ctx, cancel := context.WithCancel(context.Background())
	go socket.Start(ctx)
	defer cancel()

	events.CreateClientMessageEvent()
	for {
		select {
		case clientMessage, alive := <-events.ClientMessage:
			if !alive {
				break
			}
			for _, other := range clientMessage.Client.GetOthersClients() {
				other.Send(nyusocket.NewMessage("message", clientMessage.Message, "message").Send())
			}
		}
	}
}

Event before a login user

package main

import "fmt"
import "os"
import "context"
import "github.com/Nyura95/nyusocket"

type storeClient struct {
	token string
}

func main() {
	socket := nyusocket.NewServer(nyusocket.Options{Addr: "127.0.0.1:3001"})
	events := socket.GetEvents()

	ctx, cancel := context.WithCancel(context.Background())
	go socket.Start(ctx)
	defer cancel()

	events.CreateClientMessageEvent()
	events.CreateAuthorizationEvent()
	for {
		select {
		case authorization, alive := <-events.Authorization:
			if !alive {
				break
			}
			// authorize only one 'token' (check the client for pass the query)
			authorization.Client.Store = storeClient{
				token: authorization.Client.Query["token"][0],
			}
			authorization.Client.Hash = authorization.Client.Query["token"][0]
			authorization.Authorize <- !nyusocket.Infos.Alive(authorization.Client) // chan authorization.Authorize return an boolean, if false the client is unregister
		case clientMessage, alive := <-events.ClientMessage:
			if !alive {
				break
			}
			storeClient := clientMessage.Client.Store.(storeClient) // get store client
			for _, other := range clientMessage.Client.GetOthersClients() { // get all other clients actually registered
				other.Send(nyusocket.NewMessage("message", fmt.Sprintf("%s: %s", storeClient.token, clientMessage.Message), "message").Send()) // send customer's message to others
			}
		}
	}
}

Event on the new client login

package main

import "fmt"
import "os"
import "context"
import "github.com/Nyura95/nyusocket"

func main() {
  socket := nyusocket.NewServer(nyusocket.Options{Addr: "127.0.0.1:3001"})
	events := socket.GetEvents()

	ctx, cancel := context.WithCancel(context.Background())
	go socket.Start(ctx)
	defer cancel()

	events.CreateClientMessageEvent()
	events.CreateRegisterEvent()

	for {
		select {
		case clientMessage, alive := <-events.ClientMessage:
			if !alive {
				break
			}
			for _, other := range clientMessage.Client.GetOthersClients() {
				other.Send(nyusocket.NewMessage("message", clientMessage.Message, "message").Send())
			}
		case client, alive := <-events.Register: // new client registered
			if !alive {
				break
			}
			client.Send(nyusocket.NewMessage("register", "Hello there!", "new_register").Send()) // send a message to the client
			for _, other := range client.GetOthersClients() {
				other.Send(nyusocket.NewMessage("register", "New client", "new_register").Send()) // tell others that a new customer is registered
			}
		}
	}
}

Event on the client logout

package main

import "fmt"
import "os"
import "context"
import "github.com/Nyura95/nyusocket"

func main() {
  socket := nyusocket.NewServer(nyusocket.Options{Addr: "127.0.0.1:3001"})
	events := socket.GetEvents()

	ctx, cancel := context.WithCancel(context.Background())
	go socket.Start(ctx)
	defer cancel()

	events.CreateClientMessageEvent()
	events.CreateUnregisterEvent()

	for {
		select {
		case clientMessage, alive := <-events.ClientMessage:
			if !alive {
				break
			}
			for _, other := range clientMessage.Client.GetOthersClients() {
				other.Send(nyusocket.NewMessage("message", clientMessage.Message, "message").Send())
			}
    case unregister, alive := <-events.Unregister:
			if !alive {
				break
			}
      // unregister.Store (you can access to the store client if needed)
			for _, other := range unregister.Hub.GetClients() {
				other.Send(nyusocket.NewMessage("unregister", "Client unregister", "new_unregister").Send()) // tell others that a new customer is logout
			}
		}
	}
}

Stop server

package main

import "fmt"
import "os"
import "time"
import "github.com/Nyura95/nyusocket"
import "context"

func main() {
  socket := nyusocket.NewServer(nyusocket.Options{Addr: "127.0.0.1:3001"})

	ctx, cancel := context.WithCancel(context.Background())

	go func() {
		time.Sleep(5 * time.Second)
		cancel()
	}()

	socket.Start(ctx)

	log.Println("server closed")
}

Client side

Message server example

{ Action: string, Message: string, Key: string, Created: Date }

Who to use ? (see client.html)

var states = {
  [WebSocket.CONNECTING]: "CONNECTING",
  [WebSocket.OPEN]: "OPEN",
  [WebSocket.CLOSING]: "CLOSING",
  [WebSocket.CLOSED]: "CLOSED",
};
var _messages = [];

var client = new WebSocket("ws://...");
client.onopen = function (event) {
  console.log(event);
  document.getElementById("state").innerHTML =
    "state: " + states[client.readyState];
};
client.onmessage = function (msg) {
  console.log("New message: ", msg);
  var messages = msg.data.split("\n");
  for (let i = 0; i < messages.length; i++) {
    var message = messages[i];
    try {
      message = JSON.parse(message);
    } catch (err) {
      console.log(err);
    }
    _messages.push(message);
    var tchat = document.getElementById("messages");
    tchat.value = _messages
      .map(function (x) {
        return "Action: " + x.Action + " | " + x.Message;
      })
      .join("\r\n");
    tchat.scrollTo({ top: tchat.scrollHeight });
  }
};

nyusocket's People

Contributors

nyura95 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.