import Foundation
import ServiceStack
public class QueryGitHubRepos : QueryData<GithubRepo>
{
public var userName:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case userName
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
userName = try container.decodeIfPresent(String.self, forKey: .userName)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if userName != nil { try container.encode(userName, forKey: .userName) }
}
}
public class GithubRepo : Codable
{
public var id:Int
public var name:String
public var Description:String
public var homepage:String
public var language:String
public var watchers_Count:Int
public var stargazes_Count:Int
public var forks_Count:Int
public var open_Issues_Count:Int
public var size:Int
public var full_Name:String
public var created_at:Date
public var pushed_At:Date?
public var updated_At:Date?
public var has_issues:Bool
public var has_Downloads:Bool
public var has_Wiki:Bool
public var has_Pages:Bool
public var fork:Bool
public var owner:GithubUser
public var svn_Url:String
public var mirror_Url:String
public var url:String
public var ssh_Url:String
public var html_Url:String
public var clone_Url:String
public var git_Url:String
public var `private`:Bool
required public init(){}
}
public class GithubUser : Codable
{
public var id:Int
public var login:String
public var avatar_Url:String
public var url:String
public var followers:Int?
public var following:Int?
public var type:String
public var public_Gists:Int?
public var location:String
public var company:String
public var html_Url:String
public var public_Repos:Int?
public var created_At:Date?
public var blog:String
public var email:String
public var name:String
public var hireable:Bool?
public var gravatar_Id:String
public var bio:String
required public init(){}
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /jsv/reply/QueryGitHubRepos HTTP/1.1
Host: sharpscript.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
userName: String,
skip: 0,
take: 0,
orderBy: String,
orderByDesc: String,
include: String,
fields: String,
meta:
{
String: String
}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
offset: 0,
total: 0,
results:
[
{
id: 0,
name: String,
description: String,
homepage: String,
language: String,
watchers_Count: 0,
stargazes_Count: 0,
forks_Count: 0,
open_Issues_Count: 0,
size: 0,
full_Name: String,
created_at: 0001-01-01,
pushed_At: 0001-01-01,
updated_At: 0001-01-01,
has_issues: False,
has_Downloads: False,
has_Wiki: False,
has_Pages: False,
fork: False,
owner:
{
id: 0,
login: String,
avatar_Url: String,
url: String,
followers: 0,
following: 0,
type: String,
public_Gists: 0,
location: String,
company: String,
html_Url: String,
public_Repos: 0,
created_At: 0001-01-01,
blog: String,
email: String,
name: String,
hireable: False,
gravatar_Id: String,
bio: String
},
svn_Url: String,
mirror_Url: String,
url: String,
ssh_Url: String,
html_Url: String,
clone_Url: String,
git_Url: String,
private: False
}
],
meta:
{
String: String
},
responseStatus:
{
errorCode: String,
message: String,
stackTrace: String,
errors:
[
{
errorCode: String,
fieldName: String,
message: String,
meta:
{
String: String
}
}
],
meta:
{
String: String
}
}
}