| GET | /{Workspace}/AssetList | ||
|---|---|---|---|
| GET | /{Workspace}/AssetList/Count |
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 Schedule:
workspace: Optional[str] = None
object_id: Optional[str] = None
version_id: Optional[str] = None
based_on: Optional[str] = None
start: Optional[str] = None
end: Optional[str] = None
time_zone: Optional[str] = None
users: Optional[List[str]] = None
teams: Optional[List[str]] = None
data: Optional[Dict[str, Object]] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DomainItem:
workspace: Optional[str] = None
object_id: Optional[str] = None
version_id: Optional[str] = None
last_updated: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Location:
y: float = 0.0
x: float = 0.0
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Geometry:
type: Optional[str] = None
coordinates: Optional[List[Location]] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class MaintenanceRecord:
date_time: Optional[str] = None
notes: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class LocationHistory:
date: Optional[str] = None
location: Optional[Location] = None
barcode: Optional[str] = None
notes: Optional[str] = None
is_scan: bool = False
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ClassedItem:
object_id: Optional[str] = None
class_: Optional[str] = field(metadata=config(field_name='class'), default=None)
version_id: Optional[str] = None
ancestors: Optional[List[str]] = None
type: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EventItem:
object_id: Optional[str] = None
date: Optional[str] = None
location: Optional[Location] = None
barcode: Optional[str] = None
details: Optional[str] = None
type: Optional[str] = None
is_scan: bool = False
user: Optional[str] = None
selected_by: Optional[str] = None
status: Optional[str] = None
status_type: Optional[str] = None
date_created: Optional[str] = None
automatic: bool = False
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Anno:
x: float = 0.0
y: float = 0.0
r: float = 0.0
s: float = 0.0
t: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AddressBasic:
street: Optional[str] = None
unit: Optional[str] = None
city: Optional[str] = None
state: Optional[str] = None
zip: Optional[str] = None
country: Optional[str] = None
location: Optional[Location] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CustomDataField:
binding: Optional[str] = None
label: Optional[str] = None
value: Optional[Object] = None
data_type: Optional[str] = None
is_read_only: bool = False
is_hidden: bool = False
values: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Asset:
"""
Contains the data for an asset within the system.
"""
workspace: Optional[str] = None
time_zone: Optional[str] = None
assigned_workspace: Optional[str] = None
object_id: Optional[str] = None
version_id: Optional[str] = None
based_on: Optional[str] = None
external_id: Optional[str] = None
created: Optional[str] = None
last_updated: Optional[str] = None
name: Optional[str] = None
schedules: Optional[List[Schedule]] = None
documents: Optional[List[DomainItem]] = None
tasks: Optional[List[DomainItem]] = None
task_series: Optional[List[str]] = None
task_series_templates: Optional[List[str]] = None
users: Optional[List[DomainItem]] = None
type: Optional[str] = None
symbol: Optional[str] = None
data: Optional[Dict[str, str]] = None
geometry: Optional[Geometry] = None
maintenance_history: Optional[List[MaintenanceRecord]] = None
parent: Optional[str] = None
ancestors: Optional[List[str]] = None
location_history: Optional[List[LocationHistory]] = None
owner: Optional[ClassedItem] = None
is_parent: bool = False
assets: Optional[List[str]] = None
contacts: Optional[List[str]] = None
geometry_string: Optional[str] = None
source_projection: Optional[str] = None
events: Optional[List[EventItem]] = None
anno: Optional[Anno] = None
teams: Optional[List[str]] = None
address: Optional[AddressBasic] = None
created_by: Optional[str] = None
inventory_items: Optional[List[str]] = None
active_labor_types: Optional[Dict[str, Object]] = None
levels: int = 0
all_assests: int = 0
barcode: Optional[str] = None
custom_data_fields: Optional[List[CustomDataField]] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AssetList:
"""
/{Workspace}/AssetList returns a list of assets in the workspace.IMPORTANT NOTE: The following 'core field' query parameters can be used to 'contains' filter tasks returned: name, types (comma separated list)Custom task field 'contains' filters can also be specified by using the binding/key as the query parameter. i.e. Comments=Quick Brown Fox. Spatial extents can be passed in using: bottomleft=Lat,Lon&topright=Lat,Lon. To filter on tasks inside a boundary, use boundary=Lat,Lon,Lat,Lon etc. To filter for assets based on full text search, use fulltext To filter for assets that can be used as hierarchial nodes use the query parameter syncnodes=true To filter and return all assets below asset X in the hiearchy, use the query parameter nodeid = X To filter and return all root level assets, use the query parameter root = true To filter and return all direct children assets for a given parent, use the query parameter parentid = X To filter and return all assets modified since a date and time, use the query parameter modifiedsince = X where X = YYYY-MM-DDTHH:MM:SSZ To filter and return all assets deleted since a date and time, use the query parameter deletedsince = X where X = YYYY-MM-DDTHH:MM:SSZ. Note only Object ID, Workspace and Version is populated. Multiple sort orders can be specified using a strided list. sorts=value1,value2,value3 where value1 = field name, value2 = ascending/descending, value3 = true/false (true if field is a custom field). Pagination - /{0}/AssetList?recstart=0&reccount=1. To suppress geometry from being returned in an effort to improve performance, use the query parameter suppressgeometry=true /{Workspace}/AssetList/Count returns a count, not the actual object list
"""
workspace: Optional[str] = None
date_generated: Optional[str] = None
assets: Optional[List[Asset]] = None
records_available: int = 0
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /{Workspace}/AssetList HTTP/1.1
Host: dev.fieldsquared.com
Accept: text/csv