Skip to main content

An unofficial CLI tool and higher-level Python API client for 115.com cloud storage service

Project description

115cli

PyPI version test codecov

An unofficial CLI tool and Python library for 115.com cloud storage. It provides a command-line interface for common file operations and a higher-level Python API client that can be used as a library in your own code.

Read disclaimer carefully before using this tool.

中文版 README

Installation

pip install 115cli

Usage

CLI

After authenticating with 115cli auth, you can use the 115cli command to interact with your 115 cloud storage. Here are some examples of available commands:

# Authenticate with cookies
115cli login cookie "UID=xxx; CID=xxx; SEID=xxx; KID=xxx"

# Account info
115cli account

# List files
115cli ls /
115cli ls /path/to/dir -l
# Sort by creation time, newest first
115cli ls -l --sort created --desc

# File operations
115cli mkdir /new-folder
115cli cp /src/file.txt /dst/
115cli mv /old/path /new/path
115cli rm /path/to/file
115cli rm -r /path/to/dir
115cli find /search/path keyword

# File info and download
115cli stat /path/to/file
115cli url /path/to/file
115cli url --format aria2c /path/to/file

# Download a file to local disk
115cli fetch /path/to/file.mp4
115cli fetch /path/to/file.mp4 -o /local/save/path.mp4

# Upload (support instant upload)
115cli upload /local/file.txt /remote/dir/file.txt
# Upload with instant upload only
115cli upload --instant-only /local/file.txt /remote/dir/file.txt
# Upload a folder
115cli upload /local/folder/ /remote/dir/
# Upload with include/exclude patterns
115cli upload /local/folder/ /remote/dir/ --include "**/*.mkv" --include "**/*.mp4" --exclude "secret/*"

# Cloud download (offline download)
115cli download quota
115cli download list
115cli download list --filter completed
115cli download add "https://example.com/file.mp4"
115cli download delete <info_hash>
115cli download retry <info_hash>
115cli download clear --filter failed

Note: Creating cloud download tasks may trigger a captcha challenge. This is currently not supported by the client.

Authentication

115cli currently only supports cookie-based authentication. Obtain your cookies from the browser after logging into 115.com. You need the UID, CID, SEID, and KID cookie values.

115cli login cookie "UID=xxx; CID=xxx; SEID=xxx; KID=xxx"

Python API

The package also exposes a higher-level Python API client that you can use in your own projects:

from cli115.auth import CookieAuth
from cli115.client import create_client

auth = CookieAuth(
    uid="xxx",
    cid="xxx",
    seid="xxx",
    kid="xxx"
)
client = create_client(auth)

# List directory
entries = client.file.list("/")
for entry in entries:
    print(entry.name, entry.id)

# Get file info
info = client.file.info("/path/to/file.txt")
print(info.name, info.size, info.sha1)

# Download info
dl = client.file.url("/path/to/file.txt")
print(dl.url)

# Fetch a remote file as a lazy file-like object
with client.file.open("/path/to/file.txt") as rf:
    data = rf.read(1024)   # only downloads the first 1024 bytes

# Upload
result = client.file.upload("/remote/dir/", "/local/file.txt")

# Cloud download
client.download.add_url("https://example.com/file.mp4")
tasks = client.download.list()

This project is in an early stage of development, it may subject to breaking changes in the future.

Future Plans

The project aims to cover the core features of 115 cloud storage. Planned additions include:

  • Multi-threaded download: Multi-thread acceleration for the 115cli fetch command.
  • Recycle bin management: List, restore, and permanently delete items from the recycle bin.
  • Mobile phone authentication: SMS-based login in addition to cookie auth.

Disclaimer

This is an unofficial client for 115.com and is not affiliated with, endorsed by, or associated with 115.com or its parent company in any way.

Use at your own risk. The authors are not responsible for any account suspension, data loss, or other consequences arising from the use of this software. The API may change at any time without notice, which could break this tool.

You may encounter Aliyun WAF blocks when using the library, the mechanism and consequences are currently unknown. It may relate to the frequency of API calls. After being blocked, you may need to wait for a while before retrying, the official web interface may also be affected during the block period.

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

115cli-0.2.1.tar.gz (44.6 kB view details)

Uploaded Source

Built Distribution

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

115cli-0.2.1-py3-none-any.whl (50.9 kB view details)

Uploaded Python 3

File details

Details for the file 115cli-0.2.1.tar.gz.

File metadata

  • Download URL: 115cli-0.2.1.tar.gz
  • Upload date:
  • Size: 44.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for 115cli-0.2.1.tar.gz
Algorithm Hash digest
SHA256 0c5105a6a9fcc5355136e7237394d096db045aba1870ab3ea1f1feef8a50978b
MD5 1e50d467e78455df4f2585af1f474d9c
BLAKE2b-256 8cad1c7343c2ccf394f8c9eb4e38354481313f17003c250e67ec799986409d84

See more details on using hashes here.

File details

Details for the file 115cli-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: 115cli-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 50.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for 115cli-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 38f4d6fc22e069607a1049fa0bcbc7d7e993cdc2a2f5a07f0021f543b3d1de4c
MD5 512e384b191a9159e43f81a79b7f00c1
BLAKE2b-256 bdcff48084fbe50abbee0953c3387c1fcbaf4eb5a4a999a6a7bef2d6e7e2c758

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