| GET | /v1/links/report |
|---|
import Foundation
import ServiceStack
// @DataContract
public class GetLinkReportRequest : Codable
{
// @DataMember(Name="baseCode")
public var baseCode:String
required public init(){}
}
// @DataContract
public class GetLinkReportResponse : Codable
{
// @DataMember(Name="reports")
public var reports:ClickReport
// @DataMember(Name="responseStatus")
public var responseStatus:ResponseStatus
required public init(){}
}
// @DataContract
public class ClickReport : Codable
{
// @DataMember(Name="code")
public var code:String
// @DataMember(Name="reports")
public var reports:[String:Report]
// @DataMember(Name="totalClicks")
public var totalClicks:UInt64
required public init(){}
}
// @DataContract
public class Report : Report
{
required public init(){ super.init() }
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
}
}
// @DataContract
public class Report : Codable
{
// @DataMember(Name="data")
public var data:[ReportData]
// @DataMember(Name="executionTimeMs")
public var executionTimeMs:Int
// @DataMember(Name="totalItems")
public var totalItems:Int
// @DataMember(Name="errors")
public var errors:[Error]
// @DataMember(Name="request")
public var request:ReportRequest
// @DataMember(Name="totalClicks")
public var totalClicks:Int
required public init(){}
}
// @DataContract
public class ReportData : Codable
{
// @DataMember(Name="id")
public var id:String
// @DataMember(Name="item")
public var item:Item
// @DataMember(Name="totalClicks")
public var totalClicks:UInt64
// @DataMember(Name="clicks")
public var clicks:UInt64
// @DataMember(Name="junkClicks")
public var junkClicks:UInt64
// @DataMember(Name="spiderClicks")
public var spiderClicks:UInt64
// @DataMember(Name="dateUtc")
public var dateUtc:Date
required public init(){}
}
// @DataContract
public class Item : Codable
{
// @DataMember(Name="id")
public var id:String
// @DataMember(Name="displayName")
public var displayName:String
required public init(){}
}
// @DataContract
public class Error : Codable
{
// @DataMember(Name="code")
public var code:String
required public init(){}
}
// @DataContract
public class ReportRequest : Codable
{
// @DataMember(Name="items")
public var items:[String]
// @DataMember(Name="groupBy")
public var groupBy:[GroupBy]
// @DataMember(Name="attribute")
public var attribute:String
// @DataMember(Name="type")
public var type:ReportType
// @DataMember(Name="fromStartUtcInclusive")
public var fromStartUtcInclusive:Date
// @DataMember(Name="fromEndUtcInclusive")
public var fromEndUtcInclusive:Date
// @DataMember(Name="retailers")
public var retailers:[String]
required public init(){}
}
public enum GroupBy : String, Codable
{
case Default
case Retailer
case Date
}
public enum ReportType : String, Codable
{
case ShortUrl
case Group
case User
}
Swift GetLinkReportRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /v1/links/report HTTP/1.1 Host: api.booklinker.com Accept: text/csv
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length
{"reports":{"code":"String","reports":{"String":{"data":[{"id":"String","item":{"id":"String","displayName":"String"},"totalClicks":0,"clicks":0,"junkClicks":0,"spiderClicks":0,"dateUtc":"0001-01-01T00:00:00.0000000"}],"executionTimeMs":0,"totalItems":1,"errors":[{}],"request":{"attribute":"String","type":"ShortUrl","fromStartUtcInclusive":"0001-01-01T00:00:00.0000000","fromEndUtcInclusive":"0001-01-01T00:00:00.0000000"},"totalClicks":0}},"totalClicks":0},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}