mirror of
https://github.com/christianselig/apollo-backend
synced 2024-11-10 22:17:44 +00:00
91 lines
2.3 KiB
Go
91 lines
2.3 KiB
Go
|
package api
|
||
|
|
||
|
import (
|
||
|
"encoding/json"
|
||
|
"net/http"
|
||
|
"time"
|
||
|
|
||
|
"github.com/julienschmidt/httprouter"
|
||
|
"github.com/sirupsen/logrus"
|
||
|
|
||
|
"github.com/christianselig/apollo-backend/internal/data"
|
||
|
)
|
||
|
|
||
|
func (a *api) upsertAccountHandler(w http.ResponseWriter, r *http.Request, ps httprouter.Params) {
|
||
|
acct := &data.Account{}
|
||
|
if err := json.NewDecoder(r.Body).Decode(a); err != nil {
|
||
|
a.logger.WithFields(logrus.Fields{
|
||
|
"err": err,
|
||
|
}).Info("failed to parse request json")
|
||
|
a.errorResponse(w, r, 422, err.Error())
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// Here we check whether the account is supplied with a valid token.
|
||
|
ac := a.reddit.NewAuthenticatedClient(acct.RefreshToken, acct.AccessToken)
|
||
|
tokens, err := ac.RefreshTokens()
|
||
|
if err != nil {
|
||
|
a.logger.WithFields(logrus.Fields{
|
||
|
"err": err,
|
||
|
}).Info("failed to refresh token")
|
||
|
a.errorResponse(w, r, 422, err.Error())
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// Reset expiration timer
|
||
|
acct.ExpiresAt = time.Now().Unix() + 3540
|
||
|
acct.RefreshToken = tokens.RefreshToken
|
||
|
acct.AccessToken = tokens.AccessToken
|
||
|
|
||
|
ac = a.reddit.NewAuthenticatedClient(acct.RefreshToken, acct.AccessToken)
|
||
|
me, err := ac.Me()
|
||
|
|
||
|
if err != nil {
|
||
|
a.logger.WithFields(logrus.Fields{
|
||
|
"err": err,
|
||
|
}).Info("failed to grab user details from Reddit")
|
||
|
a.errorResponse(w, r, 500, err.Error())
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if me.NormalizedUsername() != acct.NormalizedUsername() {
|
||
|
a.logger.WithFields(logrus.Fields{
|
||
|
"err": err,
|
||
|
}).Info("user is not who they say they are")
|
||
|
a.errorResponse(w, r, 422, "nice try")
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// Set account ID from Reddit
|
||
|
acct.AccountID = me.ID
|
||
|
|
||
|
// Associate
|
||
|
d, err := a.models.Devices.GetByAPNSToken(ps.ByName("apns"))
|
||
|
if err != nil {
|
||
|
a.logger.WithFields(logrus.Fields{
|
||
|
"err": err,
|
||
|
}).Info("failed fetching device from database")
|
||
|
a.errorResponse(w, r, 500, err.Error())
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// Upsert account
|
||
|
if err := a.models.Accounts.Upsert(acct); err != nil {
|
||
|
a.logger.WithFields(logrus.Fields{
|
||
|
"err": err,
|
||
|
}).Info("failed updating account in database")
|
||
|
a.errorResponse(w, r, 500, err.Error())
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if err := a.models.DevicesAccounts.Associate(acct.ID, d.ID); err != nil {
|
||
|
a.logger.WithFields(logrus.Fields{
|
||
|
"err": err,
|
||
|
}).Info("failed associating account with device")
|
||
|
a.errorResponse(w, r, 500, err.Error())
|
||
|
return
|
||
|
}
|
||
|
|
||
|
w.WriteHeader(http.StatusOK)
|
||
|
}
|