msgraph-beta-sdk-java icon indicating copy to clipboard operation
msgraph-beta-sdk-java copied to clipboard

Cannot delete audit log query using

Open hparfait-anetac opened this issue 10 months ago • 1 comments

Describe the bug

Using the com.microsoft.graph.beta.serviceclient.GraphServiceClient as betaGraphClient I can successfully create audit log queries using betaGraphClient.security().auditLog().queries().post(auditLogQuery) but cannot delete the queries using betaGraphClient.security().auditLog().queries().byAuditLogQueryId(queryId).delete() The call fails with

com.microsoft.graph.beta.models.odataerrors.ODataError: {"message":"No HTTP resource was found that matches the request URI 'https://o365adtsearchapi-na002-es.westus.cloudapp.azure.com/security/auditLog/queries('9032b6a1-04bb-440e-973f-637ddc63bac8')'.","messageDetail":"No type was found that matches the controller named 'queries'."}
        at com.microsoft.graph.beta.models.odataerrors.ODataError.createFromDiscriminatorValue(ODataError.java:36)
        at com.microsoft.kiota.serialization.JsonParseNode.getObjectValue(JsonParseNode.java:212)
        at com.microsoft.kiota.http.OkHttpRequestAdapter.lambda$throwIfFailedResponse$0(OkHttpRequestAdapter.java:673)
        at com.microsoft.kiota.ApiExceptionBuilder.<init>(ApiExceptionBuilder.java:26)
        at com.microsoft.kiota.http.OkHttpRequestAdapter.throwIfFailedResponse(OkHttpRequestAdapter.java:672)
        at com.microsoft.kiota.http.OkHttpRequestAdapter.sendPrimitive(OkHttpRequestAdapter.java:342)
        at com.microsoft.graph.beta.security.auditlog.queries.item.AuditLogQueryItemRequestBuilder.delete(AuditLogQueryItemRequestBuilder.java:64)
        at com.microsoft.graph.beta.security.auditlog.queries.item.AuditLogQueryItemRequestBuilder.delete(AuditLogQueryItemRequestBuilder.java:53)

Expected behavior

Able to delete an audit log query

How to reproduce

        // Build a ClientSecretCredential for authentication
        ClientSecretCredential clientSecretCredential = new ClientSecretCredentialBuilder()
                .clientId(clientId)
                .tenantId(tenantId)
                .clientSecret(clientSecret)
                .build();
        com.microsoft.graph.beta.serviceclient.GraphServiceClient betaGraphClient = new com.microsoft.graph.beta.serviceclient.GraphServiceClient(
                clientSecretCredential, scopes);
        com.microsoft.graph.beta.models.security.AuditLogQuery auditLogQuery = new com.microsoft.graph.beta.models.security.AuditLogQuery();
        auditLogQuery.setOdataType("#microsoft.graph.security.auditLogQuery");
        auditLogQuery.setDisplayName("Test query");
        auditLogQuery.setFilterStartDateTime("2025-04-20T00:00:00Z");
        auditLogQuery.setFilterEndDateTime("2025-04-20T01:00:00Z");
        // submit the query
        AuditLogQuery auditLogQuerySubmitted = betaGraphClient.security().auditLog().queries().post(auditLogQuery);
        String queryId = auditLogQuerySubmitted.getId();
        // wait for completion
        // delete the query
        betaGraphClient.security().auditLog().queries().byAuditLogQueryId(queryId).delete();

SDK Version

6.36.0

Latest version known to work for scenario above?

No response

Known Workarounds

none

Debug output

Click to expand log ```
</details>


### Configuration

_No response_

### Other information

_No response_

hparfait-anetac avatar Apr 24 '25 02:04 hparfait-anetac

This looks to be a case of the SDK operation being generated where it should not be present

The documentation does not list a delete operation for this entity https://learn.microsoft.com/en-us/graph/api/resources/security-auditlogquery?view=graph-rest-beta

gavinbarron avatar Oct 20 '25 21:10 gavinbarron