mirror of
https://github.com/golang/go
synced 2024-11-18 18:44:42 -07:00
9ae4309624
Currently, when a POST request is made using code with build tag +build !appengine it doesn't set the content-type header passed to the function. This was breaking the case where a url-encoded body (a code snippet's body and protocol version) was being POSTed to golang.org/compile since it never set the content-type of the request and the corresponding form values parsed out were empty as a result. Update golang/go#28080 Change-Id: I677ca01b2f5aecedbd13d1faa7a838ddc0199244 Reviewed-on: https://go-review.googlesource.com/c/140838 Run-TryBot: Andrew Bonventre <andybons@golang.org> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org>
33 lines
723 B
Go
33 lines
723 B
Go
// Copyright 2012 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// +build !appengine
|
|
|
|
package playground
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"io"
|
|
"log"
|
|
"net/http"
|
|
)
|
|
|
|
func post(ctx context.Context, url, contentType string, body io.Reader) (*http.Response, error) {
|
|
req, err := http.NewRequest("POST", url, body)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("http.NewRequest: %v", err)
|
|
}
|
|
req.Header.Set("Content-Type", contentType)
|
|
return http.DefaultClient.Do(req.WithContext(ctx))
|
|
}
|
|
|
|
func contextFunc(_ *http.Request) context.Context {
|
|
return context.Background()
|
|
}
|
|
|
|
func report(r *http.Request, err error) {
|
|
log.Println(err)
|
|
}
|