
Product
Introducing Reachability for PHP
Reachability analysis for PHP is now available in experimental, helping teams identify which vulnerabilities are actually exploitable.
msgraph-py
Advanced tools
This package contains API wrappers to simplify interaction with Microsoft Graph API through Python functions.
This package contains API wrappers to simplify interaction with Microsoft Graph API through Python functions.
Some of the benefits of msgraph-py are:
[!NOTE]
The latest published version of this package can be found at pypi.org/project/msgraph-py
get_user()get_user_risk()revoke_refresh_tokens()list_auth_methods()delete_auth_method()reset_strong_auth()get_signin()get_group()list_group_members()add_group_member()remove_group_member()get_device()delete_device()list_owned_devices()get_laps_password()send_mail()Create an app registration in Entra ID with the necessary Graph application permissions for the functions you intend to use:
Authentication and authorization steps
Install the latest version of the package:
python3 -m pip install msgraph-py
Configure environment variables:
If used within a Django project, msgraph-py will by default first attempt to load the following variables from the project's settings.py:
# project/settings.py
AAD_TENANT_ID = "00000000-0000-0000-0000-000000000000"
AAD_CLIENT_ID = "00000000-0000-0000-0000-000000000000"
AAD_CLIENT_SECRET = "client-secret-value"
Alternatively you will need to set the following key-value pairs in os.environ:
import os
os.environ["AAD_TENANT_ID"] = "00000000-0000-0000-0000-000000000000"
os.environ["AAD_CLIENT_ID"] = "00000000-0000-0000-0000-000000000000"
os.environ["AAD_CLIENT_SECRET"] = "client-secret-value"
[!WARNING]
You should never store sensitive credentials or secrets in production code or commit them to your repository. Always load them at runtime from a secure location or from a local file excluded from the repository.
For improved security, consider migrating to certificate-based authentication instead of a static client secret. The simplest way to do this is using the openssl command to create a self-signed certificate and private key:
hostname=$(hostname -s)
fqdn=$(hostname -f)
openssl req \
-x509 \
-newkey rsa:2048 \
-sha256 \
-days 3650 \
-subj "/CN=${fqdn}" \
-keyout "${hostname}_key.pem" \
-out "${hostname}_cert.pem" \
-noenc \
&> /dev/null
[!NOTE]
Remove the-noencoption if you want to encrypt the private key with a passphrase. Adjust options such as-daysand-subjaccording to your requirements.
Upload the certificate PEM-file to the app registration in Microsoft Entra ID. Make a note of the certificate thumbprint, as we will be needing this in the next step. See Microsofts documentation on adding credentials for more info.
Remove AAD_CLIENT_SECRET from your configuration and set the following environment variables (or settings.py) instead:
os.environ["AAD_PRIVATE_KEY_PATH"] = "path/to/private_key.pem"
# Alternatively pass the key data directly (only PEM-format supported)
os.environ["AAD_PRIVATE_KEY"] = "-----BEGIN PRIVATE KEY-----...-----END PRIVATE KEY-----"
# Required if the private key is password-protected
os.environ["AAD_PRIVATE_KEY_PASSPHRASE"] = "key-passphrase-value"
# Required if the private key does not contain a X.509 certificate
os.environ["AAD_CERT_THUMBPRINT"] = "cert-thumbprint-value"
[!NOTE]
You may omit settingAAD_CERT_THUMBPRINTif the certificate and private key are bundled together, as the required thumbprint will be retrieved from the certificate automatically at runtime.PKCS#12 format (
.pfxor.p12) is also supported in addition to PEM when usingAAD_PRIVATE_KEY_PATH. In order to convert a PEM-formatted private key and certificate to a single PKCS#12-formatted file, you can use the following command:openssl pkcs12 -inkey private-key.pem -in certificate.pem -export -out bundled-key-cert.pfx
from msgraph import get_user
user = get_user("user@example.com")
List of returned properties for user resource type.
from msgraph import get_user
filtered_users = get_user(
filter="startsWith(department, 'sales')",
select=[
"displayName",
"department",
"createdDateTime",
],
orderby="createdDateTime desc",
all=True,
)
List of returned properties for user resource type.
from msgraph import list_owned_devices
user_devices = list_owned_devices(
user_id="user@example.com",
filter="isManaged eq true and trustType eq 'AzureAd'",
select=[
"deviceId",
"displayName",
"isCompliant",
"approximateLastSignInDateTime",
],
orderby="approximateLastSignInDateTime desc",
)
List of returned properties for device resource type.
from msgraph import send_mail
send_mail(
sender_id="noreply@example.com",
recipients=[
"john.doe@example.com",
"jane.doe@example.com",
],
subject="Mail from Graph API",
body="<h1>Content of the mail body</h1>",
is_html=True,
priority="high",
attachments=[
"/path/to/file1.txt",
"/path/to/file2.txt",
],
)
FAQs
This package contains API wrappers to simplify interaction with Microsoft Graph API through Python functions.
We found that msgraph-py demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Reachability analysis for PHP is now available in experimental, helping teams identify which vulnerabilities are actually exploitable.

Product
Export Socket alert data to your own cloud storage in JSON, CSV, or Parquet, with flexible snapshot or incremental delivery.

Research
/Security News
Bitwarden CLI 2026.4.0 was compromised in the Checkmarx supply chain campaign after attackers abused a GitHub Action in Bitwarden’s CI/CD pipeline.