// Copyright 1994-2025 WIT.COM Inc Licensed GPL 3.0 package forgepb import ( "bytes" "io/ioutil" "net/http" "os/user" "go.wit.com/log" ) /* func (f *Forge) HttpPostMachine(url string) ([]byte, error) { if f.Machine == nil { // run f.InitMachine() here? log.Info("you must run f.InitMachine()") return nil, fmt.Errorf("you must run f.InitMachine()") } if f.Machine.Hostname == "" { log.Info("WTF. hostname is blank") } else { log.Info("GOOD. hostname is set to", f.Machine.Hostname) } log.Info("GOOD2. hostname is set to", f.Machine.Hostname) msg, err := f.Machine.Marshal() if err != nil { log.Info("proto.Marshal() failed:", err) return nil, err } log.Info("GOOD3. hostname is set to", f.Machine.Hostname) check := new(zoopb.Machine) check.Unmarshal(msg) if check == nil { log.Info("WTF. check == nil") } log.Info("good? check.hostname =", check.Hostname) return f.HttpPost(url, msg) } */ func (f *Forge) HttpPost(url string, data []byte) ([]byte, error) { var err error var req *http.Request req, err = http.NewRequest(http.MethodPost, url, bytes.NewBuffer(data)) // log.Info("httpPost() with len", len(data), "url", url) usr, _ := user.Current() req.Header.Set("author", usr.Username) /* if f.Machine == nil { // run f.InitMachine() here? log.Info("you must run f.InitMachine()") return nil, fmt.Errorf("you must run f.InitMachine()") } */ req.Header.Set("hostname", "fixme:hostname") client := &http.Client{} resp, err := client.Do(req) if err != nil { log.Error(err) return []byte("client.Do(req) error"), err } defer resp.Body.Close() // log.Info("httpPost() with len", len(data)) body, err := ioutil.ReadAll(resp.Body) if err != nil { log.Error(err) return body, err } return body, nil }