An example chat server in golang.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

124 lines
2.7 KiB

преди 6 години
# chat.go
Rudimentary go chat server as a fun project.
# Install
```bash
git clone https://git.coolaj86.com/coolaj86/chat.go.git
преди 6 години
go get gopkg.in/yaml.v2
go get github.com/emicklei/go-restful
```
Note: I also copied some code directly from
<https://github.com/polvi/sni/blob/master/sni.go>
# Usage
преди 6 години
**Start the server**
```bash
преди 6 години
go run -race chatserver*.go -conf ./config.yml
```
преди 6 години
See sample config file at `config.sample.yml`.
**Connect clients**
You can connect multiple clients.
```bash
telnet localhost 4080
```
преди 6 години
You can also use HTTP.
```
curl http://localhost:4080
```
преди 6 години
## Testing Beyond Localhost
You can use [Telebit](https://telebit.cloud) to share the experience with friends and loved ones:
Completely userspace installation:
```
curl -fsSL https://get.telebit.cloud | bash
```
Easy configuration:
```
~/telebit http 4080
преди 6 години
> Forwarding https://lucky-duck-42.telebit.fun => localhost:4080
преди 6 години
~/telebit tcp 4080
преди 6 години
> Forwarding telebit.cloud:1234 => localhost:4080
преди 6 години
```
Caveat: Due to a bug in telebit you must send 'hello' in telnet to establish a connection.
преди 6 години
# API Docs
The API docs and examples can be seen at <http://localhost:4080>
# Project Approach
I've understood theoretical principles of Go for a long time and I've always loved it.
However, most of that came from watching Go Tech Talks and going to meetups.
This is my first Go project and my primary goal was to learn how to use Go
for the kinds of things that I'm personally interested in while also satisfying
a mix of the requirements and optional add-ons, and show you that I know how
to write code and learn.
Criteria Met
-----
* [x] Works
* [x] Attention to Detail
* [x] Security
* [x] UX
* [x] Performance
* [x] Commenting
* [x] Creativity
Limitations
----------
* [ ] Good coding style
This is my first Go project so I was learning as I went and trying different approaches.
As a result my code style is inconsistent and probably does some things the wrong way
(especially confusing since I probably did it the right way in other places).
Implemented
-----
преди 6 години
* [x] Awesome telnet server
* [x] Multiple clients can connect
* [x] Messages are relayed to all clients
* [x] Includes timestamp, name of client
преди 6 години
* [x] Config file for port and addr
преди 6 години
* [x] HTTP API
* [x] Post message
* [x] List messages
* [x] Serve Docs
* [x] Working curl examples
* [x] Multiplex the same port (because I wanted to learn)
* [x] E-mail "magic link" authentication (minus the link since it's localhost)
Not Implemented
----
преди 6 години
I don't think these things would be difficult to add,
but I was having fun learning lots of other things
and I figured Some of these things I didn't implement
* [ ] local log file
* [ ] Rooms
преди 6 години
* [ ] Blocking
* [ ] UI for HTTP API