.. | ||
cmd/wflookup | ||
handler_test.go | ||
handler.go | ||
lookup.go | ||
README.md | ||
types.go |
WebFinger
This is a simple implementation of a Go server handler and client for the WebFinger discovery protocol (RFC7033).
wflookup
This package includes a command that looks up WebFinger descriptors. You can install it with the following command:
go install queerdevs.org/profilefed/webfinger/cmd/wflookup@latest
Here are some examples for how to use it:
wflookup acct:user@example.com
wflookup http://example.com/resource/1
wflookup user@example.com # wflookup will infer the acct scheme
If you'd like to specify the server that's going to be used instead of it being inferred, you can do so using the --server
flag.
Example library usage
Server
package main
import (
"net/http"
"queerdevs.org/profilefed/webfinger"
)
func main() {
mux := http.NewServeMux()
mux.Handle("GET /.well-known/webfinger", Handler{
DescriptorFunc: func(resource string) (*Descriptor, error) {
// You can query a database here, or do whatever you need
// to in order to get the descriptor data.
return desc, nil
},
})
err := http.ListenAndServe(":8080", mux)
if err != nil {
panic(err)
}
}
Client
package main
import (
"fmt"
"queerdevs.org/profilefed/webfinger"
)
func main() {
desc, err := webfinger.Lookup("acct:user@example.com", "example.com:8080")
if err != nil {
panic(err)
}
fmt.Println(desc)
desc, err = webfinger.LookupAcct("user@example.com")
if err != nil {
panic(err)
}
fmt.Println(desc)
desc, err = webfinger.LookupURL("http://example.com/resource/1")
if err != nil {
panic(err)
}
fmt.Println(desc)
}