Trendsic Platform Service

<back to all web services

EquipmentRequest

Requires Authentication
The following routes are available for this service:
GET,POST,PUT,DELETE,OPTIONS/v1/Equipment/{EquipmentID}
GET,POST,PUT,DELETE,OPTIONS/v1/Equipment
import Foundation
import ServiceStack

public class EquipmentRequest : Codable
{
    public var equipmentID:Int
    public var equipment:[Equipment] = []

    required public init(){}
}

public class Equipment : Codable
{
    public var equipmentID:Int
    public var equipmentName:String
    public var equipmentTypeID:Int16
    public var manufacturer:String
    public var equipmentType:String
    public var serialNumber:String
    public var barCode:String
    public var equipmentLocation:String
    public var imageURL:String
    public var productDetailsURL:String
    public var recordCreatedDate:Date
    public var createdByUID:String
    public var active:Bool
    public var notes:String
    public var rate:Double
    public var projects:[Project] = []

    required public init(){}
}

public class Project : Codable
{
    public var projectID:Int
    public var projectUID:String
    public var projectName:String
    public var imageURL:String
    public var imageKey:String
    public var clientName:String
    public var clientPhone:String
    public var clientEmail:String
    public var projectManagerID:Int
    public var projectManagerName:String
    public var startDate:Date?
    public var endDate:Date?
    public var actualStartDate:Date?
    public var actualEndDate:Date?
    public var jobCount:Int
    public var crewMemberCount:Int
    public var equipmentCount:Int
    public var materialCount:Int
    public var projectStatusID:Int16
    public var projectStatusDescription:String
    public var budget:Double
    public var costToDate:Double
    public var projectLocation:String
    public var projectType:String
    public var projectSponsor:String
    public var createdBy:String
    public var createdAt:Date?
    public var updatedAt:Date?
    public var projectDescription:String
    public var scope:String
    public var statusId:Int

    required public init(){}
}

public class EquipmentResponse : Codable
{
    public var responseStatus:ResponseStatus
    public var equipment:[Equipment] = []

    required public init(){}
}


Swift EquipmentRequest DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /v1/Equipment/{EquipmentID} HTTP/1.1 
Host: api.dev.dynamics.trendsic.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	EquipmentID: 0,
	Equipment: 
	[
		{
			EquipmentID: 0,
			EquipmentName: String,
			EquipmentTypeID: 0,
			Manufacturer: String,
			EquipmentType: String,
			SerialNumber: String,
			BarCode: String,
			EquipmentLocation: String,
			ImageURL: String,
			ProductDetailsURL: String,
			RecordCreatedDate: 0001-01-01,
			CreatedByUID: 00000000000000000000000000000000,
			Active: False,
			Notes: String,
			Rate: 0,
			Projects: 
			[
				{
					ProjectID: 0,
					ProjectUID: 00000000000000000000000000000000,
					ProjectName: String,
					ImageURL: String,
					ImageKey: String,
					ClientName: String,
					ClientPhone: String,
					ClientEmail: String,
					ProjectManagerID: 0,
					ProjectManagerName: String,
					StartDate: 0001-01-01,
					EndDate: 0001-01-01,
					ActualStartDate: 0001-01-01,
					ActualEndDate: 0001-01-01,
					JobCount: 0,
					CrewMemberCount: 0,
					EquipmentCount: 0,
					MaterialCount: 0,
					ProjectStatusID: 0,
					ProjectStatusDescription: String,
					Budget: 0,
					CostToDate: 0,
					ProjectLocation: String,
					ProjectType: String,
					ProjectSponsor: String,
					CreatedBy: String,
					CreatedAt: 0001-01-01,
					UpdatedAt: 0001-01-01,
					ProjectDescription: String,
					Scope: String,
					StatusId: 0
				}
			]
		}
	]
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	ResponseStatus: 
	{
		ErrorCode: String,
		Message: String,
		StackTrace: String,
		Errors: 
		[
			{
				ErrorCode: String,
				FieldName: String,
				Message: String,
				Meta: 
				{
					String: String
				}
			}
		],
		Meta: 
		{
			String: String
		}
	},
	Equipment: 
	[
		{
			EquipmentID: 0,
			EquipmentName: String,
			EquipmentTypeID: 0,
			Manufacturer: String,
			EquipmentType: String,
			SerialNumber: String,
			BarCode: String,
			EquipmentLocation: String,
			ImageURL: String,
			ProductDetailsURL: String,
			RecordCreatedDate: 0001-01-01,
			CreatedByUID: 00000000000000000000000000000000,
			Active: False,
			Notes: String,
			Rate: 0,
			Projects: 
			[
				{
					ProjectID: 0,
					ProjectUID: 00000000000000000000000000000000,
					ProjectName: String,
					ImageURL: String,
					ImageKey: String,
					ClientName: String,
					ClientPhone: String,
					ClientEmail: String,
					ProjectManagerID: 0,
					ProjectManagerName: String,
					StartDate: 0001-01-01,
					EndDate: 0001-01-01,
					ActualStartDate: 0001-01-01,
					ActualEndDate: 0001-01-01,
					JobCount: 0,
					CrewMemberCount: 0,
					EquipmentCount: 0,
					MaterialCount: 0,
					ProjectStatusID: 0,
					ProjectStatusDescription: String,
					Budget: 0,
					CostToDate: 0,
					ProjectLocation: String,
					ProjectType: String,
					ProjectSponsor: String,
					CreatedBy: String,
					CreatedAt: 0001-01-01,
					UpdatedAt: 0001-01-01,
					ProjectDescription: String,
					Scope: String,
					StatusId: 0
				}
			]
		}
	]
}