import { type UpdatableAsset } from '@microsoft/msgraph-beta-sdk/models/windowsUpdates/index.js';
import { type AdditionalDataHolder, type BackedModel, type BaseRequestBuilder, type Parsable, type ParseNode, type RequestConfiguration, type RequestInformation, type RequestsMetadata, type SerializationWriter } from '@microsoft/kiota-abstractions';
/**
 * Creates a new instance of the appropriate class based on discriminator value
 * @param parseNode The parse node to use to read the discriminator value and create the object
 * @returns {UpdateAudiencePostRequestBody}
 */
export declare function createUpdateAudiencePostRequestBodyFromDiscriminatorValue(parseNode: ParseNode | undefined): ((instance?: Parsable) => Record<string, (node: ParseNode) => void>);
/**
 * The deserialization information for the current model
 * @returns {Record<string, (node: ParseNode) => void>}
 */
export declare function deserializeIntoUpdateAudiencePostRequestBody(updateAudiencePostRequestBody?: Partial<UpdateAudiencePostRequestBody> | undefined): Record<string, (node: ParseNode) => void>;
/**
 * Provides operations to call the updateAudience method.
 */
export interface MicrosoftGraphWindowsUpdatesUpdateAudienceRequestBuilder extends BaseRequestBuilder<MicrosoftGraphWindowsUpdatesUpdateAudienceRequestBuilder> {
    /**
     * Update the members and exclusions relationships of a deploymentAudience. Adding an azureADDevice to the members or exclusions collections of a deployment audience automatically creates a Microsoft Entra device object, if it doesn't already exist. If the same updatableAsset gets included in the exclusions and members collections of a deploymentAudience, the deployment doesn't apply to that asset. If all updatableAsset objects are the same type, you can also use the method updateAudienceById to update the deploymentAudience.
     * @param body The request body
     * @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
     * @throws {ODataError} error when the service returns a 4XX or 5XX status code
     * @see {@link https://learn.microsoft.com/graph/api/windowsupdates-deploymentaudience-updateaudience?view=graph-rest-beta|Find more info here}
     */
    post(body: UpdateAudiencePostRequestBody, requestConfiguration?: RequestConfiguration<object> | undefined): Promise<void>;
    /**
     * Update the members and exclusions relationships of a deploymentAudience. Adding an azureADDevice to the members or exclusions collections of a deployment audience automatically creates a Microsoft Entra device object, if it doesn't already exist. If the same updatableAsset gets included in the exclusions and members collections of a deploymentAudience, the deployment doesn't apply to that asset. If all updatableAsset objects are the same type, you can also use the method updateAudienceById to update the deploymentAudience.
     * @param body The request body
     * @param requestConfiguration Configuration for the request such as headers, query parameters, and middleware options.
     * @returns {RequestInformation}
     */
    toPostRequestInformation(body: UpdateAudiencePostRequestBody, requestConfiguration?: RequestConfiguration<object> | undefined): RequestInformation;
}
/**
 * Serializes information the current object
 * @param writer Serialization writer to use to serialize this model
 */
export declare function serializeUpdateAudiencePostRequestBody(writer: SerializationWriter, updateAudiencePostRequestBody?: Partial<UpdateAudiencePostRequestBody> | undefined | null): void;
export interface UpdateAudiencePostRequestBody extends AdditionalDataHolder, BackedModel, Parsable {
    /**
     * The addExclusions property
     */
    addExclusions?: UpdatableAsset[] | null;
    /**
     * Stores additional data not described in the OpenAPI description found when deserializing. Can be used for serialization as well.
     */
    additionalData?: Record<string, unknown>;
    /**
     * The addMembers property
     */
    addMembers?: UpdatableAsset[] | null;
    /**
     * Stores model information.
     */
    backingStoreEnabled?: boolean | null;
    /**
     * The removeExclusions property
     */
    removeExclusions?: UpdatableAsset[] | null;
    /**
     * The removeMembers property
     */
    removeMembers?: UpdatableAsset[] | null;
}
/**
 * Uri template for the request builder.
 */
export declare const MicrosoftGraphWindowsUpdatesUpdateAudienceRequestBuilderUriTemplate = "{+baseurl}/admin/windows/updates/deploymentAudiences/{deploymentAudience%2Did}/microsoft.graph.windowsUpdates.updateAudience";
/**
 * Metadata for all the requests in the request builder.
 */
export declare const MicrosoftGraphWindowsUpdatesUpdateAudienceRequestBuilderRequestsMetadata: RequestsMetadata;
//# sourceMappingURL=index.d.ts.map