Skip to main content

A Python program for packing/unpacking encrypted, salted, and authenticated file containers.

Project description

pypi license

nescient, n. (nesh-int) - from Latin ‘unknowing’, ‘hidden’

A Python program for packing/unpacking encrypted, salted, and authenticated file containers.

Nescient provides an easy-to-use, secure, and efficient means of file-level encryption.

Several use cases include:

  • Backing up multiple files to a reliable yet insecure location.

  • Providing additional, file-level encryption to supplement full disk encryption, securing packed files even while the machine is on with the disk-level encryption key loaded in memory.

  • Sharing files with others securely, by transferring a Nescient container through an insecure channel and providing a password through a separate secure channel.

Nescient is:

  • open source: It is licensed under the permissive MIT license.

  • multiplatform: As a Python project, Nescient works on all the major operating systems (Windows, macOS, and Linux)

  • transparent: The means with which Nescient encrypts and packs files is documented, and the algorithms used are tested both against official test vectors and arbitrary data to ensure correctness.

  • fast: All core crypto code is written in Cython and compiled to C extensions, making it fast enough to be practically usable for large files.

Nescient supports the following packing modes:

  • The AES block cipher for encryption, with either 128, 192, or 256 bit keys, in CBC mode, and SHA-256 for generating authentication tags.

  • The ChaCha20 stream cipher with 256 bit keys and SHA-256 for generating authentication tags.

Installation

Prerequisites

Nescient requires Python 3.3 or later.

Windows users are strongly suggested to have a 64-bit Python installation on their machines. Otherwise, installation may require installing the Microsoft C++ Visual Build Tools to compile Nescient’s C extensions.

From PyPI

Nescient can be installed from the Python Package Index (PyPI) by running pip install nescient.

From Releases

An arbitrary stable (not development) release can be installed from the github releases by downloading the zip archive and running pip install <path-to-zip.

From latest source

Clone or download the git repo, navigate to the directory, then run:

python3 setup.py sdist
cd dist
pip install Nescient-<version>.tar.gz

Installing from source may require installing compilation tools.

Usage

Nescient can pack or unpack files into/from .nesc containers. Some typical usage might be:

nescient pack file1 file2

nescient unpack file1.nesc

Unless otherwise specified via command line flags, Nescient packs and unpacks files in place, overwriting their data.

Command line help can be viewed with nescient -h.

Development

Nescient versioning functions on a MAJOR.MINOR.PATCH.[DEVELOP] model. Only stable, non development releases will be published to PyPI. Because Nescient is still a beta project, the MAJOR increment will be 0. Minor increments represent new features. Patch increments represent problems fixed with existing features.

Planned features include:

  • New cipher modes for existing algorithms, like the GCM authenticated mode, and additional encryption algorithms.

  • Integrated compression when packing files.

  • A GUI mode for ease of use.

  • Documentation.

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

Nescient-0.6.0.tar.gz (142.4 kB view details)

Uploaded Source

Built Distribution

Nescient-0.6.0-cp36-cp36m-win_amd64.whl (113.2 kB view details)

Uploaded CPython 3.6m Windows x86-64

File details

Details for the file Nescient-0.6.0.tar.gz.

File metadata

  • Download URL: Nescient-0.6.0.tar.gz
  • Upload date:
  • Size: 142.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for Nescient-0.6.0.tar.gz
Algorithm Hash digest
SHA256 c07ddda1c441455334a026cbfbf55e941ac38a2abc7ffeaac9897fbe846866d8
MD5 caf90eb05428b67749456ceb72ff55e0
BLAKE2b-256 8d57d5c7b92971c6699edcc66a39da45aaf961d5017deaa5619df43cb92c0cde

See more details on using hashes here.

File details

Details for the file Nescient-0.6.0-cp36-cp36m-win_amd64.whl.

File metadata

File hashes

Hashes for Nescient-0.6.0-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 32928e2845674c829f6bd91e3b7ee64d3023a3897b94e330769adae41faf6909
MD5 b47ec05bf687ed1e341eddf3e963851b
BLAKE2b-256 61bd85272c763312835d1e76f78a6cf3e844c4d3771d2b1136baa4deeeffa67f

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