Gary Kramlich 4b87ea1cc7 Add (dis|re)connect commands and provision api %!s(int64=3) %!d(string=hai) anos
..
README.md 94104102d2 Initial discord remote auth support. %!s(int64=3) %!d(string=hai) anos
client.go 4b87ea1cc7 Add (dis|re)connect commands and provision api %!s(int64=3) %!d(string=hai) anos
clientpackets.go 94104102d2 Initial discord remote auth support. %!s(int64=3) %!d(string=hai) anos
serverpackets.go 4b87ea1cc7 Add (dis|re)connect commands and provision api %!s(int64=3) %!d(string=hai) anos
user.go 94104102d2 Initial discord remote auth support. %!s(int64=3) %!d(string=hai) anos

README.md

Discord Remote Authentication

This library implements the desktop side of Discord's remote authentication protocol.

It is completely based off of the Unofficial Discord API Documentation.

Example

package main

import (
	"context"
	"fmt"

	"github.com/skip2/go-qrcode"
)

func main() {
	client, err := New()
	if err != nil {
		fmt.Printf("error: %v\n", err)

		return
	}

	ctx := context.Background()

	qrChan := make(chan *qrcode.QRCode)
	go func() {
		qrCode := <-qrChan
		fmt.Println(qrCode.ToSmallString(true))
	}()

	doneChan := make(chan struct{})

	if err := client.Dial(ctx, qrChan, doneChan); err != nil {
		close(qrChan)
		close(doneChan)

		fmt.Printf("dial error: %v\n", err)

		return
	}

	<-doneChan

	user, err := client.Result()
	fmt.Printf("user: %q\n", user)
	fmt.Printf("err: %v\n", err)
}