about summary refs log tree commit diff
diff options
context:
space:
mode:
authorWilliam Carroll <wpcarro@gmail.com>2020-02-05T17·58+0000
committerWilliam Carroll <wpcarro@gmail.com>2020-02-05T17·58+0000
commit1772408c3989c86044ee97ca9bd51ddf509adb47 (patch)
tree7d0c6eb36c8c37a2f3e9ef327a70c904fbcbe1b6
parent05135ef875497b9699c393f9ab7ac99c4c523827 (diff)
Further support Monzo OAuth2.0 login flow
I'm now pulling the authorization code off of Monzo's request to my redirect
URI. I intend to use exchange that code for an access and refresh token. Once I
have these two items, I should be able to interact with Monzo's API much more
easily.
-rw-r--r--monzo-ynab/main.go46
1 files changed, 43 insertions, 3 deletions
diff --git a/monzo-ynab/main.go b/monzo-ynab/main.go
index f5c9e9cbbeca..aee66e7c29c0 100644
--- a/monzo-ynab/main.go
+++ b/monzo-ynab/main.go
@@ -15,6 +15,8 @@ import (
 var (
 	clientId     = os.Getenv("client_id")
 	clientSecret = os.Getenv("client_secret")
+	accessToken  = nil
+	refreshToken = nil
 )
 
 const (
@@ -22,14 +24,52 @@ const (
 	redirectUri = "http://localhost:8080/authorize"
 )
 
+func getAccessCode(string authCode) {
+	form := map[string]string{
+		"grant_type":    "authorization_code",
+		"client_id":     client_id,
+		"client_secret": client_secret,
+		"redirect_uri":  redirectUri,
+		"code":          authCode,
+	}
+	json := map[string]string{
+		"access_token":  "access_token",
+		"client_id":     "client_id",
+		"expires_in":    21600,
+		"refresh_token": "refresh_token",
+		"token_type":    "Bearer",
+		"user_id":       "user_id",
+	}
+
+	// TODO: Handle retry with backoff logic here.
+	resp, error := http.Post("https://api.monzo.com/oauth2/token", form.Form(), json.Json())
+	if err != nil {
+		log.Fatal("Could not exchange authorization code for an access token.")
+	}
+
+	resp.Body()
+}
+
 func handleRedirect(w http.ResponseWriter, r *http.Request) {
-	fmt.Println(r)
-	fmt.Fprintf(w, "Ackified")
+	// assert that `r.state` is the same as `state`.
+	params := r.URL.Query()
+
+	reqState := params["state"][0]
+	reqCode := params["code"][0]
+
+	if reqState != state {
+		log.Fatal(fmt.Sprintf("Value for state returned by Monzo does not equal our state. %s != %s", reqState, state))
+	}
+
+	go getAccessCode(reqCode)
+
+	fmt.Printf("Received the authorization code from Monzo: %s", reqCode)
+	fmt.Fprintf(w, fmt.Sprintf("Authorization code: %s", reqCode))
 }
 
 func authorizeClient() {
 	url :=
-		fmt.Sprintf("https://auth.monzo.com/?client_id=%s&redirect_uri=%s&response_type=code&state=:state",
+		fmt.Sprintf("https://auth.monzo.com/?client_id=%s&redirect_uri=%s&response_type=code&state=%s",
 			clientId, redirectUri, state)
 	exec.Command("google-chrome", url).Start()
 }