Skip to main content

Obsideo Cloud - encrypted storage we can't read. Save, browse, and sync whatever you want, from your terminal.

Project description

obsideo-cli

Encrypted storage we can't read. Save, browse, and sync whatever you want from your terminal. Files are encrypted on your machine before they leave, so Obsideo's gateway, coordinator, and storage providers only ever see ciphertext. Your data lands on three independent providers (RF=3).

pip install obsideo-cli
obsideo login    # email -> 3 GB free
obsideo          # open the shell

Get started

$ obsideo login
Enter your email: you@example.com
Check your email for a verification code.
Enter verification code: 482913
You're all set. 3 GB free.

Login is handled by Obsideo's signup service at signup.obsideo.io: it emails you a one-time code and provisions your free tier. There's no password - just your email and a local key (see How it works).

Then either drop into the shell or run one-shot commands:

$ obsideo
obsideo:/ put ~/notes.txt
obsideo:/ ls
  [file] notes.txt  1.2 KB
obsideo:/ put ~/photos                       # a whole folder, uploaded recursively
obsideo:/ put "C:\My Files\tax return.pdf"   # paths with spaces: just quote them
obsideo:/ mkdir trip
obsideo:/ cd trip
obsideo:/trip/ put ~/cat.jpg
obsideo:/trip/ get cat.jpg ./downloaded.jpg

Commands

Command Description
obsideo login Sign up / log in with your email (3 GB free)
ls [path] List files and folders
cd <path> / pwd Move around / show location
put <local> [name] Encrypt + upload a file, or a whole folder (recursive). --no-encrypt to store as-is
get <remote> [local] Download + decrypt a file
rm <remote> Delete a file
mkdir <name> Create a folder
info <remote> Show object metadata
account Show storage used vs. your free quota
sync push|pull|status Sync your local folder with Obsideo
config [set k v] Show or change settings

How it works

obsideo is a thin front-end over the shared obsideo_core layer (storage seam, signing identity, account crypto, email-OTP login). The mlvault ML extension builds on the same core - build the core once, two front-ends.

  • Encryption: AES-256-GCM with one account data key held locally at ~/.obsideo/data.key. Copy that key to another machine and everything is readable there; lose it and the data is unrecoverable by design. Back it up.
  • Signing identity: an Ed25519 key (~/.obsideo/signing.key) authorizes deletes (Principle 2 - the network can't delete your data without your signature). Generated locally; only the public half is ever sent.
  • Filename encryption: on by default (encrypt_names). Each path component (folder names + filename) is encrypted on your machine with AES-SIV - deterministic, so ls/cd still list under the encrypted prefix and the client decrypts the returned tokens back to real names. Turn it off with config set encrypt_names false (interop/debug; existing objects aren't migrated).
  • What Obsideo sees: ciphertext only - never a filename or a byte of content. Residual leaks (by design at this level): directory structure (depth, fan-out), object sizes (ciphertext ≈ plaintext), and object counts. Identical names encrypt to identical tokens, so Obsideo can tell two objects share a name - never what it is.

License

MIT

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

obsideo_cli-0.2.0.tar.gz (22.5 kB view details)

Uploaded Source

Built Distribution

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

obsideo_cli-0.2.0-py3-none-any.whl (22.0 kB view details)

Uploaded Python 3

File details

Details for the file obsideo_cli-0.2.0.tar.gz.

File metadata

  • Download URL: obsideo_cli-0.2.0.tar.gz
  • Upload date:
  • Size: 22.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for obsideo_cli-0.2.0.tar.gz
Algorithm Hash digest
SHA256 fbbf31425f74a687ebfdb0b3a4b6fde81f6a682b26fd9c62dda2750cab783fa4
MD5 c6dfddf9b6939cb00bf7b7445a5710ab
BLAKE2b-256 0961c10f87558c12abecbaebd8a60418ec7e9874f6c374a11312e9333b187e27

See more details on using hashes here.

File details

Details for the file obsideo_cli-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: obsideo_cli-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 22.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for obsideo_cli-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4864f88e97206c0bb0223c00ad88fd3332baa5698b491b714d4bddd64a80a3a6
MD5 946e063cba24535e071415f31ac79db4
BLAKE2b-256 a39ea62dc4a0303ea1d73224e56612a08968071b324446317f49cdeb1776a8df

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