forked from loafle/openapi-generator-original
rollback swift template
This commit is contained in:
parent
d8060f47a8
commit
410144ea1c
@ -5,17 +5,17 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
class APIHelper {
|
class APIHelper {
|
||||||
static func rejectNil(source: [String:AnyObject?]) -> [String:AnyObject]? {
|
static func rejectNil(source: [String:AnyObject?]) -> [String:AnyObject]? {
|
||||||
var destination = [String:AnyObject]()
|
var destination = [String:AnyObject]()
|
||||||
for (key, nillableValue) in source {
|
for (key, nillableValue) in source {
|
||||||
if let value: AnyObject = nillableValue {
|
if let value: AnyObject = nillableValue {
|
||||||
destination[key] = value
|
destination[key] = value
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if destination.isEmpty {
|
if destination.isEmpty {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
return destination
|
return destination
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,29 +8,28 @@ import Foundation
|
|||||||
import PromiseKit
|
import PromiseKit
|
||||||
|
|
||||||
class {{projectName}}API {
|
class {{projectName}}API {
|
||||||
static let basePath = "{{^basePathOverride}}{{basePath}}{{/basePathOverride}}{{basePathOverride}}"
|
static let basePath = "{{^basePathOverride}}{{basePath}}{{/basePathOverride}}{{basePathOverride}}"
|
||||||
static var credential: NSURLCredential?
|
static var credential: NSURLCredential?
|
||||||
static var requestBuilderFactory: RequestBuilderFactory = AlamofireRequestBuilderFactory()
|
static var requestBuilderFactory: RequestBuilderFactory = AlamofireRequestBuilderFactory()
|
||||||
}
|
}
|
||||||
|
|
||||||
class APIBase {
|
class APIBase {
|
||||||
func toParameters(encodable: JSONEncodable?) -> [String: AnyObject]? {
|
func toParameters(encodable: JSONEncodable?) -> [String: AnyObject]? {
|
||||||
let encoded: AnyObject? = encodable?.encode()
|
let encoded: AnyObject? = encodable?.encode()
|
||||||
|
|
||||||
if encoded! is [AnyObject] {
|
if encoded! is [AnyObject] {
|
||||||
var dictionary = [String:AnyObject]()
|
var dictionary = [String:AnyObject]()
|
||||||
for (index, item) in enumerate(encoded as! [AnyObject]) {
|
for (index, item) in enumerate(encoded as! [AnyObject]) {
|
||||||
dictionary["\(index)"] = item
|
dictionary["\(index)"] = item
|
||||||
}
|
}
|
||||||
return dictionary
|
return dictionary
|
||||||
} else {
|
} else {
|
||||||
return encoded as? [String:AnyObject]
|
return encoded as? [String:AnyObject]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class RequestBuilder
|
class RequestBuilder<T> {
|
||||||
<T> {
|
|
||||||
var credential: NSURLCredential?
|
var credential: NSURLCredential?
|
||||||
var headers: [String:String] = [:]
|
var headers: [String:String] = [:]
|
||||||
let parameters: [String:AnyObject]?
|
let parameters: [String:AnyObject]?
|
||||||
@ -45,9 +44,7 @@ class RequestBuilder
|
|||||||
self.isBody = isBody
|
self.isBody = isBody
|
||||||
}
|
}
|
||||||
|
|
||||||
func execute() -> Promise
|
func execute() -> Promise<Response<T>> { fatalError("Not implemented") }
|
||||||
<Response
|
|
||||||
<T>> { fatalError("Not implemented") }
|
|
||||||
|
|
||||||
func addHeader(#name: String, value: String) -> Self {
|
func addHeader(#name: String, value: String) -> Self {
|
||||||
if !value.isEmpty {
|
if !value.isEmpty {
|
||||||
@ -60,12 +57,10 @@ class RequestBuilder
|
|||||||
self.credential = {{projectName}}API.credential
|
self.credential = {{projectName}}API.credential
|
||||||
return self
|
return self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protocol RequestBuilderFactory {
|
protocol RequestBuilderFactory {
|
||||||
func getBuilder
|
func getBuilder<T>() -> RequestBuilder<T>.Type
|
||||||
<T>() -> RequestBuilder
|
}
|
||||||
<T>.Type
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,27 +8,20 @@ import Alamofire
|
|||||||
import PromiseKit
|
import PromiseKit
|
||||||
|
|
||||||
class AlamofireRequestBuilderFactory: RequestBuilderFactory {
|
class AlamofireRequestBuilderFactory: RequestBuilderFactory {
|
||||||
func getBuilder
|
func getBuilder<T>() -> RequestBuilder<T>.Type {
|
||||||
<T>() -> RequestBuilder
|
return AlamofireRequestBuilder<T>.self
|
||||||
<T>.Type {
|
|
||||||
return AlamofireRequestBuilder
|
|
||||||
<T>.self
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Store manager to retain its reference
|
// Store manager to retain its reference
|
||||||
private var managerStore: [String: Alamofire.Manager] = [:]
|
private var managerStore: [String: Alamofire.Manager] = [:]
|
||||||
|
|
||||||
class AlamofireRequestBuilder
|
class AlamofireRequestBuilder<T>: RequestBuilder<T> {
|
||||||
<T>: RequestBuilder
|
|
||||||
<T> {
|
|
||||||
required init(method: String, URLString: String, parameters: [String : AnyObject]?, isBody: Bool) {
|
required init(method: String, URLString: String, parameters: [String : AnyObject]?, isBody: Bool) {
|
||||||
super.init(method: method, URLString: URLString, parameters: parameters, isBody: isBody)
|
super.init(method: method, URLString: URLString, parameters: parameters, isBody: isBody)
|
||||||
}
|
}
|
||||||
|
|
||||||
override func execute() -> Promise
|
override func execute() -> Promise<Response<T>> {
|
||||||
<Response
|
|
||||||
<T>> {
|
|
||||||
let managerId = NSUUID().UUIDString
|
let managerId = NSUUID().UUIDString
|
||||||
// Create a new manager for each request to customize its request header
|
// Create a new manager for each request to customize its request header
|
||||||
let configuration = NSURLSessionConfiguration.defaultSessionConfiguration()
|
let configuration = NSURLSessionConfiguration.defaultSessionConfiguration()
|
||||||
@ -37,15 +30,12 @@ func getBuilder
|
|||||||
managerStore[managerId] = manager
|
managerStore[managerId] = manager
|
||||||
|
|
||||||
let encoding = isBody ? Alamofire.ParameterEncoding.JSON : Alamofire.ParameterEncoding.URL
|
let encoding = isBody ? Alamofire.ParameterEncoding.JSON : Alamofire.ParameterEncoding.URL
|
||||||
let request = manager.request(Alamofire.Method(rawValue: method)!, URLString, parameters:
|
let request = manager.request(Alamofire.Method(rawValue: method)!, URLString, parameters: parameters, encoding: encoding)
|
||||||
parameters, encoding: encoding)
|
|
||||||
if let credential = self.credential {
|
if let credential = self.credential {
|
||||||
request.authenticate(usingCredential: credential)
|
request.authenticate(usingCredential: credential)
|
||||||
}
|
}
|
||||||
|
|
||||||
let defer = Promise
|
let defer = Promise<Response<T>>.defer()
|
||||||
<Response
|
|
||||||
<T>>.defer()
|
|
||||||
request.responseJSON(options: .AllowFragments) { (req, res, json, error) in
|
request.responseJSON(options: .AllowFragments) { (req, res, json, error) in
|
||||||
managerStore.removeValueForKey(managerId)
|
managerStore.removeValueForKey(managerId)
|
||||||
|
|
||||||
@ -72,8 +62,7 @@ func getBuilder
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
defer.reject(NSError(domain: "localhost", code: 500, userInfo: ["reason": "unreacheable
|
defer.reject(NSError(domain: "localhost", code: 500, userInfo: ["reason": "unreacheable code"]))
|
||||||
code"]))
|
|
||||||
}
|
}
|
||||||
return defer.promise
|
return defer.promise
|
||||||
}
|
}
|
||||||
@ -85,6 +74,6 @@ func getBuilder
|
|||||||
}
|
}
|
||||||
return httpHeaders
|
return httpHeaders
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,41 +8,40 @@ import Alamofire
|
|||||||
import PromiseKit
|
import PromiseKit
|
||||||
|
|
||||||
extension Bool: JSONEncodable {
|
extension Bool: JSONEncodable {
|
||||||
func encode() -> AnyObject { return self }
|
func encode() -> AnyObject { return self }
|
||||||
}
|
}
|
||||||
|
|
||||||
extension Float: JSONEncodable {
|
extension Float: JSONEncodable {
|
||||||
func encode() -> AnyObject { return self }
|
func encode() -> AnyObject { return self }
|
||||||
}
|
}
|
||||||
|
|
||||||
extension Int: JSONEncodable {
|
extension Int: JSONEncodable {
|
||||||
func encode() -> AnyObject { return self }
|
func encode() -> AnyObject { return self }
|
||||||
}
|
}
|
||||||
|
|
||||||
extension Double: JSONEncodable {
|
extension Double: JSONEncodable {
|
||||||
func encode() -> AnyObject { return self }
|
func encode() -> AnyObject { return self }
|
||||||
}
|
}
|
||||||
|
|
||||||
extension String: JSONEncodable {
|
extension String: JSONEncodable {
|
||||||
func encode() -> AnyObject { return self }
|
func encode() -> AnyObject { return self }
|
||||||
}
|
}
|
||||||
|
|
||||||
private func encodeIfPossible
|
private func encodeIfPossible<T>(object: T) -> AnyObject {
|
||||||
<T>(object: T) -> AnyObject {
|
|
||||||
if object is JSONEncodable {
|
if object is JSONEncodable {
|
||||||
return (object as! JSONEncodable).encode()
|
return (object as! JSONEncodable).encode()
|
||||||
} else {
|
} else {
|
||||||
return object as! AnyObject
|
return object as! AnyObject
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extension Array: JSONEncodable {
|
extension Array: JSONEncodable {
|
||||||
func encode() -> AnyObject {
|
func encode() -> AnyObject {
|
||||||
return self.map(encodeIfPossible)
|
return self.map(encodeIfPossible)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extension Dictionary: JSONEncodable {
|
extension Dictionary: JSONEncodable {
|
||||||
func encode() -> AnyObject {
|
func encode() -> AnyObject {
|
||||||
var dictionary = [NSObject:AnyObject]()
|
var dictionary = [NSObject:AnyObject]()
|
||||||
for (key, value) in self {
|
for (key, value) in self {
|
||||||
@ -50,4 +49,4 @@ private func encodeIfPossible
|
|||||||
}
|
}
|
||||||
return dictionary
|
return dictionary
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,11 +7,10 @@
|
|||||||
import Foundation
|
import Foundation
|
||||||
|
|
||||||
protocol JSONEncodable {
|
protocol JSONEncodable {
|
||||||
func encode() -> AnyObject
|
func encode() -> AnyObject
|
||||||
}
|
}
|
||||||
|
|
||||||
class Response
|
class Response<T> {
|
||||||
<T> {
|
|
||||||
let statusCode: Int
|
let statusCode: Int
|
||||||
let header: [String: String]
|
let header: [String: String]
|
||||||
let body: T
|
let body: T
|
||||||
@ -30,29 +29,23 @@ class Response
|
|||||||
}
|
}
|
||||||
self.init(statusCode: response.statusCode, header: header, body: body)
|
self.init(statusCode: response.statusCode, header: header, body: body)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private var once = dispatch_once_t()
|
private var once = dispatch_once_t()
|
||||||
class Decoders {
|
class Decoders {
|
||||||
static private var decoders = Dictionary
|
static private var decoders = Dictionary<String, ((AnyObject) -> AnyObject)>()
|
||||||
<String
|
|
||||||
, ((AnyObject) -> AnyObject)>()
|
|
||||||
|
|
||||||
static func addDecoder
|
static func addDecoder<T>(#clazz: T.Type, decoder: ((AnyObject) -> T)) {
|
||||||
<T>(#clazz: T.Type, decoder: ((AnyObject) -> T)) {
|
|
||||||
let key = "\(T.self)"
|
let key = "\(T.self)"
|
||||||
decoders[key] = { decoder($0) as! AnyObject }
|
decoders[key] = { decoder($0) as! AnyObject }
|
||||||
}
|
}
|
||||||
|
|
||||||
static func decode
|
static func decode<T>(#clazz: [T].Type, source: AnyObject) -> [T] {
|
||||||
<T>(#clazz: [T].Type, source: AnyObject) -> [T] {
|
|
||||||
let array = source as! [AnyObject]
|
let array = source as! [AnyObject]
|
||||||
return array.map { Decoders.decode(clazz: T.self, source: $0) }
|
return array.map { Decoders.decode(clazz: T.self, source: $0) }
|
||||||
}
|
}
|
||||||
|
|
||||||
static func decode
|
static func decode<T, Key: Hashable>(#clazz: [Key:T].Type, source: AnyObject) -> [Key:T] {
|
||||||
<T
|
|
||||||
, Key: Hashable>(#clazz: [Key:T].Type, source: AnyObject) -> [Key:T] {
|
|
||||||
let sourceDictinoary = source as! [Key: AnyObject]
|
let sourceDictinoary = source as! [Key: AnyObject]
|
||||||
var dictionary = [Key:T]()
|
var dictionary = [Key:T]()
|
||||||
for (key, value) in sourceDictinoary {
|
for (key, value) in sourceDictinoary {
|
||||||
@ -61,8 +54,7 @@ class Response
|
|||||||
return dictionary
|
return dictionary
|
||||||
}
|
}
|
||||||
|
|
||||||
static func decode
|
static func decode<T>(#clazz: T.Type, source: AnyObject) -> T {
|
||||||
<T>(#clazz: T.Type, source: AnyObject) -> T {
|
|
||||||
initialize()
|
initialize()
|
||||||
if source is T {
|
if source is T {
|
||||||
return source as! T
|
return source as! T
|
||||||
@ -76,8 +68,7 @@ class Response
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static func decodeOptional
|
static func decodeOptional<T>(#clazz: T.Type, source: AnyObject?) -> T? {
|
||||||
<T>(#clazz: T.Type, source: AnyObject?) -> T? {
|
|
||||||
if source is NSNull {
|
if source is NSNull {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -86,8 +77,7 @@ class Response
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static func decodeOptional
|
static func decodeOptional<T>(#clazz: [T].Type, source: AnyObject?) -> [T]? {
|
||||||
<T>(#clazz: [T].Type, source: AnyObject?) -> [T]? {
|
|
||||||
if source is NSNull {
|
if source is NSNull {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -96,9 +86,7 @@ class Response
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static func decodeOptional
|
static func decodeOptional<T, Key: Hashable>(#clazz: [Key:T].Type, source: AnyObject?) -> [Key:T]? {
|
||||||
<T
|
|
||||||
, Key: Hashable>(#clazz: [Key:T].Type, source: AnyObject?) -> [Key:T]? {
|
|
||||||
if source is NSNull {
|
if source is NSNull {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -126,13 +114,11 @@ class Response
|
|||||||
Decoders.addDecoder(clazz: {{{classname}}}.self) { (source: AnyObject) -> {{{classname}}} in
|
Decoders.addDecoder(clazz: {{{classname}}}.self) { (source: AnyObject) -> {{{classname}}} in
|
||||||
let sourceDictionary = source as! [NSObject:AnyObject]
|
let sourceDictionary = source as! [NSObject:AnyObject]
|
||||||
var instance = {{classname}}(){{#vars}}{{#isEnum}}
|
var instance = {{classname}}(){{#vars}}{{#isEnum}}
|
||||||
instance.{{name}} = (sourceDictionary["{{name}}"] as? String).map { {{classname}}
|
instance.{{name}} = (sourceDictionary["{{name}}"] as? String).map { {{classname}}.{{datatypeWithEnum}}(rawValue: $0)! }{{#required}}!{{/required}} {{/isEnum}}{{^isEnum}}
|
||||||
.{{datatypeWithEnum}}(rawValue: $0)! }{{#required}}!{{/required}} {{/isEnum}}{{^isEnum}}
|
instance.{{name}} = Decoders.decode{{^required}}Optional{{/required}}(clazz: {{{baseType}}}.self, source: sourceDictionary["{{name}}"]{{#required}}!{{/required}}){{/isEnum}}{{/vars}}
|
||||||
instance.{{name}} = Decoders.decode{{^required}}Optional{{/required}}(clazz: {{{baseType}}}
|
|
||||||
.self, source: sourceDictionary["{{name}}"]{{#required}}!{{/required}}){{/isEnum}}{{/vars}}
|
|
||||||
return instance
|
return instance
|
||||||
}{{/model}}
|
}{{/model}}
|
||||||
{{/models}}
|
{{/models}}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,10 +9,10 @@ import Alamofire
|
|||||||
import PromiseKit
|
import PromiseKit
|
||||||
|
|
||||||
extension {{projectName}}API {
|
extension {{projectName}}API {
|
||||||
{{#description}}
|
{{#description}}
|
||||||
/** {{description}} */{{/description}}
|
/** {{description}} */{{/description}}
|
||||||
class {{classname}}: APIBase {
|
class {{classname}}: APIBase {
|
||||||
{{#operation}}
|
{{#operation}}
|
||||||
/**
|
/**
|
||||||
{{#summary}}
|
{{#summary}}
|
||||||
{{{summary}}}
|
{{{summary}}}
|
||||||
@ -28,35 +28,24 @@ class {{classname}}: APIBase {
|
|||||||
{{/hasParams}}{{#allParams}}
|
{{/hasParams}}{{#allParams}}
|
||||||
:param: {{paramName}} ({{#isFormParam}}form{{/isFormParam}}{{#isQueryParam}}query{{/isQueryParam}}{{#isPathParam}}path{{/isPathParam}}{{#isHeaderParam}}header{{/isHeaderParam}}{{#isBodyParam}}body{{/isBodyParam}}) {{description}}{{/allParams}}
|
:param: {{paramName}} ({{#isFormParam}}form{{/isFormParam}}{{#isQueryParam}}query{{/isQueryParam}}{{#isPathParam}}path{{/isPathParam}}{{#isHeaderParam}}header{{/isHeaderParam}}{{#isBodyParam}}body{{/isBodyParam}}) {{description}}{{/allParams}}
|
||||||
|
|
||||||
:returns: Promise
|
:returns: Promise<Response<{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}Void{{/returnType}}>> {{description}}
|
||||||
<Response
|
|
||||||
<{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}Void{{/returnType}}>> {{description}}
|
|
||||||
*/
|
*/
|
||||||
func {{operationId}}({{#allParams}}{{^secondaryParam}}#{{/secondaryParam}}{{paramName}}
|
func {{operationId}}({{#allParams}}{{^secondaryParam}}#{{/secondaryParam}}{{paramName}}: {{{dataType}}}{{^required}}?{{/required}}{{#hasMore}}, {{/hasMore}}{{/allParams}}) -> RequestBuilder<{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}Void{{/returnType}}> {
|
||||||
: {{{dataType}}}{{^required}}?{{/required}}{{#hasMore}}, {{/hasMore}}{{/allParams}}) -> RequestBuilder
|
{{^pathParams}}let{{/pathParams}}{{#pathParams}}{{^secondaryParam}}var{{/secondaryParam}}{{/pathParams}} path = "{{path}}"{{#pathParams}}
|
||||||
<{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}Void{{/returnType}}> {
|
path = path.stringByReplacingOccurrencesOfString("{{=<% %>=}}{<%paramName%>}<%={{ }}=%>", withString: "\({{paramName}})", options: .LiteralSearch, range: nil){{/pathParams}}
|
||||||
{{^pathParams}}let{{/pathParams}}{{#pathParams}}{{^secondaryParam}}var{{/secondaryParam}}{{/pathParams}} path =
|
|
||||||
"{{path}}"{{#pathParams}}
|
|
||||||
path = path.stringByReplacingOccurrencesOfString("{{=<% %>=}}{<%paramName%>}<%={{ }}=%>", withString:
|
|
||||||
"\({{paramName}})", options: .LiteralSearch, range: nil){{/pathParams}}
|
|
||||||
let url = {{projectName}}API.basePath + path
|
let url = {{projectName}}API.basePath + path
|
||||||
{{#bodyParam}}
|
{{#bodyParam}}
|
||||||
let parameters = {{paramName}}{{^required}}?{{/required}}.encode() as?
|
let parameters = {{paramName}}{{^required}}?{{/required}}.encode() as? [String:AnyObject]{{/bodyParam}}{{^bodyParam}}
|
||||||
[String:AnyObject]{{/bodyParam}}{{^bodyParam}}
|
let nillableParameters: [String:AnyObject?] = {{^queryParams}}[:]{{/queryParams}}{{#queryParams}}{{^secondaryParam}}[{{/secondaryParam}}
|
||||||
let nillableParameters: [String:AnyObject?] = {{^queryParams}}
|
|
||||||
[:]{{/queryParams}}{{#queryParams}}{{^secondaryParam}}[{{/secondaryParam}}
|
|
||||||
"{{paramName}}": {{paramName}}{{#hasMore}},{{/hasMore}}{{^hasMore}}
|
"{{paramName}}": {{paramName}}{{#hasMore}},{{/hasMore}}{{^hasMore}}
|
||||||
]{{/hasMore}}{{/queryParams}}
|
]{{/hasMore}}{{/queryParams}}
|
||||||
let parameters = APIHelper.rejectNil(nillableParameters){{/bodyParam}}
|
let parameters = APIHelper.rejectNil(nillableParameters){{/bodyParam}}
|
||||||
|
|
||||||
let requestBuilder: RequestBuilder
|
let requestBuilder: RequestBuilder<{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}Void{{/returnType}}>.Type = {{projectName}}API.requestBuilderFactory.getBuilder()
|
||||||
<{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}Void{{/returnType}}>.Type = {{projectName}}
|
|
||||||
API.requestBuilderFactory.getBuilder()
|
|
||||||
|
|
||||||
return requestBuilder(method: "{{httpMethod}}", URLString: url, parameters: parameters, isBody: {{^queryParams}}
|
return requestBuilder(method: "{{httpMethod}}", URLString: url, parameters: parameters, isBody: {{^queryParams}}true{{/queryParams}}{{#queryParams}}{{^secondaryParam}}false{{/secondaryParam}}{{/queryParams}})
|
||||||
true{{/queryParams}}{{#queryParams}}{{^secondaryParam}}false{{/secondaryParam}}{{/queryParams}})
|
|
||||||
}
|
|
||||||
{{/operation}}
|
|
||||||
}
|
}
|
||||||
|
{{/operation}}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
{{/operations}}
|
{{/operations}}
|
||||||
|
@ -9,27 +9,27 @@ import Foundation
|
|||||||
|
|
||||||
{{#description}}
|
{{#description}}
|
||||||
|
|
||||||
/** {{description}} */{{/description}}
|
/** {{description}} */{{/description}}
|
||||||
class {{classname}}: JSONEncodable {
|
class {{classname}}: JSONEncodable {
|
||||||
{{#vars}}{{#isEnum}}
|
{{#vars}}{{#isEnum}}
|
||||||
enum {{datatypeWithEnum}}: String { {{#allowableValues}}{{#values}}
|
enum {{datatypeWithEnum}}: String { {{#allowableValues}}{{#values}}
|
||||||
case {{enum}} = "{{raw}}"{{/values}}{{/allowableValues}}
|
case {{enum}} = "{{raw}}"{{/values}}{{/allowableValues}}
|
||||||
}
|
}
|
||||||
{{/isEnum}}{{/vars}}
|
{{/isEnum}}{{/vars}}
|
||||||
{{#vars}}{{#isEnum}}{{#description}}/** {{description}} */
|
{{#vars}}{{#isEnum}}{{#description}}/** {{description}} */
|
||||||
{{/description}}var {{name}}: {{{datatypeWithEnum}}}{{^required}}?{{/required}}{{#required}}!{{/required}}{{#defaultValue}} = {{{defaultValue}}}{{/defaultValue}}{{/isEnum}}{{^isEnum}}{{#description}}/** {{description}} */
|
{{/description}}var {{name}}: {{{datatypeWithEnum}}}{{^required}}?{{/required}}{{#required}}!{{/required}}{{#defaultValue}} = {{{defaultValue}}}{{/defaultValue}}{{/isEnum}}{{^isEnum}}{{#description}}/** {{description}} */
|
||||||
{{/description}}var {{name}}: {{{datatype}}}{{^required}}?{{/required}}{{#required}}!{{/required}}{{#defaultValue}} = {{{defaultValue}}}{{/defaultValue}}{{/isEnum}}
|
{{/description}}var {{name}}: {{{datatype}}}{{^required}}?{{/required}}{{#required}}!{{/required}}{{#defaultValue}} = {{{defaultValue}}}{{/defaultValue}}{{/isEnum}}
|
||||||
{{/vars}}
|
{{/vars}}
|
||||||
|
|
||||||
// MARK: JSONEncodable
|
// MARK: JSONEncodable
|
||||||
func encode() -> AnyObject {
|
func encode() -> AnyObject {
|
||||||
var nillableDictionary = [String:AnyObject?](){{#vars}}{{#isNotContainer}}{{#isPrimitiveType}}{{^isEnum}}
|
var nillableDictionary = [String:AnyObject?](){{#vars}}{{#isNotContainer}}{{#isPrimitiveType}}{{^isEnum}}
|
||||||
nillableDictionary["{{name}}"] = self.{{name}}{{/isEnum}}{{/isPrimitiveType}}{{#isEnum}}
|
nillableDictionary["{{name}}"] = self.{{name}}{{/isEnum}}{{/isPrimitiveType}}{{#isEnum}}
|
||||||
nillableDictionary["{{name}}"] = self.{{name}}{{^required}}?{{/required}}.rawValue{{/isEnum}}{{^isPrimitiveType}}
|
nillableDictionary["{{name}}"] = self.{{name}}{{^required}}?{{/required}}.rawValue{{/isEnum}}{{^isPrimitiveType}}
|
||||||
nillableDictionary["{{name}}"] = self.{{name}}{{^required}}?{{/required}}.encode(){{/isPrimitiveType}}{{/isNotContainer}}{{#isContainer}}
|
nillableDictionary["{{name}}"] = self.{{name}}{{^required}}?{{/required}}.encode(){{/isPrimitiveType}}{{/isNotContainer}}{{#isContainer}}
|
||||||
nillableDictionary["{{name}}"] = self.{{name}}{{^required}}?{{/required}}.encode(){{/isContainer}}{{/vars}}
|
nillableDictionary["{{name}}"] = self.{{name}}{{^required}}?{{/required}}.encode(){{/isContainer}}{{/vars}}
|
||||||
let dictionary: [String:AnyObject] = APIHelper.rejectNil(nillableDictionary) ?? [:]
|
let dictionary: [String:AnyObject] = APIHelper.rejectNil(nillableDictionary) ?? [:]
|
||||||
return dictionary
|
return dictionary
|
||||||
}
|
}
|
||||||
}{{/model}}
|
}{{/model}}
|
||||||
{{/models}}
|
{{/models}}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user