POST | /v1/login | Process GAS Authentication |
---|
import java.math.*
import java.util.*
import java.io.InputStream
import net.servicestack.client.*
open class LoginRequest : IPost
{
/**
* GAS AuthCode
*/
@ApiMember(Description="GAS AuthCode")
open var AuthCode:String? = null
/**
* GAS ErrorCode
*/
@ApiMember(Description="GAS ErrorCode")
open var ErrorCode:String? = null
/**
* Client Id
*/
@ApiMember(Description="Client Id")
open var ClientId:String? = null
/**
* Secret
*/
@ApiMember(Description="Secret")
open var Secret:String? = null
/**
* Callback Url
*/
@ApiMember(Description="Callback Url")
open var CallbackUrl:String? = null
/**
* Redirect Url
*/
@ApiMember(Description="Redirect Url")
open var RedirectUrl:String? = null
}
open class LoginResponse
{
open var RedirectUrl:String? = null
open var IsAuthenticated:Boolean? = null
open var UserToken:String? = null
open var UserId:String? = null
open var UserRoleId:ArrayList<Int>? = null
open var DefaultRetailer:String? = null
open var LoginStatus:LoginStatus? = null
open var UserRoleRedirect:String? = null
open var DefaultVehicleType:String? = null
open var EntitlementGroup:ArrayList<String>? = null
}
enum class LoginStatus
{
Authenticated,
NotAuthenticated,
Error,
}
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 /v1/login HTTP/1.1
Host: prod-api-auth-mb-dhc.rapp-customers.co.uk
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
AuthCode: String,
ErrorCode: String,
ClientId: String,
Secret: String,
CallbackUrl: String,
RedirectUrl: String
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { RedirectUrl: String, IsAuthenticated: False, UserToken: String, UserId: String, UserRoleId: [ 0 ], DefaultRetailer: String, LoginStatus: Authenticated, UserRoleRedirect: String, DefaultVehicleType: String, EntitlementGroup: [ String ] }