Skip to main content

Pyfilesystem2 over SMB using pysmb

Project description

miarec_smbfs SMB filesystem for PyFilesystem2

Actions License

This is a fork of fs.smbfs

The code was modified by MiaRec team to fullfill our needs.

Notable differences between miarec_s3fs and fs-s3fs

  1. Requires Python 3.7+. A support of older version of Python was removed.

  2. The opener protocol prefix is msmb:// (instead of the original smb://)

Requirements

PyFilesystem2 PyPI fs Source fs License fs
six PyPI six Source six License six
PySMB PyPI pysmb Source pysmb License pysmb

miarec_smbfs supports Python versions 3.7+

Installation

Install directly from PyPI, using pip :

$ pip install miarec_smbfs

Usage

Opener

Use fs.open_fs to open a filesystem with an SMB FS URL:

import fs
smb_fs = fs.open_fs('msmb://username:password@SAMBAHOSTNAME:port/share')

The opener can use either an IPv4 address or a NetBIOS hostname, using the NetBIOS name service to find the other token. Otherwise, if NetBIOS is not available, a new SMB connection can be established by using the IPv4 address and giving the hostname with the hostname URL parameter.

The following parameters can be passed as URL parameters: timeout, name-port, direct-tcp, hostname, and domain.

Constructor

import miarec_smbfs
smb_fs = miarec_smbfs.SMBFS(
    host, username="guest", passwd="", timeout=15,
    port=139, name_port=137, direct_tcp=False, domain=""
)

with each argument explained below:

  • host: either the host name (not the FQDN) of the SMB server, its IP address, or both in a tuple. If either the IP address or the host name is not given, NETBIOS is queried to get the missing data.
  • user: the username to connect with, defaults to "guest" for anonymous connection.
  • passwd: an optional password to connect with, defaults to "" for anonymous connection.
  • timeout: the timeout, in seconds, for NetBIOS and TCP requests.
  • port: the port the SMB server is listening on.
  • name_port: the port the NetBIOS naming service is listening on.
  • direct_tcp: set to True if the server is accessible directly through TCP, leave as False for maximum compatibility.
  • domain: the network domain to connect with, i.e. the workgroup on Windows. Usually safe to leave as empty string, the default.

Once created, the SMBFS filesystem behaves like any other filesystem (see the Pyfilesystem2 documentation), except if it was open in the root directory of the server, in which case the root directory of the SMBFS instance will be read-only (since SMB clients cannot create new shares).

Testing

Automated unit tests are run on GitHub Actions

To run the tests locally, do the following.

Install Docker on local machine.

Create activate python virtual environment:

python -m vevn venv
source venv\bin\activate

Install the project and test dependencies:

pip install -e ".[test]"

Run tests:

pytest

Credits

miarec_smbfs is developed and maintained by MiaRec

The original code (fs.smbfs) was developed by:

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

miarec_smbfs-2024.1.1.tar.gz (18.8 kB view details)

Uploaded Source

Built Distribution

miarec_smbfs-2024.1.1-py2.py3-none-any.whl (15.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file miarec_smbfs-2024.1.1.tar.gz.

File metadata

  • Download URL: miarec_smbfs-2024.1.1.tar.gz
  • Upload date:
  • Size: 18.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for miarec_smbfs-2024.1.1.tar.gz
Algorithm Hash digest
SHA256 272fa4e817c4abf670d19f1af27037f5bb590c1e2b484ea78784b2076b7440b4
MD5 c2a2a0d25348047123f234c8d962e069
BLAKE2b-256 f5155b70bedc504e4090b2798c229a59614b5c69b299def4ed0c80d771f78da1

See more details on using hashes here.

File details

Details for the file miarec_smbfs-2024.1.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for miarec_smbfs-2024.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 c026cf131201e1240cd9e2c7622e06c352ee85a15c81ce045fceb91c9cdcb9e4
MD5 7b325ce968e8be5a5e0742c238b86820
BLAKE2b-256 e26cfb08e72db74493034ed7d82cc610c3519c0f9d4f4958ab2dd583f1a7a10f

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