These are UI changes 1. Added a constructor for websocket message 2. Fixed the airshipui-ui to be airshipui 3. Fixed the refresh not displaying a page 4. Renamed the angular components to match the go backend 5. Change the websocket service from multicast to direct messaging 6. Collapsed the notification service into the websocket service Change-Id: If8cd5d7006934b9eb59e1ea702d5158c93bfacfe
97 lines
2.8 KiB
Go
Executable File
97 lines
2.8 KiB
Go
Executable File
/*
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
https://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package webservice
|
|
|
|
import (
|
|
"log"
|
|
"net/http"
|
|
"time"
|
|
|
|
"github.com/pkg/errors"
|
|
"opendev.org/airship/airshipui/pkg/configs"
|
|
"opendev.org/airship/airshipui/util/utilfile"
|
|
"opendev.org/airship/airshipui/util/utilhttp"
|
|
)
|
|
|
|
// semaphore to signal the UI to authenticate
|
|
var isAuthenticated bool
|
|
|
|
const (
|
|
staticContent = "client/dist/airshipui"
|
|
)
|
|
|
|
// test if path and file exists, if it does send a page, else 404 for you
|
|
func serveFile(w http.ResponseWriter, r *http.Request) {
|
|
filePath, filePathErr := utilfile.FilePath(staticContent, r.URL.Path)
|
|
if filePathErr != nil {
|
|
utilhttp.HandleErr(w, errors.WithStack(filePathErr), http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
fileExists, fileExistsErr := utilfile.Exists(filePath)
|
|
if fileExistsErr != nil {
|
|
utilhttp.HandleErr(w, errors.WithStack(fileExistsErr), http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
if fileExists {
|
|
http.ServeFile(w, r, filePath)
|
|
} else {
|
|
// this is in an else to prevent a: superfluous response.WriteHeader call
|
|
// TODO (aschie): Determine if this should do this on any 404, or if it should 404 a request
|
|
http.ServeFile(w, r, staticContent)
|
|
}
|
|
}
|
|
|
|
// handle an auth complete attempt
|
|
func handleAuth(http.ResponseWriter, *http.Request) {
|
|
// TODO: handle the response body to capture the credentials
|
|
err := ws.WriteJSON(configs.WsMessage{
|
|
Type: configs.UI,
|
|
Component: configs.Authcomplete,
|
|
Timestamp: time.Now().UnixNano() / 1000000,
|
|
})
|
|
|
|
// error sending the websocket request
|
|
if err != nil {
|
|
onError(err)
|
|
} else {
|
|
isAuthenticated = true
|
|
}
|
|
}
|
|
|
|
// WebServer will run the handler functions for WebSockets
|
|
func WebServer() {
|
|
webServerMux := http.NewServeMux()
|
|
|
|
// some things may need a redirect so we'll give them a url to do that with
|
|
webServerMux.HandleFunc("/auth", handleAuth)
|
|
|
|
// hand off the websocket upgrade over http
|
|
webServerMux.HandleFunc("/ws", onOpen)
|
|
|
|
// establish routing to static angular client
|
|
log.Println("Attempting to serve static content from ", staticContent)
|
|
webServerMux.HandleFunc("/", serveFile)
|
|
|
|
// TODO: Figureout if we need to toggle the proxies on and off
|
|
// start proxies for web based use
|
|
startProxies()
|
|
|
|
// TODO: pull ports out into conf files
|
|
log.Println("Attempting to start webservice on localhost:8080")
|
|
log.Fatal(http.ListenAndServe(":8080", webServerMux))
|
|
}
|