| POST | /galaxy/sendmessage | Sends a push message to users, notifying them of a message in the app. |
|---|
export class ApiServiceResponse implements IServiceResponse
{
public Description: string;
public Heading: string;
public WasSuccessful: boolean;
public ModelState: Object;
public constructor(init?: Partial<ApiServiceResponse>) { (Object as any).assign(this, init); }
}
export class PostMessageResponse extends ApiServiceResponse
{
public constructor(init?: Partial<PostMessageResponse>) { super(init); (Object as any).assign(this, init); }
}
// @Flags()
export enum MessageType
{
Info = 1,
Marketing = 2,
Policy = 3,
Announcement = 4,
General = 5,
Claim = 6,
}
export class UserDetails
{
public IdNumber: string;
public GalaxyCompanyId: number;
public constructor(init?: Partial<UserDetails>) { (Object as any).assign(this, init); }
}
export class PostMessage implements ILogRequest, IHasApiKey
{
/**
* The type of message being sent.
*/
// @ApiMember(DataType="MessageType", Description="The type of message being sent.", IsRequired=true)
public Type: MessageType;
/**
* The subject of the message
*/
// @ApiMember(DataType="string", Description="The subject of the message", IsRequired=true)
public Subject: string;
/**
* The content of the message
*/
// @ApiMember(DataType="string", Description="The content of the message", IsRequired=true)
public Content: string;
/**
* The recipients who will be receiving the message
*/
// @ApiMember(Description="The recipients who will be receiving the message", IsRequired=true)
public Recipients: UserDetails[];
/**
* The API Key required for authentication
*/
// @ApiMember(Description="The API Key required for authentication", IsRequired=true)
public ApiKey: string;
/**
* If set, the message will be displayed in the user's inbox in the app. Otherwise will just be a push notification.
*/
// @ApiMember(Description="If set, the message will be displayed in the user's inbox in the app. Otherwise will just be a push notification.", IsRequired=true)
public ShowInInbox: boolean;
public constructor(init?: Partial<PostMessage>) { (Object as any).assign(this, 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 /galaxy/sendmessage HTTP/1.1
Host: galaxymobile.api.dev.86degrees.com
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<PostMessage xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/WebService.ServiceModel">
<ApiKey>String</ApiKey>
<Content>String</Content>
<Recipients xmlns:d2p1="http://schemas.datacontract.org/2004/07/BusinessLogic.Entities">
<d2p1:UserDetails>
<d2p1:GalaxyCompanyId>0</d2p1:GalaxyCompanyId>
<d2p1:IdNumber>String</d2p1:IdNumber>
</d2p1:UserDetails>
</Recipients>
<ShowInInbox>false</ShowInInbox>
<Subject>String</Subject>
<Type>Info</Type>
</PostMessage>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <PostMessageResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/WebService.ServiceModel"> <Description xmlns="http://schemas.datacontract.org/2004/07/CommonService.Api.Models.Base">String</Description> <Heading xmlns="http://schemas.datacontract.org/2004/07/CommonService.Api.Models.Base">String</Heading> <ModelState xmlns="http://schemas.datacontract.org/2004/07/CommonService.Api.Models.Base" /> <WasSuccessful xmlns="http://schemas.datacontract.org/2004/07/CommonService.Api.Models.Base">false</WasSuccessful> </PostMessageResponse>