Skip to content

The OneDrive App facilitates file management and access control on Microsoft's cloud storage platform. It lists and downloads files, monitors file access rights, and notifies users of access changes. Secure authentication via Microsoft OAuth2 ensures safe handling of user credentials and controlled resource access.

Notifications You must be signed in to change notification settings

MayankAgrawal94/onedrive-poc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OneDrive App

What does this program do?

This program connects to OneDrive to:

  • List files
  • Download files
  • List all users who have access to a file
  • Provides real-time updates on user access changes

Authentication

This application implements Microsoft OAuth2 for secure login and authorization. Users will be prompted to log in with their Microsoft account, granting the application access to their OneDrive data. The OAuth2 flow ensures that user credentials are handled securely and that the application only accesses the resources explicitly permitted by the user.

How to execute it?

  1. Clone the repository:

    git clone https://github.com/MayankAgrawal94/onedrive-poc.git
    cd onedrive-poc
  2. Install dependencies:

    npm install
  3. Setup Environment Variables Create a .env file in the root directory of onedrive-poc and add the following environment variables, filling in the missing values:

    PORT=3001
    BASE_URL=http://localhost:3001
    
    AZURE_CLIENT_ID=
    AZURE_CLIENT_SECRET=
    AZURE_TENANT_ID=
    MS_AUTH_ENDPOINT=https://login.microsoftonline.com/common/oauth2/v2.0
    MS_GRAPH_ENDPOINT=https://graph.microsoft.com/v1.0
    
    SESSION_SECRET=     #For internal 'express-session' configuration
    COOKIE_MAX_AGE=1    # in days
    
    

    Note: When registering a new app in Azure, make sure to add the 'Redirect URI' as {BASE_URL}/v1/auth/ms/cb.

  4. Start the server:

    npm run start
  5. Open the client: Open http://localhost:3001 in a web browser.

Project Structure

.
├── package.json
├── package-lock.json
├── README.md
└── src
    ├── app
    │   ├── controllers
    │   │   ├── auth
    │   │   │   ├── basic.auth.controller.js
    │   │   │   └── ms.auth.controller.js
    │   │   └── msOneDrive.controller.js
    │   ├── helpers
    │   │   ├── genericFun.js
    │   │   └── onedrive.js
    │   ├── routes
    │   │   ├── auth
    │   │   │   ├── basicAuth.routes.js
    │   │   │   └── msAuth.routes.js
    │   │   └── msOneDrive.routes.js
    │   └── services
    │       ├── auth
    │       │   ├── index.js
    │       │   ├── oauthCallback.js
    │       │   ├── oauthRequest.js
    │       │   └── refreshToken.js
    │       └── onedrive.js
    ├── app.js
    ├── config
    │   ├── env.js
    │   └── session.config.js
    ├── middleware
    │   └── isAuthenticated.js
    ├── public
    │   ├── assests
    │   │   ├── document-icon.png
    │   │   ├── download-icon.png
    │   │   └── folder-icon.png
    │   ├── index.html
    │   ├── scripts
    │   │   └── logic.js
    │   ├── styles
    │   │   ├── tree-container.css
    │   │   └── welcome.css
    │   └── welcome.html
    ├── server.js
    └── socket.js

Test the real-time updates:

  • Login with valid a OneDrive account and click the "Watch File" button.
  • The permissions will be displayed and updated in real-time as they change.

Contributing

If you have any suggestions or improvements, feel free to submit a pull request or open an issue.

Contact

If you have any feedback, questions, or suggestions, feel free to reach out. connect me at jobs@mayankagrawal.co.in or can DM me on LinkedIn.

About

The OneDrive App facilitates file management and access control on Microsoft's cloud storage platform. It lists and downloads files, monitors file access rights, and notifies users of access changes. Secure authentication via Microsoft OAuth2 ensures safe handling of user credentials and controlled resource access.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published