Swift Vapor为自定义响应添加其他信息

问题描述 投票:3回答:1

我有两个型号,旅行和位置。我会返回一个带有一些旅行领域的自定义响应,以及tripID等于Trip的id的Location数量。有我的代码(不工作)。字段locationCount始终为空。

func getList(_ request: Request)throws -> Future<Response> {

    let deviceIdReq = request.parameters.values[0].value
    let queryTrips = Trip.query(on: request).filter(\.deviceId == deviceIdReq).all()
    var tripsR = [TripCustomContent]()
    var trips = [Trip]()

    return queryTrips.flatMap { (result) -> (Future<Response>) in
        trips = result

        var count = 0
        for t in trips {
            let tripIdString = String(t.id!)
            let v = Location.query(on: request).filter(\.tripID == tripIdString).count().map({ (res) -> Int in
                return res
            })/*.map{ (result) -> (Int) in
             count = result
             return result
             }*/
            let tripCustomContent = TripCustomContent.init(startTimestamp: t.startTimestamp, endTimestamp: t.endTimestamp, deviceId: t.deviceId, locationCount: v)
            tripsR.append(tripCustomContent)
        }
        let jsonEncoder = JSONEncoder()
        let data = try jsonEncoder.encode(tripsR)
        let response = HTTPResponse.init(status: .ok, version: HTTPVersion.init(major: x, minor: y), headers: HTTPHeaders.init(), body: data)
        let finalResponse = Response.init(http: response, using: request)
        return try g.encode(for: request)
    }
}

这是我的自定义内容结构:

struct TripCustomContent: Encodable {
var startTimestamp: String?
var endTimestamp: String?
var deviceId: String
var locationCount: Future<Int>
}

有什么建议?

swift vapor
1个回答
2
投票

您正在尝试使用尚未提供的值。当你返回一个Future时,你没有返回它里面的值。

所以你想要你的TripCustomContent是这样的(用蒸汽Content代替Codable

struct TripCustomContent: Content {
    var startTimestamp: String?
    var endTimestamp: String?
    var deviceId: String
    var locationCount: Int
}

你正确地询问了Trip,但没有查询Location。你可能会尝试这样的事情:

return queryTrips.flatMap { trips -> Future<[TripCustomContent]> in
    let tripIds = trips.map({ String($0.id!) })
    return Location.query(on: request).filter(\.tripID ~~ tripIds).all().map { locations in
        return trips.map { trip in
            let locationCount = locations.filter({ $0.tripId == String(trip.id!) }).count
            return TripCustomContent(... locationCount: locationCount)
        }
    }
}

我在这做什么

  1. 将行程映射到他们的tripIds以获取一系列tripIds
  2. 使用上面数组中的一个triffId的tripOd获取所有位置
  3. 使用TripCustomContent过滤的数据库的位置将每个行程映射到tripId的实例

最后,您不需要自己编码JSON,只需返回符合Content的对象:

func getList(_ request: Request) throws -> Future<[TripCustomContent]>


以上可能是您的战略的解决方案。但也许你看看relations,如果它们可以更有效,更容易和更快捷的方式。

© www.soinside.com 2019 - 2024. All rights reserved.