aboutsummaryrefslogtreecommitdiffstats
path: root/swarm/api/http/server.go
diff options
context:
space:
mode:
Diffstat (limited to 'swarm/api/http/server.go')
-rw-r--r--swarm/api/http/server.go26
1 files changed, 23 insertions, 3 deletions
diff --git a/swarm/api/http/server.go b/swarm/api/http/server.go
index f82775f25..c8e79ab4e 100644
--- a/swarm/api/http/server.go
+++ b/swarm/api/http/server.go
@@ -24,6 +24,7 @@ import (
"io"
"net/http"
"regexp"
+ "strings"
"sync"
"time"
@@ -31,6 +32,7 @@ import (
"github.com/ethereum/go-ethereum/logger"
"github.com/ethereum/go-ethereum/logger/glog"
"github.com/ethereum/go-ethereum/swarm/api"
+ "github.com/rs/cors"
)
const (
@@ -53,19 +55,37 @@ type sequentialReader struct {
lock sync.Mutex
}
+// Server is the basic configuration needs for the HTTP server and also
+// includes CORS settings.
+type Server struct {
+ Addr string
+ CorsString string
+}
+
// browser API for registering bzz url scheme handlers:
// https://developer.mozilla.org/en/docs/Web-based_protocol_handlers
// electron (chromium) api for registering bzz url scheme handlers:
// https://github.com/atom/electron/blob/master/docs/api/protocol.md
// starts up http server
-func StartHttpServer(api *api.Api, port string) {
+func StartHttpServer(api *api.Api, server *Server) {
serveMux := http.NewServeMux()
serveMux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
handler(w, r, api)
})
- go http.ListenAndServe(":"+port, serveMux)
- glog.V(logger.Info).Infof("Swarm HTTP proxy started on localhost:%s", port)
+ var allowedOrigins []string
+ for _, domain := range strings.Split(server.CorsString, ",") {
+ allowedOrigins = append(allowedOrigins, strings.TrimSpace(domain))
+ }
+ c := cors.New(cors.Options{
+ AllowedOrigins: allowedOrigins,
+ AllowedMethods: []string{"POST", "GET", "DELETE", "PATCH", "PUT"},
+ MaxAge: 600,
+ })
+ hdlr := c.Handler(serveMux)
+
+ go http.ListenAndServe(server.Addr, hdlr)
+ glog.V(logger.Info).Infof("Swarm HTTP proxy started on localhost:%s", server.Addr)
}
func handler(w http.ResponseWriter, r *http.Request, a *api.Api) {