feat: Seeing if case paths can help with base route lookup.
This commit is contained in:
@@ -29,25 +29,30 @@ extension ApiRoute {
|
||||
}
|
||||
}
|
||||
|
||||
extension BaseRoute.EmployeeRoute {
|
||||
extension ApiRoute.EmployeeRoute {
|
||||
|
||||
func handleApiRequest(request: Request) async throws -> any AsyncResponseEncodable {
|
||||
@Dependency(\.database) var database
|
||||
|
||||
switch self {
|
||||
case let .create(employee):
|
||||
return try await database.employees.create(employee)
|
||||
case let .delete(id: id):
|
||||
try await database.employees.delete(id)
|
||||
return HTTPStatus.ok
|
||||
case .index:
|
||||
return try await database.employees.fetchAll()
|
||||
case let .get(id: id):
|
||||
guard let employee = try await database.employees.get(id) else {
|
||||
throw Abort(.badRequest, reason: "Employee not found")
|
||||
|
||||
case let .base(route):
|
||||
switch route {
|
||||
case let .create(employee):
|
||||
return try await database.employees.create(employee)
|
||||
case .index:
|
||||
return try await database.employees.fetchAll()
|
||||
case let .get(id: id):
|
||||
guard let employee = try await database.employees.get(id) else {
|
||||
throw Abort(.badRequest, reason: "Employee not found")
|
||||
}
|
||||
return employee
|
||||
case let .update(id: id, updates: updates):
|
||||
return try await database.employees.update(id, updates)
|
||||
}
|
||||
return employee
|
||||
case let .update(id: id, updates: updates):
|
||||
return try await database.employees.update(id, updates)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user