Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/reiver/go-finger
Pacakge finger implements the finger protocol, for the Go programming language.
https://github.com/reiver/go-finger
finger finger-protocol
Last synced: about 2 months ago
JSON representation
Pacakge finger implements the finger protocol, for the Go programming language.
- Host: GitHub
- URL: https://github.com/reiver/go-finger
- Owner: reiver
- License: mit
- Created: 2022-11-17T16:56:04.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2024-04-21T04:19:55.000Z (9 months ago)
- Last Synced: 2024-11-14T09:38:59.044Z (2 months ago)
- Topics: finger, finger-protocol
- Language: Go
- Homepage:
- Size: 124 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# go-finger
Package **finger** implements the **finger-protocol**, for the Go programming language.
I.e., generally, what is defined in:
* IETF RFC-742 — https://datatracker.ietf.org/doc/html/rfc742
* IETF RFC-1288 — https://datatracker.ietf.org/doc/html/rfc1288Although this package add some modernizations that are compatible with IETF RFC-742,
and in the spirt of the **finger-protocol**,
_that you can choose whether to use or not use_.## Documention
Online documentation, which includes examples, can be found at: http://godoc.org/github.com/reiver/go-finger
[![GoDoc](https://godoc.org/github.com/reiver/go-finger?status.svg)](https://godoc.org/github.com/reiver/go-finger)
## Simple Finger Client
This is an example of how to create very very very simple **finger-protocol** client using this package.
It is meant for educational purposes.
A more useful **finger-protocol** client would include a lot more features.
But anyway....We first need to decide what the **finger-protocol** target will be.
What is a **finger-protocol** "target"‽
Well, for example, if we were to run the **finger** program as:
```
finger [email protected]
```Then out target would be:
```go
"joeblow"
```So, in our Go code we would have something like:
```go
package mainimport (
"github.com/reiver/go-finger"
)func main() {
var target finger.Target = finger.CreateTarget("joeblow")
//@TODO
}
```Now we need to put the `target` inside of a **finger-protocol** request.
We do that with the following code:
```go
package mainimport (
"github.com/reiver/go-finger"
)func main() {
var target finger.Target = finger.CreateTarget("joeblow")
var request finger.Request = finger.AssembleRequestTarget(target)
//@TODO
}
```Next, we need to figure out what is the TCP-address of the **finger-protocol server** our **finger-protocol client** will connect to.
TCP-addresses (as a string) look something like:
"example.com:79"
"reiver.link:1971"
"181.70.250.13:1079"
"12.23.34.45:7979"
I.e., it is a 'host' and a TCP-port (with a colon ":" between them).
We are using the following as our reference example:
```
finger [email protected]
```So what is our "address"‽
It cannot be just this:
```go
"example.com"
```Since it doesn't include a TCP-port.
But, as it turns out, this package can handle this situation.
When the TCP-port (in the address) is missing, it defaults it to the default **finger-protocol** TCP-port.
(Which is TCP-port 79.)So, now our code becomes:
```go
package mainimport (
"github.com/reiver/go-finger"
)func main() {
var target finger.Target = finger.CreateTarget("joeblow")
var request finger.Request = finger.AssembleRequestTarget(target)
var address finger.Address = finger.CreateAddressHost("example.com")
//@TODO
}
```Now we need to connect to the server.
We will do that using `net.Dial()`.So....
```go
package mainimport (
"github.com/reiver/go-finger""fmt"
"net"
)func main() {
var target finger.Target = finger.CreateTarget("joeblow")
var request finger.Request = finger.AssembleRequestTarget(target)
var address finger.Address = finger.CreateAddressHost("example.com")
conn, err := net.Dial("tcp", address.Resolve())
if nil != err {
fmt.Println("ERROR:", err)
return
}
defer conn.Close()//@TODO
}
```And now we need to create client that will use this TCP connection to make a **finger-protocol request**.
So, this will create the client:
```go
package mainimport (
"github.com/reiver/go-finger""fmt"
"net"
)func main() {
var target finger.Target = finger.CreateTarget("joeblow")
var request finger.Request = finger.AssembleRequestTarget(target)
var address finger.Address = finger.CreateAddressHost("example.com")
conn, err := net.Dial("tcp", address.Resolve())
if nil != err {
fmt.Println("ERROR:", err)
return
}
defer conn.Close()var client finger.Client = finger.AssembleClient(conn)
//@TODO
}
```And then this will send the **finger-protocol request**.
```go
package mainimport (
"github.com/reiver/go-finger""fmt"
"net"
)func main() {
var target finger.Target = finger.CreateTarget("joeblow")
var request finger.Request = finger.AssembleRequestTarget(target)
var address finger.Address = finger.CreateAddressHost("example.com")
conn, err := net.Dial("tcp", address.Resolve())
if nil != err {
fmt.Println("ERROR:", err)
return
}
defer conn.Close()var client finger.Client = finger.AssembleClient(conn)
responseReader, err := client.Do(request)
if nil != err {
fmt.Println("ERROR:", err)
return
}//@TODO
}
```And finally, this will send the **finger-protocol response** this program received from the **finger-protocol server** to STDOUT (so that we can see it):
```go
package mainimport (
"github.com/reiver/go-finger""fmt"
"io"
"net"
"os"
)func main() {
var target finger.Target = finger.CreateTarget("joeblow")
var request finger.Request = finger.AssembleRequestTarget(target)
var address finger.Address = finger.CreateAddressHost("example.com")
conn, err := net.Dial("tcp", address.Resolve())
if nil != err {
fmt.Println("ERROR:", err)
return
}
defer conn.Close()var client finger.Client = finger.AssembleClient(conn)
responseReader, err := client.Do(request)
if nil != err {
fmt.Println("ERROR:", err)
return
}io.Copy(os.Stdout, responseReader)
}
```## Unicde UTF-8
**This package supports Unicode UTF-8 text encoding for the finger-protocol.**
The finger-protocol existed **before** any IETF RFC was written about it, but —
There are 2 IETF RFCs that are relavent for the finger-protocol:
* IETF RFC-742 (released in 1977) — https://datatracker.ietf.org/doc/html/rfc742
* IETF RFC-1288 (released in 1991) — https://datatracker.ietf.org/doc/html/rfc1288IETF RFC-742 does _not_ directly or indirectly forbid the use of Unicode UTF-8 — because IETF RFC-742 does _not_ seem to explicitly specify what character-set should be used.
IETF RFC-1288 indirectly forbids the use of Unicode UTF-8.**This package sides with the original IETF RFC-742, and supports Unicode UTF-8 text.**
This package does this (supports the Unicode UTF-8 encoding of text) to provide a _more modern_ implementation of the finger-protocol.
Someone in the future can write a new IETF RFC for the finger-protocol that gives permission to use the Unicode UTF-8 text encoding.
## Import
To import package **finger** use import code like the follownig:
```
import "github.com/reiver/go-finger"
```## Installation
To install package **finger** do the following:
```
GOPROXY=direct go get https://github.com/reiver/go-finger
```## Author
Package **finger** was written by [Charles Iliya Krempeaux](http://reiver.link/)