Caps-Server/Sources/App/configure.swift

52 lines
1.4 KiB
Swift
Raw Normal View History

import Vapor
import Foundation
2023-01-11 18:29:32 +01:00
import Clairvoyant
2020-09-20 11:36:35 +02:00
public func configure(_ app: Application) throws {
2023-01-11 18:26:53 +01:00
let resourceDirectory = URL(fileURLWithPath: app.directory.resourcesDirectory)
let publicDirectory = app.directory.publicDirectory
2023-01-11 18:29:32 +01:00
2023-01-11 18:26:53 +01:00
let config = Config(loadFrom: resourceDirectory)
let authenticator = Authenticator(writers: config.writers)
let monitor = MetricObserver(
logFolder: config.logURL,
2023-01-30 16:07:04 +01:00
accessManager: authenticator,
logMetricId: "caps.log")
2023-01-11 18:29:32 +01:00
// All new metrics are automatically registered with the standard observer
MetricObserver.standard = monitor
2023-01-11 18:29:32 +01:00
let status = Metric<ServerStatus>("caps.status")
status.update(.initializing)
let server = CapServer(in: URL(fileURLWithPath: publicDirectory))
2023-01-11 18:29:32 +01:00
monitor.registerRoutes(app)
app.http.server.configuration.port = config.port
app.routes.defaultMaxBodySize = .init(stringLiteral: config.maxBodySize)
if config.serveFiles {
let middleware = FileMiddleware(publicDirectory: publicDirectory)
app.middleware.use(middleware)
}
// Register routes to the router
server.registerRoutes(with: app, authenticator: authenticator)
// Initialize the server data
2022-10-07 21:13:21 +02:00
do {
2023-01-11 18:29:32 +01:00
try server.loadData()
status.update(.nominal)
2022-10-07 21:13:21 +02:00
} catch {
status.update(.initializationFailure)
2022-10-07 21:13:21 +02:00
}
}
2023-01-11 18:29:32 +01:00
func log(_ message: String) {
MetricObserver.standard?.log(message)
2023-01-11 18:29:32 +01:00
print(message)
2022-10-07 21:13:21 +02:00
}