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 .jsv suffix or ?format=jsv
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/jsv
Content-Type: text/jsv
Content-Length: length
{
Meta:
{
String: String
},
PurchaseOrderVersionId: 0,
PurchaseOrderId: 0,
SupplierUserId: 0
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { PurchaseOrderVersion: { Meta: { String: String }, ViewingDateTime: 0001-01-01, ReviewingDateTime: 0001-01-01, 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 } } }