forked from Adyen/adyen-dotnet-api-library
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTerminalsTerminalLevelService.cs
123 lines (111 loc) · 9.57 KB
/
TerminalsTerminalLevelService.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
/*
* Management API
*
*
* The version of the OpenAPI document: 3
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Threading;
using System.Threading.Tasks;
using Adyen.Model;
using Adyen.Model.Management;
namespace Adyen.Service.Management
{
/// <summary>
/// TerminalsTerminalLevelService Interface
/// </summary>
public interface ITerminalsTerminalLevelService
{
/// <summary>
/// Get a list of terminals
/// </summary>
/// <param name="searchQuery"><see cref="string"/> - Returns terminals with an ID that contains the specified string. If present, other query parameters are ignored.</param>
/// <param name="otpQuery"><see cref="string"/> - Returns one or more terminals associated with the one-time passwords specified in the request. If this query parameter is used, other query parameters are ignored.</param>
/// <param name="countries"><see cref="string"/> - Returns terminals located in the countries specified by their [two-letter country code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2).</param>
/// <param name="merchantIds"><see cref="string"/> - Returns terminals that belong to the merchant accounts specified by their unique merchant account ID.</param>
/// <param name="storeIds"><see cref="string"/> - Returns terminals that are assigned to the [stores](https://docs.adyen.com/api-explorer/#/ManagementService/latest/get/stores) specified by their unique store ID.</param>
/// <param name="brandModels"><see cref="string"/> - Returns terminals of the [models](https://docs.adyen.com/api-explorer/#/ManagementService/latest/get/companies/{companyId}/terminalModels) specified in the format *brand.model*.</param>
/// <param name="pageNumber"><see cref="int?"/> - The number of the page to fetch.</param>
/// <param name="pageSize"><see cref="int?"/> - The number of items to have on a page, maximum 100. The default is 20 items on a page.</param>
/// <param name="requestOptions"><see cref="RequestOptions"/> - Additional request options.</param>
/// <returns><see cref="ListTerminalsResponse"/>.</returns>
Model.Management.ListTerminalsResponse ListTerminals(string searchQuery = default, string otpQuery = default, string countries = default, string merchantIds = default, string storeIds = default, string brandModels = default, int? pageNumber = default, int? pageSize = default, RequestOptions requestOptions = default);
/// <summary>
/// Get a list of terminals
/// </summary>
/// <param name="searchQuery"><see cref="string"/> - Returns terminals with an ID that contains the specified string. If present, other query parameters are ignored.</param>
/// <param name="otpQuery"><see cref="string"/> - Returns one or more terminals associated with the one-time passwords specified in the request. If this query parameter is used, other query parameters are ignored.</param>
/// <param name="countries"><see cref="string"/> - Returns terminals located in the countries specified by their [two-letter country code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2).</param>
/// <param name="merchantIds"><see cref="string"/> - Returns terminals that belong to the merchant accounts specified by their unique merchant account ID.</param>
/// <param name="storeIds"><see cref="string"/> - Returns terminals that are assigned to the [stores](https://docs.adyen.com/api-explorer/#/ManagementService/latest/get/stores) specified by their unique store ID.</param>
/// <param name="brandModels"><see cref="string"/> - Returns terminals of the [models](https://docs.adyen.com/api-explorer/#/ManagementService/latest/get/companies/{companyId}/terminalModels) specified in the format *brand.model*.</param>
/// <param name="pageNumber"><see cref="int?"/> - The number of the page to fetch.</param>
/// <param name="pageSize"><see cref="int?"/> - The number of items to have on a page, maximum 100. The default is 20 items on a page.</param>
/// <param name="requestOptions"><see cref="RequestOptions"/> - Additional request options.</param>
/// <param name="cancellationToken"> A CancellationToken enables cooperative cancellation between threads, thread pool work items, or Task objects.</param>
/// <returns>Task of <see cref="ListTerminalsResponse"/>.</returns>
Task<Model.Management.ListTerminalsResponse> ListTerminalsAsync(string searchQuery = default, string otpQuery = default, string countries = default, string merchantIds = default, string storeIds = default, string brandModels = default, int? pageNumber = default, int? pageSize = default, RequestOptions requestOptions = default, CancellationToken cancellationToken = default);
/// <summary>
/// Reassign a terminal
/// </summary>
/// <param name="terminalId"><see cref="string"/> - The unique identifier of the payment terminal.</param>
/// <param name="terminalReassignmentRequest"><see cref="TerminalReassignmentRequest"/> - </param>
/// <param name="requestOptions"><see cref="RequestOptions"/> - Additional request options.</param>
void ReassignTerminal(string terminalId, TerminalReassignmentRequest terminalReassignmentRequest = default, RequestOptions requestOptions = default);
/// <summary>
/// Reassign a terminal
/// </summary>
/// <param name="terminalId"><see cref="string"/> - The unique identifier of the payment terminal.</param>
/// <param name="terminalReassignmentRequest"><see cref="TerminalReassignmentRequest"/> - </param>
/// <param name="requestOptions"><see cref="RequestOptions"/> - Additional request options.</param>
/// <param name="cancellationToken"> A CancellationToken enables cooperative cancellation between threads, thread pool work items, or Task objects.</param>
Task ReassignTerminalAsync(string terminalId, TerminalReassignmentRequest terminalReassignmentRequest = default, RequestOptions requestOptions = default, CancellationToken cancellationToken = default);
}
/// <summary>
/// Represents a collection of functions to interact with the TerminalsTerminalLevelService API endpoints
/// </summary>
public class TerminalsTerminalLevelService : AbstractService, ITerminalsTerminalLevelService
{
private readonly string _baseUrl;
public TerminalsTerminalLevelService(Client client) : base(client)
{
_baseUrl = CreateBaseUrl("https://management-test.adyen.com/v3");
}
public Model.Management.ListTerminalsResponse ListTerminals(string searchQuery = default, string otpQuery = default, string countries = default, string merchantIds = default, string storeIds = default, string brandModels = default, int? pageNumber = default, int? pageSize = default, RequestOptions requestOptions = default)
{
return ListTerminalsAsync(searchQuery, otpQuery, countries, merchantIds, storeIds, brandModels, pageNumber, pageSize, requestOptions).ConfigureAwait(false).GetAwaiter().GetResult();
}
public async Task<Model.Management.ListTerminalsResponse> ListTerminalsAsync(string searchQuery = default, string otpQuery = default, string countries = default, string merchantIds = default, string storeIds = default, string brandModels = default, int? pageNumber = default, int? pageSize = default, RequestOptions requestOptions = default, CancellationToken cancellationToken = default)
{
// Build the query string
var queryParams = new Dictionary<string, string>();
if (searchQuery != null) queryParams.Add("searchQuery", searchQuery);
if (otpQuery != null) queryParams.Add("otpQuery", otpQuery);
if (countries != null) queryParams.Add("countries", countries);
if (merchantIds != null) queryParams.Add("merchantIds", merchantIds);
if (storeIds != null) queryParams.Add("storeIds", storeIds);
if (brandModels != null) queryParams.Add("brandModels", brandModels);
if (pageNumber != null) queryParams.Add("pageNumber", pageNumber.ToString());
if (pageSize != null) queryParams.Add("pageSize", pageSize.ToString());
var endpoint = _baseUrl + "/terminals" + ToQueryString(queryParams);
var resource = new ServiceResource(this, endpoint);
return await resource.RequestAsync<Model.Management.ListTerminalsResponse>(null, requestOptions, new HttpMethod("GET"), cancellationToken).ConfigureAwait(false);
}
public void ReassignTerminal(string terminalId, TerminalReassignmentRequest terminalReassignmentRequest = default, RequestOptions requestOptions = default)
{
ReassignTerminalAsync(terminalId, terminalReassignmentRequest, requestOptions).ConfigureAwait(false).GetAwaiter().GetResult();
}
public async Task ReassignTerminalAsync(string terminalId, TerminalReassignmentRequest terminalReassignmentRequest = default, RequestOptions requestOptions = default, CancellationToken cancellationToken = default)
{
var endpoint = _baseUrl + $"/terminals/{terminalId}/reassign";
var resource = new ServiceResource(this, endpoint);
await resource.RequestAsync(terminalReassignmentRequest.ToJson(), requestOptions, new HttpMethod("POST"), cancellationToken).ConfigureAwait(false);
}
}
}