Skip to main content

Perform simple tasks on OneDrive through the Graph API.

Project description

Graph-OneDrive

Interact with Microsoft's OneDrive service using the Graph API.

The Graph-OneDrive package facilitates the creation of OneDrive class instances which are objects that you can use to interact with OneDrive sessions. Thus multiple OneDrives can be connected to in parallel.

Functions include:

  • listing directories;
  • moving, copying, and renaming files and folders;
  • uploading and downloading files;
  • getting drive metadata including usage.

Azure app requirement

For the package to connect to the Graph API, you need to have an app registered in the Microsoft Azure Portal. The documentation provides basic guidance on how to register an app.

Note that some Microsoft work and school accounts will not allow apps to connect with them without admin consent.

Installation

The package currently requires Python 3.7 or greater.

Install and update using pip which will use the releases hosted on PyPI. Further options in the docs.

pip install graph-onedrive

Documentation

Documentation and examples are provided on GitHub: https://github.com/dariobauer/graph-onedrive/blob/main/docs/

A simple example

Run this command in the terminal after installation which will create a config file in the current folder.

$ graph-onedrive config

Save the following in a .py file in the same folder.

import os
import graph_onedrive

# Set config path
config_key = "onedrive"
config_file_name = "config.json"
current_file_path = os.path.dirname(os.path.abspath(__file__))
config_path = os.path.join(current_file_path, config_file_name)

# Create session instance
my_onedrive = graph_onedrive.create_from_config_file(config_path, config_key)

# Complete tasks using the instance. For this example we will just display the usage
my_onedrive.get_usage(verbose=True)

# Save the config to retain the refresh token.
graph_onedrive.save_to_config_file(my_onedrive, config_path, config_key)

License

This project itself is subject to BSD 3-Clause License detailed in LICENSE.

The Graph API is provided by Microsoft Corporation and subject to their terms of use.

Links

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

graph_onedrive-0.0.1a7.tar.gz (16.5 kB view details)

Uploaded Source

Built Distribution

graph_onedrive-0.0.1a7-py2.py3-none-any.whl (16.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file graph_onedrive-0.0.1a7.tar.gz.

File metadata

  • Download URL: graph_onedrive-0.0.1a7.tar.gz
  • Upload date:
  • Size: 16.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for graph_onedrive-0.0.1a7.tar.gz
Algorithm Hash digest
SHA256 baf04f2cc6f6be84b8813a14a45188fbd5afd2b640e4b6676a733d9402f3397d
MD5 d89dff6a026b225af43d50129320b5c6
BLAKE2b-256 94bbf76fc625e6760f6f018e7984811a42274ea89f6b1e9432e60255593331df

See more details on using hashes here.

File details

Details for the file graph_onedrive-0.0.1a7-py2.py3-none-any.whl.

File metadata

  • Download URL: graph_onedrive-0.0.1a7-py2.py3-none-any.whl
  • Upload date:
  • Size: 16.3 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for graph_onedrive-0.0.1a7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0a273f0bf696f5d30bdad78291afa49e7a19c48582b02bcaf7f5d15180da424e
MD5 4ac24b07e9bfd86230a75b4ce6bef0e7
BLAKE2b-256 d6d7b46d06ed37252a0ea51de801e79ad0db9b89e4d769b0a3f03a953d91d1a8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page