-
Notifications
You must be signed in to change notification settings - Fork 0
/
DeleteItem.cs
144 lines (99 loc) · 3.84 KB
/
DeleteItem.cs
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
// Copyright (c) 2022 AccelByte Inc. All Rights Reserved.
// This is licensed software from AccelByte Inc, for limitations
// and restrictions contact your company contract manager.
// This code is generated by tool. DO NOT EDIT.
using System.Net;
using System.IO;
using System.Text.Json;
using AccelByte.Sdk.Api.Platform.Model;
using AccelByte.Sdk.Core;
using AccelByte.Sdk.Core.Util;
namespace AccelByte.Sdk.Api.Platform.Operation
{
/// <summary>
/// deleteItem
///
/// This API is used to delete an item permanently.
///
/// force: the default value should be: false. When the value is:
/// * false: only the items in the draft store that have never been published yet can be removed.
/// * true: the item in the draft store(even been published before) can be removed.
/// </summary>
public class DeleteItem : AccelByte.Sdk.Core.Operation
{
#region Builder Part
public static DeleteItemBuilder Builder { get => new DeleteItemBuilder(); }
public class DeleteItemBuilder
: OperationBuilder<DeleteItemBuilder>
{
public bool? Force { get; set; }
public string? StoreId { get; set; }
internal DeleteItemBuilder() { }
public DeleteItemBuilder SetForce(bool _force)
{
Force = _force;
return this;
}
public DeleteItemBuilder SetStoreId(string _storeId)
{
StoreId = _storeId;
return this;
}
public DeleteItem Build(
string itemId,
string namespace_
)
{
DeleteItem op = new DeleteItem(this,
itemId,
namespace_
);
op.PreferredSecurityMethod = PreferredSecurityMethod;
op.RequestJsonOptions = RequestJsonOptions;
op.ResponseJsonOptions = ResponseJsonOptions;
op.FlightId = FlightId;
return op;
}
}
private DeleteItem(DeleteItemBuilder builder,
string itemId,
string namespace_
)
{
PathParams["itemId"] = itemId;
PathParams["namespace"] = namespace_;
if (builder.Force != null) QueryParams["force"] = Convert.ToString(builder.Force)!;
if (builder.StoreId is not null) QueryParams["storeId"] = builder.StoreId;
Securities.Add(AccelByte.Sdk.Core.Operation.SECURITY_BEARER);
}
#endregion
public DeleteItem(
string itemId,
string namespace_,
bool? force,
string? storeId
)
{
PathParams["itemId"] = itemId;
PathParams["namespace"] = namespace_;
if (force != null) QueryParams["force"] = Convert.ToString(force)!;
if (storeId is not null) QueryParams["storeId"] = storeId;
Securities.Add(AccelByte.Sdk.Core.Operation.SECURITY_BEARER);
}
public override string Path => "/platform/admin/namespaces/{namespace}/items/{itemId}";
public override HttpMethod Method => HttpMethod.Delete;
public override string[] Consumes => new string[] { };
public override string[] Produces => new string[] { "application/json" };
[Obsolete("2022-04-19 - Use 'Securities' property instead.")]
public override string? Security { get; set; } = "Bearer";
public void ParseResponse(HttpStatusCode code, string contentType, Stream payload)
{
if (code == (HttpStatusCode)204)
{
return;
}
var payloadString = Helper.ConvertInputStreamToString(payload);
throw new HttpResponseException(code, payloadString);
}
}
}