POST | /v1/login | Process GAS Authentication |
---|
"use strict";
/** @typedef {'Authenticated'|'NotAuthenticated'|'Error'} */
export var LoginStatus;
(function (LoginStatus) {
LoginStatus["Authenticated"] = "Authenticated"
LoginStatus["NotAuthenticated"] = "NotAuthenticated"
LoginStatus["Error"] = "Error"
})(LoginStatus || (LoginStatus = {}));
export class LoginResponse {
/** @param {{RedirectUrl?:string,IsAuthenticated?:boolean,UserToken?:string,UserId?:string,UserRoleId?:number[],DefaultRetailer?:string,LoginStatus?:LoginStatus,UserRoleRedirect?:string,DefaultVehicleType?:string,EntitlementGroup?:string[]}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {string} */
RedirectUrl;
/** @type {boolean} */
IsAuthenticated;
/** @type {string} */
UserToken;
/** @type {string} */
UserId;
/** @type {number[]} */
UserRoleId;
/** @type {string} */
DefaultRetailer;
/** @type {LoginStatus} */
LoginStatus;
/** @type {string} */
UserRoleRedirect;
/** @type {string} */
DefaultVehicleType;
/** @type {string[]} */
EntitlementGroup;
}
export class LoginRequest {
/** @param {{AuthCode?:string,ErrorCode?:string,ClientId?:string,Secret?:string,CallbackUrl?:string,RedirectUrl?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {string}
* @description GAS AuthCode */
AuthCode;
/**
* @type {string}
* @description GAS ErrorCode */
ErrorCode;
/**
* @type {string}
* @description Client Id */
ClientId;
/**
* @type {string}
* @description Secret */
Secret;
/**
* @type {string}
* @description Callback Url */
CallbackUrl;
/**
* @type {string}
* @description Redirect Url */
RedirectUrl;
}
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 /v1/login HTTP/1.1
Host: prod-api-auth-mb-dhc.rapp-customers.co.uk
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<LoginRequest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Mercedes.Auth.API.ServiceModel">
<AuthCode>String</AuthCode>
<CallbackUrl>String</CallbackUrl>
<ClientId>String</ClientId>
<ErrorCode>String</ErrorCode>
<RedirectUrl>String</RedirectUrl>
<Secret>String</Secret>
</LoginRequest>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <LoginResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Mercedes.Auth.API.ServiceModel"> <DefaultRetailer>String</DefaultRetailer> <DefaultVehicleType>String</DefaultVehicleType> <EntitlementGroup xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays"> <d2p1:string>String</d2p1:string> </EntitlementGroup> <IsAuthenticated>false</IsAuthenticated> <LoginStatus>Authenticated</LoginStatus> <RedirectUrl>String</RedirectUrl> <UserId>String</UserId> <UserRoleId xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays"> <d2p1:int>0</d2p1:int> </UserRoleId> <UserRoleRedirect>String</UserRoleRedirect> <UserToken>String</UserToken> </LoginResponse>