mirror of
https://codeberg.org/flpolyaplus/aplus.git
synced 2024-11-21 17:00:30 -05:00
Move aplus requests to new launch_aplus function
This commit is contained in:
parent
78fd5e4e1f
commit
e46ca43d4c
12
README.md
12
README.md
@ -1,3 +1,13 @@
|
|||||||
# aplus
|
# aplus
|
||||||
|
|
||||||
aplus cli
|
aplus cli
|
||||||
|
|
||||||
|
# Usage
|
||||||
|
|
||||||
|
# Launch interactive prompt
|
||||||
|
aplus
|
||||||
|
|
||||||
|
# Enter code immediately
|
||||||
|
aplus -c <code>
|
||||||
|
aplus --code <code>
|
||||||
|
|
||||||
|
28
aplus.go
28
aplus.go
@ -75,3 +75,31 @@ func extract_attribute(input string, attribute string) string {
|
|||||||
|
|
||||||
return input[start : start+end]
|
return input[start : start+end]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func launch_aplus(course_code int) {
|
||||||
|
aplus_link := fmt.Sprintf("%s/courses/%d/external_tools/sessionless_launch?id=913&access_token=%s", base_link, course_code, token) // 7329 always works
|
||||||
|
aplus := get_aplus(token, aplus_link, client)
|
||||||
|
|
||||||
|
resp, err := client.Get(aplus)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("Error while performing GET request to aplus auth link.")
|
||||||
|
}
|
||||||
|
|
||||||
|
defer resp.Body.Close()
|
||||||
|
body, _ := io.ReadAll(resp.Body)
|
||||||
|
|
||||||
|
form_str := get_form_from_request_body(body)
|
||||||
|
|
||||||
|
form_values := parse_form(form_str)
|
||||||
|
|
||||||
|
resp, _ = client.PostForm("https://floridapoly.aplusattendance.com/canvas", form_values)
|
||||||
|
|
||||||
|
body, err = io.ReadAll(resp.Body)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("Error reading body of post form response from aplus attendance.")
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println(string(body))
|
||||||
|
}
|
||||||
|
17
canvas.go
17
canvas.go
@ -5,18 +5,35 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"net/http/cookiejar"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
|
"golang.org/x/net/publicsuffix"
|
||||||
)
|
)
|
||||||
|
|
||||||
func initialize() {
|
func initialize() {
|
||||||
base_link = "https://floridapolytechnic.instructure.com/api/v1"
|
base_link = "https://floridapolytechnic.instructure.com/api/v1"
|
||||||
token = os.Getenv("CANVAS_API_KEY")
|
token = os.Getenv("CANVAS_API_KEY")
|
||||||
|
|
||||||
|
jar, _ := cookiejar.New(&cookiejar.Options{
|
||||||
|
PublicSuffixList: publicsuffix.List,
|
||||||
|
})
|
||||||
|
|
||||||
|
client = http.Client{
|
||||||
|
CheckRedirect: func(req *http.Request, via []*http.Request) error {
|
||||||
|
fmt.Println("Redirected to:", req.URL)
|
||||||
|
fmt.Println(req.Cookies())
|
||||||
|
return nil
|
||||||
|
},
|
||||||
|
Jar: jar,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func get_courses(token string, link string, client http.Client) []CanvasCourse {
|
func get_courses(token string, link string, client http.Client) []CanvasCourse {
|
||||||
resp, err := client.Get(link)
|
resp, err := client.Get(link)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Error performing GET request to get courses.")
|
fmt.Println("Error performing GET request to get courses.")
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
body, _ := io.ReadAll(resp.Body)
|
body, _ := io.ReadAll(resp.Body)
|
||||||
|
75
main.go
75
main.go
@ -1,86 +1,19 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/cookiejar"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"golang.org/x/net/publicsuffix"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var base_link string
|
var base_link string
|
||||||
var token string
|
var token string
|
||||||
|
var client http.Client
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
||||||
jar, _ := cookiejar.New(&cookiejar.Options{
|
|
||||||
PublicSuffixList: publicsuffix.List,
|
|
||||||
})
|
|
||||||
|
|
||||||
client := http.Client{
|
|
||||||
CheckRedirect: func(req *http.Request, via []*http.Request) error {
|
|
||||||
fmt.Println("Redirected to:", req.URL)
|
|
||||||
fmt.Println(req.Cookies())
|
|
||||||
return nil
|
|
||||||
},
|
|
||||||
Jar: jar,
|
|
||||||
}
|
|
||||||
|
|
||||||
initialize()
|
initialize()
|
||||||
|
|
||||||
// select_course()
|
// select_course()
|
||||||
|
course_code := 7329
|
||||||
|
launch_aplus(course_code)
|
||||||
|
|
||||||
aplus_link := fmt.Sprintf("%s/courses/%d/external_tools/sessionless_launch?id=913&access_token=%s", base_link, 7329, token) // 7329 always works
|
// enter_code()
|
||||||
aplus := get_aplus(token, aplus_link, client)
|
|
||||||
fmt.Println(aplus)
|
|
||||||
resp, err := client.Get(aplus)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("Error while performing GET request to aplus auth link.")
|
|
||||||
}
|
|
||||||
|
|
||||||
defer resp.Body.Close()
|
|
||||||
body, _ := io.ReadAll(resp.Body)
|
|
||||||
|
|
||||||
form_str := get_form_from_request_body(body)
|
|
||||||
fmt.Println(form_str)
|
|
||||||
|
|
||||||
form_values := parse_form(form_str)
|
|
||||||
|
|
||||||
fmt.Println("Form Values:")
|
|
||||||
for key, values := range form_values {
|
|
||||||
fmt.Printf("%s: %s\n", key, values)
|
|
||||||
}
|
|
||||||
|
|
||||||
//req, _ := client.PostForm("https://floridapoly.aplusattendance.com/canvas", form_values)
|
|
||||||
req, _ := http.NewRequest(http.MethodPost, "https://floridapoly.aplusattendance.com/canvas", strings.NewReader(form_values.Encode()))
|
|
||||||
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
|
|
||||||
req.Header.Set("Access-Control-Allow-Origin", "*")
|
|
||||||
req.Header.Set("Access-Control-Allow-Credentials", "true")
|
|
||||||
req.Header.Set("Access-Control-Allow-Headers", "Content-Type,access-control-allow-origin, access-control-allow-headers,access-control-allow-credentials")
|
|
||||||
|
|
||||||
resp, err = client.Do(req)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("Error posting form to Aplus Attendance.")
|
|
||||||
}
|
|
||||||
|
|
||||||
body, err = io.ReadAll(resp.Body)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("Error reading body of post form response from aplus attendance.")
|
|
||||||
}
|
|
||||||
|
|
||||||
fmt.Println(string(body))
|
|
||||||
//fmt.Println(resp)
|
|
||||||
fmt.Println(resp.Header)
|
|
||||||
fmt.Println(resp.Cookies())
|
|
||||||
// we need to submit the above post request correctly in order to submit this request.
|
|
||||||
//resp, _ = client.Get("https://floridapoly.aplusattendance.com/canvas/student/?canvasCourse=7329&doStudentAuth=truee")
|
|
||||||
//body, _ = io.ReadAll(resp.Body)
|
|
||||||
|
|
||||||
//fmt.Println(string(body))
|
|
||||||
//fmt.Println(req)
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user