com.microsoft.graph.beta.generated.chats.item.ChatItemRequestBuilder Maven / Gradle / Ivy
package com.microsoft.graph.beta.chats.item;
import com.microsoft.graph.beta.chats.item.completemigration.CompleteMigrationRequestBuilder;
import com.microsoft.graph.beta.chats.item.hideforuser.HideForUserRequestBuilder;
import com.microsoft.graph.beta.chats.item.installedapps.InstalledAppsRequestBuilder;
import com.microsoft.graph.beta.chats.item.lastmessagepreview.LastMessagePreviewRequestBuilder;
import com.microsoft.graph.beta.chats.item.markchatreadforuser.MarkChatReadForUserRequestBuilder;
import com.microsoft.graph.beta.chats.item.markchatunreadforuser.MarkChatUnreadForUserRequestBuilder;
import com.microsoft.graph.beta.chats.item.members.MembersRequestBuilder;
import com.microsoft.graph.beta.chats.item.messages.MessagesRequestBuilder;
import com.microsoft.graph.beta.chats.item.operations.OperationsRequestBuilder;
import com.microsoft.graph.beta.chats.item.permissiongrants.PermissionGrantsRequestBuilder;
import com.microsoft.graph.beta.chats.item.pinnedmessages.PinnedMessagesRequestBuilder;
import com.microsoft.graph.beta.chats.item.removeallaccessforuser.RemoveAllAccessForUserRequestBuilder;
import com.microsoft.graph.beta.chats.item.sendactivitynotification.SendActivityNotificationRequestBuilder;
import com.microsoft.graph.beta.chats.item.tabs.TabsRequestBuilder;
import com.microsoft.graph.beta.chats.item.unhideforuser.UnhideForUserRequestBuilder;
import com.microsoft.graph.beta.models.Chat;
import com.microsoft.graph.beta.models.odataerrors.ODataError;
import com.microsoft.kiota.BaseRequestBuilder;
import com.microsoft.kiota.BaseRequestConfiguration;
import com.microsoft.kiota.HttpMethod;
import com.microsoft.kiota.QueryParameters;
import com.microsoft.kiota.RequestAdapter;
import com.microsoft.kiota.RequestInformation;
import com.microsoft.kiota.RequestOption;
import com.microsoft.kiota.serialization.Parsable;
import com.microsoft.kiota.serialization.ParsableFactory;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
/**
* Provides operations to manage the collection of chat entities.
*/
@jakarta.annotation.Generated("com.microsoft.kiota")
public class ChatItemRequestBuilder extends BaseRequestBuilder {
/**
* Provides operations to call the completeMigration method.
* @return a {@link CompleteMigrationRequestBuilder}
*/
@jakarta.annotation.Nonnull
public CompleteMigrationRequestBuilder completeMigration() {
return new CompleteMigrationRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to call the hideForUser method.
* @return a {@link HideForUserRequestBuilder}
*/
@jakarta.annotation.Nonnull
public HideForUserRequestBuilder hideForUser() {
return new HideForUserRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the installedApps property of the microsoft.graph.chat entity.
* @return a {@link InstalledAppsRequestBuilder}
*/
@jakarta.annotation.Nonnull
public InstalledAppsRequestBuilder installedApps() {
return new InstalledAppsRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the lastMessagePreview property of the microsoft.graph.chat entity.
* @return a {@link LastMessagePreviewRequestBuilder}
*/
@jakarta.annotation.Nonnull
public LastMessagePreviewRequestBuilder lastMessagePreview() {
return new LastMessagePreviewRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to call the markChatReadForUser method.
* @return a {@link MarkChatReadForUserRequestBuilder}
*/
@jakarta.annotation.Nonnull
public MarkChatReadForUserRequestBuilder markChatReadForUser() {
return new MarkChatReadForUserRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to call the markChatUnreadForUser method.
* @return a {@link MarkChatUnreadForUserRequestBuilder}
*/
@jakarta.annotation.Nonnull
public MarkChatUnreadForUserRequestBuilder markChatUnreadForUser() {
return new MarkChatUnreadForUserRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the members property of the microsoft.graph.chat entity.
* @return a {@link MembersRequestBuilder}
*/
@jakarta.annotation.Nonnull
public MembersRequestBuilder members() {
return new MembersRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the messages property of the microsoft.graph.chat entity.
* @return a {@link MessagesRequestBuilder}
*/
@jakarta.annotation.Nonnull
public MessagesRequestBuilder messages() {
return new MessagesRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the operations property of the microsoft.graph.chat entity.
* @return a {@link OperationsRequestBuilder}
*/
@jakarta.annotation.Nonnull
public OperationsRequestBuilder operations() {
return new OperationsRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the permissionGrants property of the microsoft.graph.chat entity.
* @return a {@link PermissionGrantsRequestBuilder}
*/
@jakarta.annotation.Nonnull
public PermissionGrantsRequestBuilder permissionGrants() {
return new PermissionGrantsRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the pinnedMessages property of the microsoft.graph.chat entity.
* @return a {@link PinnedMessagesRequestBuilder}
*/
@jakarta.annotation.Nonnull
public PinnedMessagesRequestBuilder pinnedMessages() {
return new PinnedMessagesRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to call the removeAllAccessForUser method.
* @return a {@link RemoveAllAccessForUserRequestBuilder}
*/
@jakarta.annotation.Nonnull
public RemoveAllAccessForUserRequestBuilder removeAllAccessForUser() {
return new RemoveAllAccessForUserRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to call the sendActivityNotification method.
* @return a {@link SendActivityNotificationRequestBuilder}
*/
@jakarta.annotation.Nonnull
public SendActivityNotificationRequestBuilder sendActivityNotification() {
return new SendActivityNotificationRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to manage the tabs property of the microsoft.graph.chat entity.
* @return a {@link TabsRequestBuilder}
*/
@jakarta.annotation.Nonnull
public TabsRequestBuilder tabs() {
return new TabsRequestBuilder(pathParameters, requestAdapter);
}
/**
* Provides operations to call the unhideForUser method.
* @return a {@link UnhideForUserRequestBuilder}
*/
@jakarta.annotation.Nonnull
public UnhideForUserRequestBuilder unhideForUser() {
return new UnhideForUserRequestBuilder(pathParameters, requestAdapter);
}
/**
* Instantiates a new {@link ChatItemRequestBuilder} and sets the default values.
* @param pathParameters Path parameters for the request
* @param requestAdapter The request adapter to use to execute the requests.
*/
public ChatItemRequestBuilder(@jakarta.annotation.Nonnull final HashMap pathParameters, @jakarta.annotation.Nonnull final RequestAdapter requestAdapter) {
super(requestAdapter, "{+baseurl}/chats/{chat%2Did}{?%24expand,%24select}", pathParameters);
}
/**
* Instantiates a new {@link ChatItemRequestBuilder} and sets the default values.
* @param rawUrl The raw URL to use for the request builder.
* @param requestAdapter The request adapter to use to execute the requests.
*/
public ChatItemRequestBuilder(@jakarta.annotation.Nonnull final String rawUrl, @jakarta.annotation.Nonnull final RequestAdapter requestAdapter) {
super(requestAdapter, "{+baseurl}/chats/{chat%2Did}{?%24expand,%24select}", rawUrl);
}
/**
* Soft-delete a chat. When invoked with delegated permissions, this operation only works for tenant admins and Teams service admins.
* @throws ODataError When receiving a 4XX or 5XX status code
* @see Find more info here
*/
public void delete() {
delete(null);
}
/**
* Soft-delete a chat. When invoked with delegated permissions, this operation only works for tenant admins and Teams service admins.
* @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @throws ODataError When receiving a 4XX or 5XX status code
* @see Find more info here
*/
public void delete(@jakarta.annotation.Nullable final java.util.function.Consumer requestConfiguration) {
final RequestInformation requestInfo = toDeleteRequestInformation(requestConfiguration);
final HashMap> errorMapping = new HashMap>();
errorMapping.put("XXX", ODataError::createFromDiscriminatorValue);
this.requestAdapter.sendPrimitive(requestInfo, errorMapping, Void.class);
}
/**
* Retrieve a single chat (without its messages). This method supports federation. To access a chat, at least one chat member must belong to the tenant the request initiated from.
* @return a {@link Chat}
* @throws ODataError When receiving a 4XX or 5XX status code
* @see Find more info here
*/
@jakarta.annotation.Nullable
public Chat get() {
return get(null);
}
/**
* Retrieve a single chat (without its messages). This method supports federation. To access a chat, at least one chat member must belong to the tenant the request initiated from.
* @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return a {@link Chat}
* @throws ODataError When receiving a 4XX or 5XX status code
* @see Find more info here
*/
@jakarta.annotation.Nullable
public Chat get(@jakarta.annotation.Nullable final java.util.function.Consumer requestConfiguration) {
final RequestInformation requestInfo = toGetRequestInformation(requestConfiguration);
final HashMap> errorMapping = new HashMap>();
errorMapping.put("XXX", ODataError::createFromDiscriminatorValue);
return this.requestAdapter.send(requestInfo, errorMapping, Chat::createFromDiscriminatorValue);
}
/**
* Update the properties of a chat object.
* @param body The request body
* @return a {@link Chat}
* @throws ODataError When receiving a 4XX or 5XX status code
* @see Find more info here
*/
@jakarta.annotation.Nullable
public Chat patch(@jakarta.annotation.Nonnull final Chat body) {
return patch(body, null);
}
/**
* Update the properties of a chat object.
* @param body The request body
* @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return a {@link Chat}
* @throws ODataError When receiving a 4XX or 5XX status code
* @see Find more info here
*/
@jakarta.annotation.Nullable
public Chat patch(@jakarta.annotation.Nonnull final Chat body, @jakarta.annotation.Nullable final java.util.function.Consumer requestConfiguration) {
Objects.requireNonNull(body);
final RequestInformation requestInfo = toPatchRequestInformation(body, requestConfiguration);
final HashMap> errorMapping = new HashMap>();
errorMapping.put("XXX", ODataError::createFromDiscriminatorValue);
return this.requestAdapter.send(requestInfo, errorMapping, Chat::createFromDiscriminatorValue);
}
/**
* Soft-delete a chat. When invoked with delegated permissions, this operation only works for tenant admins and Teams service admins.
* @return a {@link RequestInformation}
*/
@jakarta.annotation.Nonnull
public RequestInformation toDeleteRequestInformation() {
return toDeleteRequestInformation(null);
}
/**
* Soft-delete a chat. When invoked with delegated permissions, this operation only works for tenant admins and Teams service admins.
* @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return a {@link RequestInformation}
*/
@jakarta.annotation.Nonnull
public RequestInformation toDeleteRequestInformation(@jakarta.annotation.Nullable final java.util.function.Consumer requestConfiguration) {
final RequestInformation requestInfo = new RequestInformation(HttpMethod.DELETE, urlTemplate, pathParameters);
requestInfo.configure(requestConfiguration, DeleteRequestConfiguration::new);
requestInfo.headers.tryAdd("Accept", "application/json");
return requestInfo;
}
/**
* Retrieve a single chat (without its messages). This method supports federation. To access a chat, at least one chat member must belong to the tenant the request initiated from.
* @return a {@link RequestInformation}
*/
@jakarta.annotation.Nonnull
public RequestInformation toGetRequestInformation() {
return toGetRequestInformation(null);
}
/**
* Retrieve a single chat (without its messages). This method supports federation. To access a chat, at least one chat member must belong to the tenant the request initiated from.
* @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return a {@link RequestInformation}
*/
@jakarta.annotation.Nonnull
public RequestInformation toGetRequestInformation(@jakarta.annotation.Nullable final java.util.function.Consumer requestConfiguration) {
final RequestInformation requestInfo = new RequestInformation(HttpMethod.GET, urlTemplate, pathParameters);
requestInfo.configure(requestConfiguration, GetRequestConfiguration::new, x -> x.queryParameters);
requestInfo.headers.tryAdd("Accept", "application/json");
return requestInfo;
}
/**
* Update the properties of a chat object.
* @param body The request body
* @return a {@link RequestInformation}
*/
@jakarta.annotation.Nonnull
public RequestInformation toPatchRequestInformation(@jakarta.annotation.Nonnull final Chat body) {
return toPatchRequestInformation(body, null);
}
/**
* Update the properties of a chat object.
* @param body The request body
* @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
* @return a {@link RequestInformation}
*/
@jakarta.annotation.Nonnull
public RequestInformation toPatchRequestInformation(@jakarta.annotation.Nonnull final Chat body, @jakarta.annotation.Nullable final java.util.function.Consumer requestConfiguration) {
Objects.requireNonNull(body);
final RequestInformation requestInfo = new RequestInformation(HttpMethod.PATCH, urlTemplate, pathParameters);
requestInfo.configure(requestConfiguration, PatchRequestConfiguration::new);
requestInfo.headers.tryAdd("Accept", "application/json");
requestInfo.setContentFromParsable(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 rawUrl The raw URL to use for the request builder.
* @return a {@link ChatItemRequestBuilder}
*/
@jakarta.annotation.Nonnull
public ChatItemRequestBuilder withUrl(@jakarta.annotation.Nonnull final String rawUrl) {
Objects.requireNonNull(rawUrl);
return new ChatItemRequestBuilder(rawUrl, requestAdapter);
}
/**
* Configuration for the request such as headers, query parameters, and middleware options.
*/
@jakarta.annotation.Generated("com.microsoft.kiota")
public class DeleteRequestConfiguration extends BaseRequestConfiguration {
}
/**
* Retrieve a single chat (without its messages). This method supports federation. To access a chat, at least one chat member must belong to the tenant the request initiated from.
*/
@jakarta.annotation.Generated("com.microsoft.kiota")
public class GetQueryParameters implements QueryParameters {
/**
* Expand related entities
*/
@jakarta.annotation.Nullable
public String[] expand;
/**
* Select properties to be returned
*/
@jakarta.annotation.Nullable
public String[] select;
/**
* Extracts the query parameters into a map for the URI template parsing.
* @return a {@link Map}
*/
@jakarta.annotation.Nonnull
public Map toQueryParameters() {
final Map allQueryParams = new HashMap();
allQueryParams.put("%24expand", expand);
allQueryParams.put("%24select", select);
return allQueryParams;
}
}
/**
* Configuration for the request such as headers, query parameters, and middleware options.
*/
@jakarta.annotation.Generated("com.microsoft.kiota")
public class GetRequestConfiguration extends BaseRequestConfiguration {
/**
* Request query parameters
*/
@jakarta.annotation.Nullable
public GetQueryParameters queryParameters = new GetQueryParameters();
}
/**
* Configuration for the request such as headers, query parameters, and middleware options.
*/
@jakarta.annotation.Generated("com.microsoft.kiota")
public class PatchRequestConfiguration extends BaseRequestConfiguration {
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy