package main import ( "fmt" "log" "net/http" mgo "gopkg.in/mgo.v2" "github.com/fatih/color" "github.com/gorilla/handlers" ownrsa "./ownrsa" ) var userCollection *mgo.Collection var serverRSA ownrsa.RSA func main() { color.Blue("Starting serverIDsigner") //read configuration file readConfig("config.json") initializeToken() //initialize RSA serverRSA = ownrsa.GenerateKeyPair() color.Blue("Public Key:") fmt.Println(serverRSA.PubK) color.Green("Private Key:") fmt.Println(serverRSA.PrivK) //mongodb session, err := getSession() check(err) userCollection = getCollection(session, "users") //run thw webserver go webserver() //run API log.Println("api server running") log.Print("port: ") log.Println(config.Port) router := NewRouter() headersOk := handlers.AllowedHeaders([]string{"X-Requested-With", "Access-Control-Allow-Origin"}) originsOk := handlers.AllowedOrigins([]string{"*"}) methodsOk := handlers.AllowedMethods([]string{"GET", "HEAD", "POST", "PUT", "OPTIONS"}) log.Fatal(http.ListenAndServe(":"+config.Port, handlers.CORS(originsOk, headersOk, methodsOk)(router))) } func webserver() { log.Println("webserver in port " + config.WebServerPort) http.Handle("/", http.FileServer(http.Dir("./webapp"))) http.ListenAndServe(":"+config.WebServerPort, nil) }