add registration function
This commit is contained in:
parent
2544fe4fcf
commit
804268f298
2 changed files with 111 additions and 3 deletions
|
@ -18,5 +18,6 @@ linters-settings:
|
||||||
|
|
||||||
linters:
|
linters:
|
||||||
enable-all: true
|
enable-all: true
|
||||||
# disable:
|
disable:
|
||||||
|
#- json
|
||||||
fast: false
|
fast: false
|
||||||
|
|
111
main.go
111
main.go
|
@ -1,7 +1,114 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import "fmt"
|
import (
|
||||||
|
"bytes"
|
||||||
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
fmt.Println("Hello, Enbas!")
|
register()
|
||||||
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
applicationName = "Enbas"
|
||||||
|
redirectUris = "urn:ietf:wg:oauth:2.0:oob"
|
||||||
|
)
|
||||||
|
|
||||||
|
type AccountConfig struct {
|
||||||
|
CurrentAccount string `json:"currentAccount"`
|
||||||
|
Accounts map[string]Account `json:"accounts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type Account struct {
|
||||||
|
Instance string `json:"instance"`
|
||||||
|
ClientID string `json:"clientId"`
|
||||||
|
ClientSecret string `json:"clientSecret"`
|
||||||
|
AccessToken string `json:"accessToken"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type RegisterRequest struct {
|
||||||
|
ClientName string `json:"client_name"`
|
||||||
|
RedirectUris string `json:"redirect_uris"`
|
||||||
|
Scopes string `json:"scopes"`
|
||||||
|
Website string `json:"website"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type RegisterResponse struct {
|
||||||
|
ClientID string `json:"client_id"`
|
||||||
|
ClientSecret string `json:"client_secret"`
|
||||||
|
ID string `json:"id"`
|
||||||
|
Name string `json:"name"`
|
||||||
|
RedirectUri string `json:"redirect_uri"`
|
||||||
|
VapidKey string `json:"vapid_key"`
|
||||||
|
Website string `json:"website"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func register() Account {
|
||||||
|
// ask user for instance, if not start with http(s), prepend with https.
|
||||||
|
fmt.Print("Please enter the instance URL: ")
|
||||||
|
|
||||||
|
instance := ""
|
||||||
|
if _, err := fmt.Scanln(&instance); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
request := RegisterRequest{
|
||||||
|
ClientName: applicationName,
|
||||||
|
RedirectUris: redirectUris,
|
||||||
|
Scopes: "read",
|
||||||
|
Website: "",
|
||||||
|
}
|
||||||
|
|
||||||
|
data, err := json.Marshal(request)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
httpRequestBody := bytes.NewBuffer(data)
|
||||||
|
|
||||||
|
path := "/api/v1/apps"
|
||||||
|
url := instance + path
|
||||||
|
|
||||||
|
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
|
||||||
|
defer cancel()
|
||||||
|
|
||||||
|
httpRequest, err := http.NewRequestWithContext(ctx, http.MethodPost, url, httpRequestBody)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
httpRequest.Header.Add("Content-Type", "application/json")
|
||||||
|
httpRequest.Header.Set("User-Agent", "Enbas/0.0.0")
|
||||||
|
|
||||||
|
httpClient := http.Client{}
|
||||||
|
|
||||||
|
httpResponse, err := httpClient.Do(httpRequest)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
defer httpResponse.Body.Close()
|
||||||
|
|
||||||
|
var registerResponse RegisterResponse
|
||||||
|
|
||||||
|
if err := json.NewDecoder(httpResponse.Body).Decode(®isterResponse); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println(registerResponse)
|
||||||
|
|
||||||
|
fmt.Println("Please sign into your instance with your browser and enter the access token\nAccess token: ")
|
||||||
|
|
||||||
|
account := Account{
|
||||||
|
Instance: instance,
|
||||||
|
ClientID: registerResponse.ClientID,
|
||||||
|
ClientSecret: registerResponse.ClientSecret,
|
||||||
|
AccessToken: "",
|
||||||
|
}
|
||||||
|
|
||||||
|
return account
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue