-
Notifications
You must be signed in to change notification settings - Fork 0
/
CreateFulfillmentScript.cs
140 lines (97 loc) · 3.97 KB
/
CreateFulfillmentScript.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
// 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>
/// createFulfillmentScript
///
/// [Not Supported Yet In Starter] Create fulfillment script.
/// Other detail info:
///
///
/// Fulfillment scripts are used for adding custom fulfillment logic based on ITEM_TYPE : [MEDIA,INGAMEITEM] for now, and the custom scripts only cover grantDays.
/// Example for grantDays:
/// `order && ((order.currency && order.currency.currencyCode) == 'LP' || order.isFree) ? 30 : -1`
/// </summary>
public class CreateFulfillmentScript : AccelByte.Sdk.Core.Operation
{
#region Builder Part
public static CreateFulfillmentScriptBuilder Builder { get => new CreateFulfillmentScriptBuilder(); }
public class CreateFulfillmentScriptBuilder
: OperationBuilder<CreateFulfillmentScriptBuilder>
{
public Model.FulfillmentScriptCreate? Body { get; set; }
internal CreateFulfillmentScriptBuilder() { }
public CreateFulfillmentScriptBuilder SetBody(Model.FulfillmentScriptCreate _body)
{
Body = _body;
return this;
}
public CreateFulfillmentScript Build(
string id
)
{
CreateFulfillmentScript op = new CreateFulfillmentScript(this,
id
);
op.PreferredSecurityMethod = PreferredSecurityMethod;
op.RequestJsonOptions = RequestJsonOptions;
op.ResponseJsonOptions = ResponseJsonOptions;
op.FlightId = FlightId;
return op;
}
}
private CreateFulfillmentScript(CreateFulfillmentScriptBuilder builder,
string id
)
{
PathParams["id"] = id;
BodyParams = builder.Body;
Securities.Add(AccelByte.Sdk.Core.Operation.SECURITY_BEARER);
}
#endregion
public CreateFulfillmentScript(
string id,
Model.FulfillmentScriptCreate body
)
{
PathParams["id"] = id;
BodyParams = body;
Securities.Add(AccelByte.Sdk.Core.Operation.SECURITY_BEARER);
}
public override string Path => "/platform/admin/fulfillment/scripts/{id}";
public override HttpMethod Method => HttpMethod.Post;
public override string[] Consumes => new string[] { "application/json" };
public override string[] Produces => new string[] { };
[Obsolete("2022-04-19 - Use 'Securities' property instead.")]
public override string? Security { get; set; } = "Bearer";
public Model.FulfillmentScriptInfo? ParseResponse(HttpStatusCode code, string contentType, Stream payload)
{
if (code == (HttpStatusCode)204)
{
return null;
}
else if (code == (HttpStatusCode)201)
{
if (ResponseJsonOptions != null)
return JsonSerializer.Deserialize<Model.FulfillmentScriptInfo>(payload, ResponseJsonOptions);
else
return JsonSerializer.Deserialize<Model.FulfillmentScriptInfo>(payload);
}
else if (code == (HttpStatusCode)200)
{
return JsonSerializer.Deserialize<Model.FulfillmentScriptInfo>(payload, ResponseJsonOptions);
}
var payloadString = Helper.ConvertInputStreamToString(payload);
throw new HttpResponseException(code, payloadString);
}
}
}