This package is used to interact with the microsoft graph API
Project description
Microsoft Python client
Microsoft graph API Python client with support for Server to Server Oauth tokens with App Only access.
Install
This package is available on Pypi
pip install ms-python-client
Requirements
- Python >= 3.10
How to configure the client variables to make API calls
Defining your env variables
Define the following variables in your env
or your .env
file:
- MS_ACCOUNT_ID
- MS_CLIENT_ID
- MS_CLIENT_SECRET
For testing purposes
For testing purposes, you can use the following value:
- MS_ACCESS_TOKEN
This token could be obtained from the Microsoft Graph Explorer by clicking on the Sign in with Microsoft
button and then clicking on the Access Token
tab.
Usage
Initialize the MSApiClient from environment variables
from ms_python_client.ms_api_client import MSApiClient
ms_client = MSApiClient.init_from_env()
Initialize the MSApiClient from .env
from ms_python_client.ms_api_client import MSApiClient
ms_client = MSApiClient.init_from_dotenv()
Initialize the MSApiClient manually
from ms_python_client.ms_api_client import MSApiClient
ms_client = MSApiClient(
account_id="<YOUR ACCOUNT ID>",
client_id="<YOUR CLIENT ID>",
client_secret="<YOUR CLIENT SECRET>")
Use the file system to store the access token instead of environment
There are some cases where you might want to store the access token in the file system in order to share its value with other elements of the application (Ex. different pods on a Kubernetes/Openshift application).
You can define the path where the token will be stored, passing the use_path
variable to the constructor:
from ms_python_client.ms_api_client import MSApiClient
ms_client = MSApiClient(
account_id="<YOUR ACCOUNT ID>",
client_id="<YOUR CLIENT ID>",
client_secret="<YOUR CLIENT SECRET>",
use_path="/path/to/token/folder")
How to make API calls
USER_ID = "12345"
SUBJECT = "Test meeting"
query = {"$count": "true", "$filter": f"contains(subject,'{SUBJECT}')"}
result = cern_ms_client.events.list_events(USER_ID, query)
Optional: How to configure the logging
from ms_python_client.utils.logger import setup_logs
setup_logs(log_level=logging.DEBUG)
Available endpoints
events:
- get all events
- get a single event
- create an event
- update an event
- delete an event
CERN specific usage
Instead of using the MSApiClient
class, you can use the CERNMSApiClient
class, which is a subclass of the MSApiClient
class.
This class will provide you some more utilities but it will only work for CERN users (obviously).
This will be used in the context of synchronizing the events between the CERN Indico system and the calendars of the Zoom Rooms.
How to initialize the CERNMSApiClient
Follow the How to configure the client variables to make API calls section and then:
from ms_python_client.cern_ms_api_client import CERNMSApiClient
cern_ms_client = CERNMSApiClient.init_from_dotenv()
Available endpoints
events:
- get all events
- get a single event using indico id
- create an event
- update an event using indico id
- delete an event using indico id
You will find useful the EventParameters
and PartialEventParameters
classes, which will help you to create the events.
INDICO_EVENT_ID
is the id of the event in the indico system which is mandatory to create an event.USER_ID
is the email of the Zoom Room.
from ms_python_client.cern_ms_api_client import CERNMSApiClient
from ms_python_client.utils.event_generator import (EventParameters, PartialEventParameters)
cern_ms_client = CERNMSApiClient.init_from_dotenv()
USER_ID = os.getenv("USER_ID") # Which is the email of the Zoom Room
INDICO_EVENT_ID = os.getenv("INDICO_EVENT_ID")
event_parameters = EventParameters(
subject="Test meeting",
start_time="2021-10-01T12:00:00",
end_time="2021-10-01T13:00:00",
timezone="Europe/Zurich",
indico_event_id=INDICO_EVENT_ID,
zoom_url="https://cern.zoom.us/******",
)
partial_event_parameters = PartialEventParameters(
indico_event_id=INDICO_EVENT_ID,
end_time="2021-10-01T14:00:00",
) # You can update only the end_time of the event for example
cern_ms_client.events.create_event(USER_ID, event_parameters)
cern_ms_client.events.update_event_by_indico_id(USER_ID, partial_event_parameters)
cern_ms_client.events.delete_event_by_indico_id(USER_ID, INDICO_EVENT_ID)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ms_python_client-0.2.0.tar.gz
.
File metadata
- Download URL: ms_python_client-0.2.0.tar.gz
- Upload date:
- Size: 10.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.11.0 Linux/5.15.0-1041-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cdec034a64c209c06ade5e11b35f2604a27278b24638c3fbff8826b67e53ebba |
|
MD5 | f7b93357892b99fe96531d365d52278a |
|
BLAKE2b-256 | 0cc59476aa6dad8a40c4862ced7faa196052581d03493c488b3afced008071c2 |
File details
Details for the file ms_python_client-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: ms_python_client-0.2.0-py3-none-any.whl
- Upload date:
- Size: 12.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.11.0 Linux/5.15.0-1041-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 59f614bfc22d68d91b14ee39a3bcf04b4ca4631bcd46551050b32d8686853919 |
|
MD5 | 918960c92b6036fb20c012a830ed8dba |
|
BLAKE2b-256 | 037e66faca4a378a29e9ca93ef5190dc0f0e60342af6bae8115636d0425edcd4 |