-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathMessageTracesRequestBuilder.php
More file actions
134 lines (123 loc) · 7.01 KB
/
MessageTracesRequestBuilder.php
File metadata and controls
134 lines (123 loc) · 7.01 KB
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
<?php
namespace Microsoft\Graph\Beta\Generated\Admin\Exchange\Tracing\MessageTraces;
use Exception;
use Http\Promise\Promise;
use Microsoft\Graph\Beta\Generated\Admin\Exchange\Tracing\MessageTraces\Count\CountRequestBuilder;
use Microsoft\Graph\Beta\Generated\Admin\Exchange\Tracing\MessageTraces\Item\ExchangeMessageTraceItemRequestBuilder;
use Microsoft\Graph\Beta\Generated\Models\ExchangeMessageTrace;
use Microsoft\Graph\Beta\Generated\Models\ExchangeMessageTraceCollectionResponse;
use Microsoft\Graph\Beta\Generated\Models\ODataErrors\ODataError;
use Microsoft\Kiota\Abstractions\BaseRequestBuilder;
use Microsoft\Kiota\Abstractions\HttpMethod;
use Microsoft\Kiota\Abstractions\RequestAdapter;
use Microsoft\Kiota\Abstractions\RequestInformation;
/**
* Provides operations to manage the messageTraces property of the microsoft.graph.messageTracingRoot entity.
*/
class MessageTracesRequestBuilder extends BaseRequestBuilder
{
/**
* Provides operations to count the resources in the collection.
*/
public function count(): CountRequestBuilder {
return new CountRequestBuilder($this->pathParameters, $this->requestAdapter);
}
/**
* Provides operations to manage the messageTraces property of the microsoft.graph.messageTracingRoot entity.
* @param string $exchangeMessageTraceId The unique identifier of exchangeMessageTrace
* @return ExchangeMessageTraceItemRequestBuilder
*/
public function byExchangeMessageTraceId(string $exchangeMessageTraceId): ExchangeMessageTraceItemRequestBuilder {
$urlTplParams = $this->pathParameters;
$urlTplParams['exchangeMessageTrace%2Did'] = $exchangeMessageTraceId;
return new ExchangeMessageTraceItemRequestBuilder($urlTplParams, $this->requestAdapter);
}
/**
* Instantiates a new MessageTracesRequestBuilder and sets the default values.
* @param array<string, mixed>|string $pathParametersOrRawUrl Path parameters for the request or a String representing the raw URL.
* @param RequestAdapter $requestAdapter The request adapter to use to execute the requests.
*/
public function __construct($pathParametersOrRawUrl, RequestAdapter $requestAdapter) {
parent::__construct($requestAdapter, [], '{+baseurl}/admin/exchange/tracing/messageTraces{?%24count,%24expand,%24filter,%24orderby,%24search,%24select,%24skip,%24top}');
if (is_array($pathParametersOrRawUrl)) {
$this->pathParameters = $pathParametersOrRawUrl;
} else {
$this->pathParameters = ['request-raw-url' => $pathParametersOrRawUrl];
}
}
/**
* Get a list of exchangeMessageTrace objects.
* @param MessageTracesRequestBuilderGetRequestConfiguration|null $requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return Promise<ExchangeMessageTraceCollectionResponse|null>
* @throws Exception
* @link https://learn.microsoft.com/graph/api/messagetracingroot-list-messagetraces?view=graph-rest-beta Find more info here
*/
public function get(?MessageTracesRequestBuilderGetRequestConfiguration $requestConfiguration = null): Promise {
$requestInfo = $this->toGetRequestInformation($requestConfiguration);
$errorMappings = [
'XXX' => [ODataError::class, 'createFromDiscriminatorValue'],
];
return $this->requestAdapter->sendAsync($requestInfo, [ExchangeMessageTraceCollectionResponse::class, 'createFromDiscriminatorValue'], $errorMappings);
}
/**
* Create new navigation property to messageTraces for admin
* @param ExchangeMessageTrace $body The request body
* @param MessageTracesRequestBuilderPostRequestConfiguration|null $requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return Promise<ExchangeMessageTrace|null>
* @throws Exception
*/
public function post(ExchangeMessageTrace $body, ?MessageTracesRequestBuilderPostRequestConfiguration $requestConfiguration = null): Promise {
$requestInfo = $this->toPostRequestInformation($body, $requestConfiguration);
$errorMappings = [
'XXX' => [ODataError::class, 'createFromDiscriminatorValue'],
];
return $this->requestAdapter->sendAsync($requestInfo, [ExchangeMessageTrace::class, 'createFromDiscriminatorValue'], $errorMappings);
}
/**
* Get a list of exchangeMessageTrace objects.
* @param MessageTracesRequestBuilderGetRequestConfiguration|null $requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return RequestInformation
*/
public function toGetRequestInformation(?MessageTracesRequestBuilderGetRequestConfiguration $requestConfiguration = null): RequestInformation {
$requestInfo = new RequestInformation();
$requestInfo->urlTemplate = $this->urlTemplate;
$requestInfo->pathParameters = $this->pathParameters;
$requestInfo->httpMethod = HttpMethod::GET;
if ($requestConfiguration !== null) {
$requestInfo->addHeaders($requestConfiguration->headers);
if ($requestConfiguration->queryParameters !== null) {
$requestInfo->setQueryParameters($requestConfiguration->queryParameters);
}
$requestInfo->addRequestOptions(...$requestConfiguration->options);
}
$requestInfo->tryAddHeader('Accept', "application/json");
return $requestInfo;
}
/**
* Create new navigation property to messageTraces for admin
* @param ExchangeMessageTrace $body The request body
* @param MessageTracesRequestBuilderPostRequestConfiguration|null $requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return RequestInformation
*/
public function toPostRequestInformation(ExchangeMessageTrace $body, ?MessageTracesRequestBuilderPostRequestConfiguration $requestConfiguration = null): RequestInformation {
$requestInfo = new RequestInformation();
$requestInfo->urlTemplate = $this->urlTemplate;
$requestInfo->pathParameters = $this->pathParameters;
$requestInfo->httpMethod = HttpMethod::POST;
if ($requestConfiguration !== null) {
$requestInfo->addHeaders($requestConfiguration->headers);
$requestInfo->addRequestOptions(...$requestConfiguration->options);
}
$requestInfo->tryAddHeader('Accept', "application/json");
$requestInfo->setContentFromParsable($this->requestAdapter, "application/json", $body);
return $requestInfo;
}
/**
* Returns a request builder with the provided arbitrary URL. Using this method means any other path or query parameters are ignored.
* @param string $rawUrl The raw URL to use for the request builder.
* @return MessageTracesRequestBuilder
*/
public function withUrl(string $rawUrl): MessageTracesRequestBuilder {
return new MessageTracesRequestBuilder($rawUrl, $this->requestAdapter);
}
}