"bytes"
"errors"
"fmt"
- "io/ioutil"
- "log"
- "os"
"os/exec"
- "path/filepath"
"strings"
ttls "go.stargrave.org/tofuproxy/tls"
)
-func findInNetrc(host string) (string, string) {
- netrcPath, ok := os.LookupEnv("NETRC")
- if !ok {
- netrcPath = filepath.Join(os.Getenv("HOME"), ".netrc")
- }
- data, err := ioutil.ReadFile(netrcPath)
- if err != nil {
- if os.IsNotExist(err) {
- return "", ""
- }
- log.Fatalln(err)
- }
- var login string
- var password string
- for _, line := range strings.Split(string(data), "\n") {
- if i := strings.Index(line, "#"); i >= 0 {
- line = line[:i]
- }
- f := strings.Fields(line)
- if len(f) >= 6 &&
- f[0] == "machine" && f[1] == host &&
- f[2] == "login" && f[4] == "password" {
- login, password = f[3], f[5]
- break
- }
- }
- return login, password
-}
-
func authDialog(host, realm string) (string, string, error) {
var b bytes.Buffer
userInit, passInit := findInNetrc(host)
--- /dev/null
+// Nearly all code is taken from src/cmd/go/internal/auth/netrc.go
+
+package tofuproxy
+
+import (
+ "io/ioutil"
+ "log"
+ "os"
+ "path/filepath"
+ "strings"
+)
+
+func findInNetrc(host string) (string, string) {
+ netrcPath, ok := os.LookupEnv("NETRC")
+ if !ok {
+ homeDir, err := os.UserHomeDir()
+ if err != nil {
+ log.Fatalln(err)
+ }
+ netrcPath = filepath.Join(homeDir, ".netrc")
+ }
+ data, err := ioutil.ReadFile(netrcPath)
+ if err != nil {
+ if os.IsNotExist(err) {
+ return "", ""
+ }
+ log.Fatalln(err)
+ }
+ inMacro := false
+ var machine, login, password string
+ for _, line := range strings.Split(string(data), "\n") {
+ if inMacro {
+ if line == "" {
+ inMacro = false
+ }
+ continue
+ }
+ fields := strings.Fields(line)
+ i := 0
+ for ; i < len(fields)-1; i += 2 {
+ switch fields[i] {
+ case "machine":
+ machine = fields[i+1]
+ login = ""
+ password = ""
+ case "default":
+ break
+ case "login":
+ login = fields[i+1]
+ case "password":
+ password = fields[i+1]
+ case "macdef":
+ inMacro = true
+ }
+ if machine != "" && login != "" && password != "" {
+ if machine == host {
+ return login, password
+ }
+ machine, login, password = "", "", ""
+ }
+ }
+ if i < len(fields) && fields[i] == "default" {
+ break
+ }
+ }
+ return "", ""
+}