POST | /api/schedules | ||
---|---|---|---|
PUT | /api/schedules/{RequestId} |
import Foundation
import ServiceStack
/**
* Creates or Reschedules a SupplierConnect schedule. This will return the id of the schedule request created and the communication id of the notification sent.
*/
// @Api(Description="Creates or Reschedules a SupplierConnect schedule. This will return the id of the schedule request created and the communication id of the notification sent.")
// @DataContract
public class ScheduleRequest : Codable
{
/**
* Id of the schedule request to be recreated
*/
// @DataMember(Name="RequestId")
// @ApiMember(Description="Id of the schedule request to be recreated", IsRequired=true, Name="RequestId")
public var RequestId:String
/**
* Date/Time of the activity
*/
// @DataMember(Name="ScheduleDateTime")
// @ApiMember(Description="Date/Time of the activity", IsRequired=true, Name="ScheduleDateTime")
// @Required()
public var ScheduleDateTime:Date?
// @DataMember(Name="Requester")
public var Requester:ContactInfo
// @DataMember(Name="Supplier")
public var Supplier:ContactInfo
// @DataMember(Name="Project")
public var Project:ProjectInfo
// @DataMember(Name="PurchaseOrder")
public var PurchaseOrder:PurchaseOrderInfo
// @DataMember(Name="Activity")
public var Activity:ActivityReference
// @DataMember(Name="Params")
public var Params:[ScheduleParams]
// @DataMember(Name="Attachments")
public var Attachments:[EmailAttachment]
required public init(){}
}
// @DataContract
public class ContactInfo : Codable
{
// @DataMember(Name="Id")
public var Id:String
// @DataMember(Name="Name")
public var Name:String
// @DataMember(Name="Email")
public var Email:String
// @DataMember(Name="Phone")
public var Phone:String
// @DataMember(Name="ContactReference")
public var ContactReference:ObjectReference
required public init(){}
}
// @DataContract
public class ObjectReference : Codable
{
// @DataMember(Name="RmsTableContextId")
public var RmsTableContextId:String
// @DataMember(Name="AlternateKey")
public var AlternateKey:String
// @DataMember(Name="DataSourceInstanceId")
public var DataSourceInstanceId:String
required public init(){}
}
// @DataContract
public class ProjectInfo : Codable
{
// @DataMember(Name="Id")
public var Id:String
// @DataMember(Name="Name")
public var Name:String
// @DataMember(Name="Reference")
public var Reference:String
// @DataMember(Name="Description")
public var Description:String
// @DataMember(Name="Address")
public var Address:String
// @DataMember(Name="HouseType")
public var HouseType:String
// @DataMember(Name="Elevation")
public var Elevation:String
// @DataMember(Name="CustomerName")
public var CustomerName:String
// @DataMember(Name="Supervisor")
public var Supervisor:ContactInfo
// @DataMember(Name="ProjectReference")
public var ProjectReference:ObjectReference
required public init(){}
}
// @DataContract
public class PurchaseOrderInfo : Codable
{
// @DataMember(Name="Id")
public var Id:String
// @DataMember(Name="Reference")
public var Reference:String
// @DataMember(Name="Description")
public var Description:String
// @DataMember(Name="PurchaseOrderReference")
public var PurchaseOrderReference:ObjectReference
required public init(){}
}
// @DataContract
public class ActivityReference : Codable
{
/**
* Name/details of the activity
*/
// @DataMember(Name="name")
// @ApiMember(Description="Name/details of the activity", IsRequired=true, Name="Name")
public var name:String
// @DataMember(Name="notes")
public var notes:String
required public init(){}
}
// @DataContract
public class ScheduleParams : Codable
{
// @DataMember(Name="Name")
public var Name:String
// @DataMember(Name="Value")
public var Value:String
required public init(){}
}
public class EmailAttachment : Codable
{
public var fileName:String
public var contentType:String
public var path:String
public var url:String
public var length:Int
public var fileStream:Data
public var streamContent:String
public var attachmentType:AttachmentType
public var processedAndUploadedAsBlob:Bool
required public init(){}
}
public enum AttachmentType : String, Codable
{
case Url
case FileStream
}
public class ScheduleResponse : Codable
{
public var referenceId:String
public var communicationId:String
public var success:Bool
public var message:String
public var payload: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 /api/schedules HTTP/1.1
Host: production-eros-gateway-api-supplierconnect.azurewebsites.net
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<ScheduleRequest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Eros.Subtle.Dvaravartman.SupplierConnect.Model.APIModels">
<Activity>
<name>String</name>
<notes>String</notes>
</Activity>
<Attachments xmlns:d2p1="http://schemas.datacontract.org/2004/07/Eros.Saguna.Common.Library">
<d2p1:EmailAttachment>
<d2p1:AttachmentType>Url</d2p1:AttachmentType>
<d2p1:ContentType>String</d2p1:ContentType>
<d2p1:FileName>String</d2p1:FileName>
<d2p1:FileStream xmlns:d4p1="http://schemas.datacontract.org/2004/07/System.IO" i:nil="true" />
<d2p1:Length>0</d2p1:Length>
<d2p1:Path>String</d2p1:Path>
<d2p1:ProcessedAndUploadedAsBlob>false</d2p1:ProcessedAndUploadedAsBlob>
<d2p1:StreamContent>String</d2p1:StreamContent>
<d2p1:Url>String</d2p1:Url>
</d2p1:EmailAttachment>
</Attachments>
<Params>
<ScheduleParams>
<Name>String</Name>
<Value>String</Value>
</ScheduleParams>
</Params>
<Project>
<Address>String</Address>
<CustomerName>String</CustomerName>
<Description>String</Description>
<Elevation>String</Elevation>
<HouseType>String</HouseType>
<Id>00000000-0000-0000-0000-000000000000</Id>
<Name>String</Name>
<ProjectReference>
<AlternateKey>String</AlternateKey>
<DataSourceInstanceId>00000000-0000-0000-0000-000000000000</DataSourceInstanceId>
<RmsTableContextId>00000000-0000-0000-0000-000000000000</RmsTableContextId>
</ProjectReference>
<Reference>String</Reference>
<Supervisor>
<ContactReference>
<AlternateKey>String</AlternateKey>
<DataSourceInstanceId>00000000-0000-0000-0000-000000000000</DataSourceInstanceId>
<RmsTableContextId>00000000-0000-0000-0000-000000000000</RmsTableContextId>
</ContactReference>
<Email>String</Email>
<Id>00000000-0000-0000-0000-000000000000</Id>
<Name>String</Name>
<Phone>String</Phone>
</Supervisor>
</Project>
<PurchaseOrder>
<Description>String</Description>
<Id>00000000-0000-0000-0000-000000000000</Id>
<PurchaseOrderReference>
<AlternateKey>String</AlternateKey>
<DataSourceInstanceId>00000000-0000-0000-0000-000000000000</DataSourceInstanceId>
<RmsTableContextId>00000000-0000-0000-0000-000000000000</RmsTableContextId>
</PurchaseOrderReference>
<Reference>String</Reference>
</PurchaseOrder>
<RequestId>00000000-0000-0000-0000-000000000000</RequestId>
<Requester>
<ContactReference>
<AlternateKey>String</AlternateKey>
<DataSourceInstanceId>00000000-0000-0000-0000-000000000000</DataSourceInstanceId>
<RmsTableContextId>00000000-0000-0000-0000-000000000000</RmsTableContextId>
</ContactReference>
<Email>String</Email>
<Id>00000000-0000-0000-0000-000000000000</Id>
<Name>String</Name>
<Phone>String</Phone>
</Requester>
<ScheduleDateTime>0001-01-01T00:00:00</ScheduleDateTime>
<Supplier>
<ContactReference>
<AlternateKey>String</AlternateKey>
<DataSourceInstanceId>00000000-0000-0000-0000-000000000000</DataSourceInstanceId>
<RmsTableContextId>00000000-0000-0000-0000-000000000000</RmsTableContextId>
</ContactReference>
<Email>String</Email>
<Id>00000000-0000-0000-0000-000000000000</Id>
<Name>String</Name>
<Phone>String</Phone>
</Supplier>
</ScheduleRequest>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <ScheduleResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Eros.Subtle.Dvaravartman.SupplierConnect.Model.APIModels"> <CommunicationId>00000000-0000-0000-0000-000000000000</CommunicationId> <Message>String</Message> <Payload>String</Payload> <ReferenceId>00000000-0000-0000-0000-000000000000</ReferenceId> <Success>false</Success> </ScheduleResponse>