msgraph-sdk-python icon indicating copy to clipboard operation
msgraph-sdk-python copied to clipboard

Add members using patch method does not add users to group

Open marvin-garcia opened this issue 1 year ago • 6 comments

Title Add members using patch method does not add users to group.

Environment Python Version: 3.10.12 msgraph-sdk version: 1.1.0 OS: Ubuntu 22.04

Stack trace (if available) Screenshot or formatted copy and paste of your stack trace. N/A

Describe the bug A clear and concise description of what the bug is.

I have the following methods to add a single and multiple users to a group in my AAD B2C tenant. The post method works, and the user is added to the AAD group. The patch method does not work, it returns None and does not raise any exception. I tried the same payload with my user Ids using the MS Graph explorer and users are added successfully. The service principal has full Group, GroupMember and User permissions in the MS Graph API.

async def add_group_member(group_id: str, user_id: str) -> bool:
    """Adds a single user to a group."""
    try:
        if not user_id:
            return False
        
        request_body = ReferenceCreate(odata_id = f'https://graph.microsoft.com/v1.0/directoryObjects/{user_id}')
        await GRAPH_CLIENT.groups.by_group_id(group_id).members.ref.post(request_body)

        return True
    except Exception as e:
        raise e

async def add_group_members(group_id: str, user_ids: List[str]) -> bool:
    """Adds users to a group."""
    try:
        if not user_ids:
            return False
        elif len(user_ids) > 20:
            raise Exception("You can only add 20 users at a time.")
        elif len(user_ids) == 1:
            return await self.add_group_member(group_id, user_ids[0])

        request_body = Group(
            additional_data = {
                "members@odata_bind" : [f'https://graph.microsoft.com/v1.0/directoryObjects/{user_id}' for user_id in user_ids]
            }
        )
        await GRAPH_CLIENT.groups.by_group_id(group_id).patch(request_body)

        return True
    except Exception as e:
        raise e

To Reproduce Steps to reproduce the behavior: GRAPH_CLIENT = ClientSecretCredentials(...) add_group_members(group_id, user_ids)

Expected behavior A clear and concise description of what you expected to happen. Multiple groups added to the group in a single patch request.

Screenshots If applicable, add screenshots to help explain your problem. N/A

Additional context Add any other context about the problem here. N/A

marvin-garcia avatar Feb 29 '24 22:02 marvin-garcia

I have similar issue. I got None as the response but the group is not added.

e88z4 avatar Mar 20 '24 19:03 e88z4

Hey all, I found out that this code works to add user to group

# Add user to group
body = ReferenceCreate(
    odata_id=f"https://graph.microsoft.com/v1.0/users/{azure_user_id}"
)
response = await self.graph_client.groups.by_group_id(
    group_id
).members.ref.post(body=body)

vicecarloans avatar Apr 02 '24 17:04 vicecarloans

Hey all, I found out that this code works to add user to group

# Add user to group
body = ReferenceCreate(
    odata_id=f"https://graph.microsoft.com/v1.0/users/{azure_user_id}"
)
response = await self.graph_client.groups.by_group_id(
    group_id
).members.ref.post(body=body)

yeah, but keep in mind that this is doing a POST request for each user added, the PATCH is useful to add multiple users at once. it is working on the API using the request directly but through the SDK is failing.

LuchoPeres avatar May 03 '24 20:05 LuchoPeres

I managed to solve the issue by adjusting the body as shown below.

request_body = Group (
    additional_data = {
        "[email protected]": [
            f"https://graph.microsoft.com/v1.0/directoryObjects/{id}",
        ]
    } 
) 

Although it looked like a bug at first, the problem was actually with the properties. The distinction is in using 'odata.bind' as opposed to 'odata_bind'. I do believe that this error should publish a warning though. This inconsistency can also be seen in multiple sections of the official Microsoft Graph API documentation.

LuchoPeres avatar May 07 '24 14:05 LuchoPeres

This is an issue with the snippet generator which needs to be fixed here to avoid snake casing the key values present in the additional_data bag.

andrueastman avatar May 08 '24 07:05 andrueastman

I managed to solve the issue by adjusting the body as shown below.

request_body = Group ( additional_data = { "[email protected]": [ f"https://graph.microsoft.com/v1.0/directoryObjects/{id}", ] } ) Although it looked like a bug at first, the problem was actually with the properties. The distinction is in using 'odata.bind' as opposed to 'odata_bind'. I do believe that this error should publish a warning though. This inconsistency can also be seen in multiple sections of the official Microsoft Graph API documentation.

Really annoying issue, especially because the official documentation is showing a wrong request body. Would really appreciate if at least the docs could be fixed.

mkemmerz avatar Apr 03 '25 12:04 mkemmerz