Required role: | VeoliaAdmin |
PUT | /user/{supplieruserid}/purchaseorder/{purchaseorderid}/purchaseorderversion/{purchaseorderversionid}/meta |
---|
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 PurchaseOrderBase:
purchase_order_id: int = 0
supplier_user_id: int = 0
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PurchaseOrderVersionBase(PurchaseOrderBase):
purchase_order_version_id: int = 0
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ResponseBase:
response_status: Optional[ResponseStatus] = None
class ReviewStatus(IntEnum):
DRAFT = 0
COMMENTED = 1
ACCEPTED = 2
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PurchaseOrderVersionSimple:
id: int = 0
purchase_order_id: int = 0
supplier_user_id: int = 0
version: int = 0
is_viewed: bool = False
status: Optional[ReviewStatus] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BrowseFileResponseBase:
id: int = 0
file_content_id: int = 0
file_name: Optional[str] = None
size: int = 0
class PurchaseOrderDocumentType(IntEnum):
DRAFT = 0
COMMENT = 1
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PurchaseOrderFileSimple(BrowseFileResponseBase):
purchase_order_version_id: int = 0
document_type: Optional[PurchaseOrderDocumentType] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PurchaseOrderVersionDetails(PurchaseOrderVersionSimple):
meta: Optional[Dict[str, str]] = None
viewing_date_time: Optional[datetime.datetime] = None
reviewing_date_time: Optional[datetime.datetime] = None
purchase_order_files: Optional[List[PurchaseOrderFileSimple]] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BrowsePurchaseOrderVersionResponse(ResponseBase):
purchase_order_version: Optional[PurchaseOrderVersionDetails] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EditPurchaseOrderVersionMeta(PurchaseOrderVersionBase, IPut):
meta: Optional[Dict[str, str]] = None
Python EditPurchaseOrderVersionMeta DTOs
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.
PUT /user/{supplieruserid}/purchaseorder/{purchaseorderid}/purchaseorderversion/{purchaseorderversionid}/meta HTTP/1.1
Host: szallitoiportal-be.veolia.hu
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"Meta":{"String":"String"},"PurchaseOrderVersionId":0,"PurchaseOrderId":0,"SupplierUserId":0}
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"PurchaseOrderVersion":{"Meta":{"String":"String"},"ViewingDateTime":"0001-01-01T00:00:00.0000000","ReviewingDateTime":"0001-01-01T00:00:00.0000000","PurchaseOrderFiles":[{"PurchaseOrderVersionId":0,"DocumentType":0,"Id":0,"FileContentId":0,"FileName":"String","Size":0}],"Id":0,"PurchaseOrderId":0,"SupplierUserId":0,"Version":0,"IsViewed":false,"Status":0},"ResponseStatus":{"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}}}