Skip to main content

Mount remote cloud storage as FUSE filesystem

Project description

FUSE File System for accessing remote servers

A FUSE file system for mounting remote file servers as local directories. Currently, we support Microsoft SharePoint sites.

Installation

pip install remote-fuse

Configuration

The following environment variables need to be set:

  • TENANT_ID: Azure AD tenant ID
  • CLIENT_ID: Azure AD client/application ID
  • CLIENT_SECRET: Azure AD client secret
  • SITE_ID: SharePoint site ID

Running

# Mount remote cloud storage
remote-fuse <mounting-point>
# Optionally, you can add `--site-id <site-id` as an argument to the command.

# Unomunt when finished
fusermount -uqz <mount-point>

Development

# Install dependencies
python -m venv .venv
source .venv/bin/activate

# Install dependencies
pip install -e .

# For development/testing
pip install -e ".[test]"

Requirements

  • FUSE implementation (libfuse2 on Ubuntu, macFUSE on macOS)

Usage

# Mount SharePoint site as local directory
python commands/fuse_sharepoint.py <mount-point>

# Unomunt SharePoint site when finished
fusermount -uqz <mount-point>

# Run tests
pytest

Overview of the project

  • src/remote_fuse.py: Implements Fuse interface and by invoking API calls to remote service
  • src/sharepoint.py: Implements the interface to present SharePoint as a local filesystem
  • commands/fuse_sharepoint.py: Mounts SharePoint site as local directory

python-fuse documentation

Currently, python-fuse only supports Linux. There is no easy way to stop the process once started, it doesn't react to signals, however, it will stop if you unmount it. https://github.com/libfuse/python-fuse/blob/master/README.new_fusepy_api.rst

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

remote_fuse-0.1.0.tar.gz (15.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

remote_fuse-0.1.0-py3-none-any.whl (14.9 kB view details)

Uploaded Python 3

File details

Details for the file remote_fuse-0.1.0.tar.gz.

File metadata

  • Download URL: remote_fuse-0.1.0.tar.gz
  • Upload date:
  • Size: 15.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for remote_fuse-0.1.0.tar.gz
Algorithm Hash digest
SHA256 67d4700db3f9212fe4ef98991af6b061b3db2bbf7d711052b132b7f279a4b7d1
MD5 7e543596dca2cea19fa5901c3fe5c350
BLAKE2b-256 e64d0223e069fea1b425839c3c6943a55afeb22d7b410e162f7141f524283189

See more details on using hashes here.

File details

Details for the file remote_fuse-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: remote_fuse-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 14.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for remote_fuse-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0bde9629d460525a4777538711533be00565aceb23c1652a95264c8fc1605483
MD5 b4c6f36c7dc026c10a9978cef248ba36
BLAKE2b-256 5117e1a572faa447a2d676406234f9564c73aa65b0e7d418bacd080f46395b5c

See more details on using hashes here.

Supported by

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