package server
import (
"encoding/json"
"log"
"net/http"
)
// Start is the entry point of web services
func Start() {
r := mux.NewRouter()
r.Use(middleware)
r.HandleFunc("/teste", teste).Methods("GET")
r.Use(mux.CORSMethodMiddleware(r))
log.Println("HTTPS Escutando a porta: 443")
log.Fatalln(http.ListenAndServeTLS(":443", "server.crt", "server.key", r))
}
func middleware(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.Header().Add("Content-Type", "application/json")
w.Header().Set("Access-Control-Allow-Headers", "Accept, Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization")
w.Header().Set("Access-Control-Allow-Origin", "*")
w.Header().Set("Access-Control-Max-Age", "86400")
w.Header().Set("Access-Control-Allow-Methods", "GET, OPTIONS, HEAD, PUT, POST")
w.Header().Set("Access-Control-Allow-Credentials", "true")
w.Header().Set("Access-Control-Expose-Headers", "X-Header, X-Y-Header")
r.Header.Set("Access-Control-Request-Method", "POST, GET") // needs to be non-empty
r.Header.Set("Access-Control-Request-Headers", "Accept, Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization") // needs to be non-empty
r.Header.Set("Access-Control-Request-Origin", "*")
r.Header.Set("Access-Control-Expose-Headers", "X-Header, X-Y-Header")
next.ServeHTTP(w, r)
})
}
func teste(rw http.ResponseWriter, req *http.Request) {
json.NewEncoder(rw).Encode("Backend 1.21 443 is working....")
}