Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/madeindra/golang-websocket
Pub Sub server via WebSocket using Gorilla WebSocket
https://github.com/madeindra/golang-websocket
chat go golang gorilla gorilla-websocket pubsub websocket websockets
Last synced: 3 months ago
JSON representation
Pub Sub server via WebSocket using Gorilla WebSocket
- Host: GitHub
- URL: https://github.com/madeindra/golang-websocket
- Owner: madeindra
- Created: 2021-06-22T00:42:23.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-02-19T11:05:23.000Z (almost 2 years ago)
- Last Synced: 2024-06-19T01:57:43.872Z (7 months ago)
- Topics: chat, go, golang, gorilla, gorilla-websocket, pubsub, websocket, websockets
- Language: Go
- Homepage: https://open.madecanggih.dev/websocket
- Size: 125 KB
- Stars: 39
- Watchers: 1
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Websocket Server in Go
## Running the server
1. Clone this repository2. Mount the repository & run this command to install dependencies
```
make setup
```3. Run the websocket server
```
make run
```4. Websocket server will be running on `localhost:8080`
## Using this server with client
1. After running the server, open your Websocket client. If you don't have any, try `Websocket King` extension for chrome.2. Connect to `ws://localhost:8080/socket`, you will be greeted by the server.
```
Server: Welcome! Your ID is f0ab664a-5af3-4f8d-8afe-eb93085267e4
```3. To subscribe to a topic, send this payload (*topic can be anything*)
```
{
"action": "subscribe",
"topic": "world"
}
```4. To send a message to the topic's subscribers, send payload in this format
```
{
"action": "publish",
"topic": "world",
"message": "Hello world!"
}
```5. To unsubscribe from the topic, send this payload (*topic can be anything*)
```
{
"action": "unsubscribe",
"topic": "world"
}
```## HTTP vs WebSocket
You might be asking "why should I use Websocket instead of REST API"?
REST API uses HTTP which can only send response once per request.
Meanwhile, WebSocket can be used for persistent bidirectional communication without the need of reestablishing connection everytime.
This can be useful in some scenario like chatting or pub-sub.
Here is the diagram to visualize the difference between HTTP and WebSocket.
![HTTP-vs-WebSocket](./docs/http-vs-ws.png)
## Flowchart
This flowchart describes how this server works.
![Server-Flowchart](./docs/server-flowchart.png)## Project Structure
```
cmd
└── main
└── main.go
internal
└── websocket
└── handler.go
└── model.go
└── server.go
```
### Main files
**main.go**: the main file to be executed.### Handler
**handler.go**: handles open/close connection & pass the message to the server.
### Model
**model.go**: stores the models used by the server.
### Server
**server.go**: runs specific action according to the client message, also containes functions that needed by the server to work properly as a websocket server.## Further Work
This repository is far from ideal. It's just a proof-of-concept.
While this repository is close to a pub-sub, it can still be used for a chat server.
For example, we can add a function on socket connected so that client will be automatically subscribes to their own ID as a topic. Other clients then will use those user's ID as a topic to publish a message.
I have tried building such solution combined with Authorization to prevent other user from subscribing to other's ID and it does work.
## Credit
This repository is inspired by [Golang-PubSub by @tabvn](https://github.com/tabvn/golang-pubsub-youtube)