2020-05-17 20:01:30 +02:00
|
|
|
import Vapor
|
2022-05-22 23:24:04 +02:00
|
|
|
import Foundation
|
2023-01-11 18:29:32 +01:00
|
|
|
import Clairvoyant
|
2020-05-17 20:01:30 +02:00
|
|
|
|
2023-02-16 23:08:58 +01:00
|
|
|
public func configure(_ app: Application) async throws {
|
2022-05-22 23:24:04 +02:00
|
|
|
|
2023-01-11 18:26:53 +01:00
|
|
|
let resourceDirectory = URL(fileURLWithPath: app.directory.resourcesDirectory)
|
2022-05-22 23:24:04 +02:00
|
|
|
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)
|
2023-01-17 22:02:27 +01:00
|
|
|
let authenticator = Authenticator(writers: config.writers)
|
|
|
|
|
2023-02-16 23:08:58 +01:00
|
|
|
let monitor = await MetricObserver(
|
2023-01-17 22:02:27 +01:00
|
|
|
logFolder: config.logURL,
|
2023-01-30 16:07:04 +01:00
|
|
|
accessManager: authenticator,
|
2023-01-17 22:02:27 +01:00
|
|
|
logMetricId: "caps.log")
|
2023-01-11 18:29:32 +01:00
|
|
|
|
2023-01-17 22:02:27 +01:00
|
|
|
// All new metrics are automatically registered with the standard observer
|
|
|
|
MetricObserver.standard = monitor
|
2023-01-11 18:29:32 +01:00
|
|
|
|
2023-02-16 23:08:58 +01:00
|
|
|
let status = try await Metric<ServerStatus>("caps.status",
|
2023-02-06 10:03:08 +01:00
|
|
|
name: "Status",
|
|
|
|
description: "The general status of the service")
|
2023-02-16 23:08:58 +01:00
|
|
|
try await status.update(.initializing)
|
2023-01-11 18:29:32 +01:00
|
|
|
|
|
|
|
app.http.server.configuration.port = config.port
|
|
|
|
app.routes.defaultMaxBodySize = .init(stringLiteral: config.maxBodySize)
|
|
|
|
|
2023-02-16 23:08:58 +01:00
|
|
|
let server = await CapServer(in: URL(fileURLWithPath: publicDirectory))
|
|
|
|
|
|
|
|
await monitor.registerRoutes(app)
|
|
|
|
|
2022-05-22 23:24:04 +02:00
|
|
|
if config.serveFiles {
|
|
|
|
let middleware = FileMiddleware(publicDirectory: publicDirectory)
|
|
|
|
app.middleware.use(middleware)
|
|
|
|
}
|
|
|
|
|
2023-01-17 22:02:27 +01:00
|
|
|
// 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()
|
2022-10-07 21:13:21 +02:00
|
|
|
} catch {
|
2023-02-16 23:08:58 +01:00
|
|
|
try await status.update(.initializationFailure)
|
2022-10-07 21:13:21 +02:00
|
|
|
}
|
2023-02-16 23:08:58 +01:00
|
|
|
try await status.update(.nominal)
|
2022-10-07 21:13:21 +02:00
|
|
|
}
|
|
|
|
|
2023-01-11 18:29:32 +01:00
|
|
|
func log(_ message: String) {
|
2023-02-16 23:08:58 +01:00
|
|
|
guard let observer = MetricObserver.standard else {
|
|
|
|
print(message)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
Task {
|
|
|
|
await observer.log(message)
|
|
|
|
}
|
2022-10-07 21:13:21 +02:00
|
|
|
}
|