This commit is contained in:
parent
5244119ffe
commit
31556d3a6b
47
api/oauth.go
47
api/oauth.go
@ -1,56 +1,15 @@
|
|||||||
package oauth
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
"log"
|
|
||||||
"net/http"
|
|
||||||
"os"
|
|
||||||
"time"
|
|
||||||
"x/oauth2"
|
|
||||||
"github.com/ProjectSegfault/segfautils/config"
|
"github.com/ProjectSegfault/segfautils/config"
|
||||||
"github.com/goccy/go-json"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
clientID = config.OAuthClientID()
|
clientID = config.OAuthClientID()
|
||||||
clientSecret = config.OAuthClientSecret()
|
clientSecret = config.OAuthClientSecret()
|
||||||
redirectURL = config.RedirectURL()
|
redirectURL = config.OAuthRedirectURL()
|
||||||
authURL = config.AuthURL()
|
authURL = config.OAuthURL()
|
||||||
)
|
)
|
||||||
|
|
||||||
func LoginOAuth() {
|
func LoginOAuth() {
|
||||||
// Create a new redirect route route
|
|
||||||
http.HandleFunc("/oauth/redirect", func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
err := r.ParseForm()
|
|
||||||
if err != nil {
|
|
||||||
fmt.Fprintf(os.Stdout, "could not parse query: %v", err)
|
|
||||||
w.WriteHeader(http.StatusBadRequest)
|
|
||||||
}
|
|
||||||
code := r.FormValue("code")
|
|
||||||
reqURL := fmt.Sprintf("%s/login/oauth/access_token?client_id=%s&client_secret=%s&code=%s", authURL, clientID, clientSecret, code)
|
|
||||||
req, err := http.NewRequest(http.MethodPost, reqURL, nil)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Fprintf(os.Stdout, "could not create HTTP request: %v", err)
|
|
||||||
w.WriteHeader(http.StatusBadRequest)
|
|
||||||
}
|
|
||||||
req.Header.Set("accept", "application/json")
|
|
||||||
res, err := httpClient.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Fprintf(os.Stdout, "could not send HTTP request: %v", err)
|
|
||||||
w.WriteHeader(http.StatusInternalServerError)
|
|
||||||
}
|
|
||||||
defer res.Body.Close()
|
|
||||||
var t OAuthAccessResponse
|
|
||||||
if err := json.NewDecoder(res.Body).Decode(&t); err != nil {
|
|
||||||
fmt.Fprintf(os.Stdout, "could not parse JSON response: %v", err)
|
|
||||||
w.WriteHeader(http.StatusBadRequest)
|
|
||||||
}
|
|
||||||
w.Header().Set("Location", "/announcements/?access_token="+t.AccessToken)
|
|
||||||
w.WriteHeader(http.StatusFound)
|
|
||||||
}
|
|
||||||
|
|
||||||
type OAuthAccessResponse struct {
|
|
||||||
AccessToken string `json:"access_token"`
|
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@ import (
|
|||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
)
|
)
|
||||||
|
|
||||||
func RedirectURL() string {
|
func OAuthRedirectURL() string {
|
||||||
viper.SetConfigName("config")
|
viper.SetConfigName("config")
|
||||||
viper.AddConfigPath("./data")
|
viper.AddConfigPath("./data")
|
||||||
err := viper.ReadInConfig()
|
err := viper.ReadInConfig()
|
||||||
|
@ -6,7 +6,7 @@ import (
|
|||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
)
|
)
|
||||||
|
|
||||||
func AuthURL() string {
|
func OAuthURL() string {
|
||||||
viper.SetConfigName("config")
|
viper.SetConfigName("config")
|
||||||
viper.AddConfigPath("./data")
|
viper.AddConfigPath("./data")
|
||||||
err := viper.ReadInConfig()
|
err := viper.ReadInConfig()
|
||||||
|
8
data/lol.toml
Normal file
8
data/lol.toml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
[segfautils]
|
||||||
|
port = 6893
|
||||||
|
webhook_url = "https://127.0.0.1:8080/segfautils"
|
||||||
|
auth_token = "121212"
|
||||||
|
|
||||||
|
[hcaptcha]
|
||||||
|
site_key = "lol"
|
||||||
|
secret_key = "lol2"
|
@ -2,7 +2,7 @@
|
|||||||
Web utilities for Project Segfault
|
Web utilities for Project Segfault
|
||||||
|
|
||||||
## What does it do?
|
## What does it do?
|
||||||
For now it powers our contact form. In the future we will expand our APIs so you can do more cool things.
|
For now it powers our contact form and our announcements page. In the future we will expand our APIs so you can do more cool things. (We currently do not have any new idea so please open issues and give us suggestions!!)
|
||||||
|
|
||||||
## Setup
|
## Setup
|
||||||
|
|
||||||
@ -20,7 +20,7 @@ If you're using Portainer, you should know how to add Segfautils.
|
|||||||
```
|
```
|
||||||
git clone https://github.com/ProjectSegfault/segfautils
|
git clone https://github.com/ProjectSegfault/segfautils
|
||||||
cd segfautils/
|
cd segfautils/
|
||||||
# You need to add the environment HCAPTCHA_SITE_KEY, HCAPTCHA_SECRET_KEY, SEGFAUTILS_WEBHOOK_URL and SEGFAUTILS_PORT.
|
# You need to config file located in data/config.toml.
|
||||||
go run main.go # Run this when you've done above, and you're planning on developing, if not, do below
|
go run main.go # Run this when you've done above, and you're planning on developing, if not, do below
|
||||||
go build . -o segfautils
|
go build . -o segfautils
|
||||||
./segfautils
|
./segfautils
|
||||||
|
@ -2,16 +2,39 @@
|
|||||||
package utils
|
package utils
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"log"
|
"fmt"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
"github.com/ProjectSegfault/segfautils/config"
|
var (
|
||||||
|
is = 0
|
||||||
|
arrName = [9]string{"Port", "Authentication token", "Webhook URL", "HCaptcha secret", "Hcaptcha site key", "OAuth client ID", "OAuth client secret", "OAuth redirect URL", "OAuth athentication URL"}
|
||||||
|
arrCfg = [9]string{"0", "YOURAUTHTOKEN", "YOURWEBHOOKURL", "YOURSECRETKEY", "YOURSITEKEY", "YOURCLIENTID", "YOURCLIENTSECRET", "YOURREDIRECTURL", "YOURAUTHURL"}
|
||||||
|
testCfg = [9]string{"config.Authtoken()", "config.WebhookURL()", "config.HCaptchaSecretKey()", "config.HCaptchaSiteKey()", "config.OAuthClientID()", "config.OAuthClientSecret()", "config.OAuthRedirectURL()", "config.OAuthURL()"}
|
||||||
)
|
)
|
||||||
|
|
||||||
func CheckConfig() {
|
func CheckConfig() {
|
||||||
if config.Port() == "0" {
|
|
||||||
log.Fatal("[Segfautils] ❌ You need to set the port you'd like to use in the config file. Check documentation for more information.")
|
for i := 0; i < 8; i++ {
|
||||||
|
if testCfg[i] == arrCfg[i] || testCfg[i] == "" {
|
||||||
|
fmt.Println(arrCfg[i])
|
||||||
|
is = i
|
||||||
|
Fail()
|
||||||
} else {
|
} else {
|
||||||
log.Println("[Segfautils] ✅ segfautils.port is set to", config.Port())
|
fmt.Println(arrCfg[i])
|
||||||
|
fmt.Println(testCfg[i])
|
||||||
|
is = i
|
||||||
|
Check()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
func CheckConfig() {
|
||||||
|
if config.Port() == "0" {
|
||||||
|
Fail()
|
||||||
|
} else {
|
||||||
|
Check()
|
||||||
}
|
}
|
||||||
if config.AuthToken() == "YOURAUTHTOKEN" || config.AuthToken() == "" {
|
if config.AuthToken() == "YOURAUTHTOKEN" || config.AuthToken() == "" {
|
||||||
log.Fatal("[Segfautils] ❌ You need to set the authentication token you'd like to use in the config file. Check documentation for more information.")
|
log.Fatal("[Segfautils] ❌ You need to set the authentication token you'd like to use in the config file. Check documentation for more information.")
|
||||||
@ -34,5 +57,23 @@ func CheckConfig() {
|
|||||||
} else {
|
} else {
|
||||||
log.Println("[Segfautils] ✅ hcaptcha.site_key is set!")
|
log.Println("[Segfautils] ✅ hcaptcha.site_key is set!")
|
||||||
}
|
}
|
||||||
log.Println("[Segfautils] ✅ All config checks passed!")
|
log.Println("[segfautils] ✅ All config checks passed!")
|
||||||
|
log.Println("[segfautils] ✅ Listening at port ", config.Port())
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
func Check() {
|
||||||
|
fmt.Printf("[Segfautils] ✅ %s is set!\n", arrName[is])
|
||||||
|
}
|
||||||
|
|
||||||
|
func Fail() {
|
||||||
|
fmt.Printf("[Segfautils] ❌ You need to set the %s you'd like to use in the config file. Check documentation for more information.\n", arrName[is])
|
||||||
|
os.Exit(Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
func OptionalFail() {
|
||||||
|
fmt.Printf("[Segfautils] ⚠️ The %s isn't set. You don't have to, but the program will not be able to behave correctly. Check documentation for more information.\n", arrName[is])
|
||||||
|
}
|
||||||
|
|
||||||
|
func Error() int {
|
||||||
|
return 12
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user