@harrisoff/onedrive-js-sdk v2.0.0
OneDrive JS SDK
This project wraps a small part of OneDrive's APIs, only for uploading files and creating sharing links.
You can build a webGUI to use it. There is an example OneDrive Image Hosting.
Configure Account
In App registrations page click new registration button, then you'll need to fill the following fields:
Name
Supported account types
Personal Microsoft accounts onlyis enough for personal usageRedirect URI
For example,
https://localhost:3000/
After registration, click Authentication on the left, check Access tokens (used for implicit flows) and save.
Application (client) ID is generated once the application is registered. But you'll need to verify the application before using it. Just click Branding on the left and follow the instructions.
Usage
Authentication
Here we use token flow in authentication. Use helper function generateAuthUrl to generate an auth url and open it.
import { generateAuthUrl } from '@harrisoff/onedrive-js-sdk'
const authUrl = generateAuthUrl('your-client-id', 'your-redirect-uri')Actually there's another field
scopeis required in the auth url. This value is set toopenid https://graph.microsoft.com/Files.ReadWrite.Alland is unnecessary to be changed.
After redirecting back to your site, access_token or error messages will be presented in the hash depending on whether authentication is successful.
API calls
There are two ways to call APIs.
The original APIs are exposed so you can use them directly:
import { uploadSmall, createUploadSession, uploadLargeChunk, share, getShareItem } from '@harrisoff/onedrive-js-sdk'Or you can use constructor to create a client instance, which wraps the original APIs:
import OneDriveAPI from '@harrisoff/onedrive-js-sdk'
const client = new OneDriveApi({ accessToken })
const { id: fileId } = await client.upload(file, filePath)
const { shareId } = await client.share(fileId)
const shareUrl = await client.getShareUrl(shareId)TODO List
- progress callback
Development
For more details, see: