Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rawhat/glisten
A pure gleam TCP library
https://github.com/rawhat/glisten
Last synced: about 2 months ago
JSON representation
A pure gleam TCP library
- Host: GitHub
- URL: https://github.com/rawhat/glisten
- Owner: rawhat
- License: apache-2.0
- Created: 2022-04-05T15:38:55.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-10-16T22:27:45.000Z (3 months ago)
- Last Synced: 2024-10-27T19:50:35.562Z (3 months ago)
- Language: Gleam
- Homepage:
- Size: 202 KB
- Stars: 65
- Watchers: 4
- Forks: 10
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-gleam - glisten - [📚](https://hexdocs.pm/glisten/) - a shiny Gleam TCP/SSL server (Packages / Networking)
README
# glisten
[![Package Version](https://img.shields.io/hexpm/v/glisten)](https://hex.pm/packages/glisten)
[![Hex Docs](https://img.shields.io/badge/hex-docs-ffaff3)](https://hexdocs.pm/glisten/)A Gleam TCP server library. Built on top of `gleam_otp`, it provides a
supervisor over a pool of socket acceptors. Each acceptor will block on `accept`
until a connection is opened. The acceptor will then spawn a handler process
and then block again on `accept`.Below is a simple example that will echo received messages. You can get this
up and running with the following:```sh
$ gleam new
$ cd
$ gleam add glisten gleam_erlang gleam_otp
```Then place this code in `src/.gleam`:
```gleam
import gleam/bytes_builder
import gleam/erlang/process
import gleam/option.{None}
import gleam/otp/actor
import glisten.{Packet}pub fn main() {
let assert Ok(_) =
glisten.handler(fn(_conn) { #(Nil, None) }, fn(msg, state, conn) {
let assert Packet(msg) = msg
let assert Ok(_) = glisten.send(conn, bytes_builder.from_bit_array(msg))
actor.continue(state)
})
|> glisten.serve(3000)process.sleep_forever()
}
```SSL is also handled using the `glisten.{serve_ssl}` method. This requires a
certificate and key file path. The rest of the handler flow remains unchanged.`glisten` doesn't provide a public API for connected clients. In order to hook
into the socket lifecycle, you can establish some functions which are called
for the opening and closing of the socket. An example is provided below.To serve over SSL:
```gleam
// ...
import glisten/sslpub fn main() {
let assert Ok(_) =
glisten.handler(
// omitted
)
|> glisten.serve_ssl(
// Passing labeled arguments for clarity
port: 8080,
certfile: "/path/to/server.crt",
keyfile: "/path/to/server.key",
)
process.sleep_forever()
}
```But you can also drop down to the lower level listen/accept flow if you'd prefer
to manage connections yourself, or only handle a small number at a time.```gleam
import gleam/io
import gleam/result
import glisten/socket/options.{ActiveMode, Passive}
import glisten/tcppub fn main() {
use listener <- result.then(tcp.listen(8000, [ActiveMode(Passive)]))
use socket <- result.then(tcp.accept(listener))
use msg <- result.then(tcp.receive(socket, 0))
io.debug(#("got a msg", msg))Ok(Nil)
}
```See [mist](https://github.com/rawhat/mist) for HTTP support built on top of this library.