GET,POST | /authorizeuser/{Service}/{Profile} |
---|
import Foundation
import ServiceStack
public class AuthorizeUser : IAuthorizeUser, Codable
{
// @ApiMember(IsRequired=true)
public var bearerToken:String
// @ApiMember(IsRequired=true, ParameterType="path")
public var profile:String
// @ApiMember(IsRequired=true, ParameterType="path")
public var service:String
// @ApiMember(Name="X-WAAPI-CONTEXT", ParameterType="header")
public var customerContext:String
required public init(){}
}
public class AuthorizeUserResponse : AuthorizeBaseResponse, IAuthorizeUserResponse
{
public var userObjectId:String?
public var userTenant:String
public var userTenantId:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case userObjectId
case userTenant
case userTenantId
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
userObjectId = try container.decodeIfPresent(String.self, forKey: .userObjectId)
userTenant = try container.decodeIfPresent(String.self, forKey: .userTenant)
userTenantId = try container.decodeIfPresent(String.self, forKey: .userTenantId)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if userObjectId != nil { try container.encode(userObjectId, forKey: .userObjectId) }
if userTenant != nil { try container.encode(userTenant, forKey: .userTenant) }
if userTenantId != nil { try container.encode(userTenantId, forKey: .userTenantId) }
}
}
public class AuthorizeBaseResponse : Codable
{
public var isAuthorized:Bool
public var settings:[Setting] = []
public var suggestedStatusCode:Int
public var suggestedResponseMessage:String
public var reason:String
public var customerId:String?
required public init(){}
}
public class Setting : Codable
{
public var name:String
public var stringValue:String
public var booleanValue:Bool
public var dataType:String
required public init(){}
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /authorizeuser/{Service}/{Profile} HTTP/1.1
Host: nkapi-sgepz3-auth-r1.azurewebsites.net
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<AuthorizeUser xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Norkart.Api.Authorization.ServiceModel">
<BearerToken>String</BearerToken>
<CustomerContext>String</CustomerContext>
<Profile>String</Profile>
<Service>String</Service>
</AuthorizeUser>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <AuthorizeUserResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Norkart.Api.Authorization.ServiceModel"> <CustomerId i:nil="true" /> <IsAuthorized>false</IsAuthorized> <Reason>String</Reason> <Settings> <Setting> <BooleanValue>false</BooleanValue> <DataType>String</DataType> <Name>String</Name> <StringValue>String</StringValue> </Setting> </Settings> <SuggestedResponseMessage>String</SuggestedResponseMessage> <SuggestedStatusCode>0</SuggestedStatusCode> <UserObjectId i:nil="true" /> <UserTenant>String</UserTenant> <UserTenantId>String</UserTenantId> </AuthorizeUserResponse>