| GET,POST,PUT,DELETE,OPTIONS | /v1/ProjectMaterial/{ProjectMaterialID} | ||
|---|---|---|---|
| GET,POST,PUT,DELETE,OPTIONS | /v1/ProjectMaterial |
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Project:
project_i_d: int = 0
project_u_i_d: Optional[str] = None
project_name: Optional[str] = None
image_u_r_l: Optional[str] = None
image_key: Optional[str] = None
client_name: Optional[str] = None
client_phone: Optional[str] = None
client_email: Optional[str] = None
project_manager_i_d: int = 0
project_manager_name: Optional[str] = None
start_date: Optional[datetime.datetime] = None
end_date: Optional[datetime.datetime] = None
actual_start_date: Optional[datetime.datetime] = None
actual_end_date: Optional[datetime.datetime] = None
job_count: int = 0
crew_member_count: int = 0
equipment_count: int = 0
material_count: int = 0
project_status_i_d: int = 0
project_status_description: Optional[str] = None
budget: Decimal = decimal.Decimal(0)
cost_to_date: Decimal = decimal.Decimal(0)
project_location: Optional[str] = None
project_type: Optional[str] = None
project_sponsor: Optional[str] = None
created_by: Optional[str] = None
created_at: Optional[datetime.datetime] = None
updated_at: Optional[datetime.datetime] = None
project_description: Optional[str] = None
scope: Optional[str] = None
status_id: int = 0
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Material:
material_i_d: int = 0
material_name: Optional[str] = None
material_type_i_d: int = 0
material_status_i_d: int = 0
quantity: int = 0
supplier: Optional[str] = None
order_date: datetime.datetime = datetime.datetime(1, 1, 1)
delivery_date: datetime.datetime = datetime.datetime(1, 1, 1)
on_site_date: datetime.datetime = datetime.datetime(1, 1, 1)
material_location: Optional[str] = None
manufacturer: Optional[str] = None
serial_number: Optional[str] = None
bar_code: Optional[str] = None
tracking_info: Optional[str] = None
material_description: Optional[str] = None
notes: Optional[str] = None
image_u_r_l: Optional[str] = None
details_u_r_l: Optional[str] = None
created_by_u_i_d: Optional[str] = None
active: bool = False
record_created_date: datetime.datetime = datetime.datetime(1, 1, 1)
status_id: int = 0
material_type_name: Optional[str] = None
cost: float = 0.0
projects: List[Project] = field(default_factory=list)
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ProjectMaterial(Material):
project_material_i_d: int = 0
project_i_d: int = 0
project_end_date: datetime.datetime = datetime.datetime(1, 1, 1)
material_cost: float = 0.0
job_i_d: int = 0
billed_material_cost: float = 0.0
material_qty: int = 0
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ProjectMaterialResponse:
response_status: Optional[ResponseStatus] = None
project_material: List[ProjectMaterial] = field(default_factory=list)
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ProjectMaterialRequest:
project_material_i_d: int = 0
project_material: List[ProjectMaterial] = field(default_factory=list)
Python ProjectMaterialRequest DTOs
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/ProjectMaterial/{ProjectMaterialID} HTTP/1.1
Host: api.dev.dynamics.trendsic.com
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<ProjectMaterialRequest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/CRM.AgencyPlatform.API.Internal">
<ProjectMaterial>
<ProjectMaterial>
<Active>false</Active>
<BarCode>String</BarCode>
<Cost>0</Cost>
<CreatedByUID>00000000-0000-0000-0000-000000000000</CreatedByUID>
<DeliveryDate>0001-01-01T00:00:00</DeliveryDate>
<DetailsURL>String</DetailsURL>
<ImageURL>String</ImageURL>
<Manufacturer>String</Manufacturer>
<MaterialDescription>String</MaterialDescription>
<MaterialID>0</MaterialID>
<MaterialLocation>String</MaterialLocation>
<MaterialName>String</MaterialName>
<MaterialStatusID>0</MaterialStatusID>
<MaterialTypeID>0</MaterialTypeID>
<MaterialTypeName>String</MaterialTypeName>
<Notes>String</Notes>
<OnSiteDate>0001-01-01T00:00:00</OnSiteDate>
<OrderDate>0001-01-01T00:00:00</OrderDate>
<Projects>
<Project>
<ActualEndDate>0001-01-01T00:00:00</ActualEndDate>
<ActualStartDate>0001-01-01T00:00:00</ActualStartDate>
<Budget>0</Budget>
<ClientEmail>String</ClientEmail>
<ClientName>String</ClientName>
<ClientPhone>String</ClientPhone>
<CostToDate>0</CostToDate>
<CreatedAt>0001-01-01T00:00:00</CreatedAt>
<CreatedBy>String</CreatedBy>
<CrewMemberCount>0</CrewMemberCount>
<EndDate>0001-01-01T00:00:00</EndDate>
<EquipmentCount>0</EquipmentCount>
<ImageKey>String</ImageKey>
<ImageURL>String</ImageURL>
<JobCount>0</JobCount>
<MaterialCount>0</MaterialCount>
<ProjectDescription>String</ProjectDescription>
<ProjectID>0</ProjectID>
<ProjectLocation>String</ProjectLocation>
<ProjectManagerID>0</ProjectManagerID>
<ProjectManagerName>String</ProjectManagerName>
<ProjectName>String</ProjectName>
<ProjectSponsor>String</ProjectSponsor>
<ProjectStatusDescription>String</ProjectStatusDescription>
<ProjectStatusID>0</ProjectStatusID>
<ProjectType>String</ProjectType>
<ProjectUID>00000000-0000-0000-0000-000000000000</ProjectUID>
<Scope>String</Scope>
<StartDate>0001-01-01T00:00:00</StartDate>
<StatusId>0</StatusId>
<UpdatedAt>0001-01-01T00:00:00</UpdatedAt>
</Project>
</Projects>
<Quantity>0</Quantity>
<RecordCreatedDate>0001-01-01T00:00:00</RecordCreatedDate>
<SerialNumber>String</SerialNumber>
<StatusId>0</StatusId>
<Supplier>String</Supplier>
<TrackingInfo>String</TrackingInfo>
<BilledMaterialCost>0</BilledMaterialCost>
<JobID>0</JobID>
<MaterialCost>0</MaterialCost>
<MaterialQty>0</MaterialQty>
<ProjectEndDate>0001-01-01T00:00:00</ProjectEndDate>
<ProjectID>0</ProjectID>
<ProjectMaterialID>0</ProjectMaterialID>
</ProjectMaterial>
</ProjectMaterial>
<ProjectMaterialID>0</ProjectMaterialID>
</ProjectMaterialRequest>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length
<ProjectMaterialResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/CRM.AgencyPlatform.API.Internal">
<ProjectMaterial>
<ProjectMaterial>
<Active>false</Active>
<BarCode>String</BarCode>
<Cost>0</Cost>
<CreatedByUID>00000000-0000-0000-0000-000000000000</CreatedByUID>
<DeliveryDate>0001-01-01T00:00:00</DeliveryDate>
<DetailsURL>String</DetailsURL>
<ImageURL>String</ImageURL>
<Manufacturer>String</Manufacturer>
<MaterialDescription>String</MaterialDescription>
<MaterialID>0</MaterialID>
<MaterialLocation>String</MaterialLocation>
<MaterialName>String</MaterialName>
<MaterialStatusID>0</MaterialStatusID>
<MaterialTypeID>0</MaterialTypeID>
<MaterialTypeName>String</MaterialTypeName>
<Notes>String</Notes>
<OnSiteDate>0001-01-01T00:00:00</OnSiteDate>
<OrderDate>0001-01-01T00:00:00</OrderDate>
<Projects>
<Project>
<ActualEndDate>0001-01-01T00:00:00</ActualEndDate>
<ActualStartDate>0001-01-01T00:00:00</ActualStartDate>
<Budget>0</Budget>
<ClientEmail>String</ClientEmail>
<ClientName>String</ClientName>
<ClientPhone>String</ClientPhone>
<CostToDate>0</CostToDate>
<CreatedAt>0001-01-01T00:00:00</CreatedAt>
<CreatedBy>String</CreatedBy>
<CrewMemberCount>0</CrewMemberCount>
<EndDate>0001-01-01T00:00:00</EndDate>
<EquipmentCount>0</EquipmentCount>
<ImageKey>String</ImageKey>
<ImageURL>String</ImageURL>
<JobCount>0</JobCount>
<MaterialCount>0</MaterialCount>
<ProjectDescription>String</ProjectDescription>
<ProjectID>0</ProjectID>
<ProjectLocation>String</ProjectLocation>
<ProjectManagerID>0</ProjectManagerID>
<ProjectManagerName>String</ProjectManagerName>
<ProjectName>String</ProjectName>
<ProjectSponsor>String</ProjectSponsor>
<ProjectStatusDescription>String</ProjectStatusDescription>
<ProjectStatusID>0</ProjectStatusID>
<ProjectType>String</ProjectType>
<ProjectUID>00000000-0000-0000-0000-000000000000</ProjectUID>
<Scope>String</Scope>
<StartDate>0001-01-01T00:00:00</StartDate>
<StatusId>0</StatusId>
<UpdatedAt>0001-01-01T00:00:00</UpdatedAt>
</Project>
</Projects>
<Quantity>0</Quantity>
<RecordCreatedDate>0001-01-01T00:00:00</RecordCreatedDate>
<SerialNumber>String</SerialNumber>
<StatusId>0</StatusId>
<Supplier>String</Supplier>
<TrackingInfo>String</TrackingInfo>
<BilledMaterialCost>0</BilledMaterialCost>
<JobID>0</JobID>
<MaterialCost>0</MaterialCost>
<MaterialQty>0</MaterialQty>
<ProjectEndDate>0001-01-01T00:00:00</ProjectEndDate>
<ProjectID>0</ProjectID>
<ProjectMaterialID>0</ProjectMaterialID>
</ProjectMaterial>
</ProjectMaterial>
<ResponseStatus xmlns:d2p1="http://schemas.servicestack.net/types">
<d2p1:ErrorCode>String</d2p1:ErrorCode>
<d2p1:Message>String</d2p1:Message>
<d2p1:StackTrace>String</d2p1:StackTrace>
<d2p1:Errors>
<d2p1:ResponseError>
<d2p1:ErrorCode>String</d2p1:ErrorCode>
<d2p1:FieldName>String</d2p1:FieldName>
<d2p1:Message>String</d2p1:Message>
<d2p1:Meta xmlns:d5p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d5p1:KeyValueOfstringstring>
<d5p1:Key>String</d5p1:Key>
<d5p1:Value>String</d5p1:Value>
</d5p1:KeyValueOfstringstring>
</d2p1:Meta>
</d2p1:ResponseError>
</d2p1:Errors>
<d2p1:Meta xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:KeyValueOfstringstring>
<d3p1:Key>String</d3p1:Key>
<d3p1:Value>String</d3p1:Value>
</d3p1:KeyValueOfstringstring>
</d2p1:Meta>
</ResponseStatus>
</ProjectMaterialResponse>