1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
/*
* Selling Partner API for Listings Items
*
* The Selling Partner API for Listings Items (Listings Items API) provides programmatic access to selling partner listings on Amazon. Use this API in collaboration with the Selling Partner API for Product Type Definitions, which you use to retrieve the information about Amazon product types needed to use the Listings Items API. For more information, see the [Listing Items API Use Case Guide](doc:listings-items-api-v2020-09-01-use-case-guide).
*
* The version of the OpenAPI document: 2020-09-01
*
* Generated by: https://openapi-generator.tech
*/
/// PatchOperation : Individual JSON Patch operation for an HTTP PATCH request.
#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
pub struct PatchOperation {
/// Type of JSON Patch operation. Supported JSON Patch operations include add, replace, and delete. See <https://tools.ietf.org/html/rfc6902>.
#[serde(default, rename = "op")]
pub op: Op,
/// JSON Pointer path of the element to patch. See <https://tools.ietf.org/html/rfc6902>.
#[serde(default, rename = "path")]
pub path: String,
/// JSON value to add, replace, or delete.
#[serde(default, rename = "value", skip_serializing_if = "Option::is_none")]
pub value: Option<Vec<serde_json::Value>>,
}
impl PatchOperation {
/// Individual JSON Patch operation for an HTTP PATCH request.
pub fn new(op: Op, path: String) -> PatchOperation {
PatchOperation {
op,
path,
value: None,
}
}
}
/// Type of JSON Patch operation. Supported JSON Patch operations include add, replace, and delete. See <https://tools.ietf.org/html/rfc6902>.
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Op {
#[serde(rename = "add")]
Add,
#[serde(rename = "replace")]
Replace,
#[serde(rename = "delete")]
Delete,
}
impl Default for Op {
fn default() -> Op {
Self::Add
}
}