Skip to main content

Ni! Ni! Ni!

Project description

Ni! Ni! Ni!

  1. Visit software license page.

  2. Give me a shrubbery i.e. pay up.

  3. Receive license code.

  4. Configure software with username and license code.

Quick Start

$ pip install knightswhosayni
$ python -m knightswhosayni.main [path/to/src] [module-name] [prefix] [license-key]
$ tox -e py
$ python -m build
$ twine upload dist/*

License Users

Option 1: Using Code

import builtins
builtins.[prefix]LICENSE_USER = '[username]'
builtins.[prefix]LICENSE_CODE = '[license code]'

Option 2: Using Environment Variables

export [prefix]LICENSE_USER=[username]
export [prefix]LICENSE_CODE=[license code]

Option 3: Using License File

# [prefix.lower()]license.ini
[prefix.strip('_')]
LICENSE_USER=[username]
LICENSE_CODE=[license code]

Example

Given:

  • prefix – ‘PACKAGE_NAME_V1_’

  • username – name@example.com

import builtins
builtins.PACKAGE_NAME_V1_LICENSE_USER = 'name@example.com'
builtins.PACKAGE_NAME_V1_LICENSE_CODE = 'e385cf4c-be9a-4389-82ba-bfa85b8ad17c'
export PACKAGE_NAME_V1_LICENSE_USER=name@example.com
export PACKAGE_NAME_V1_LICENSE_CODE=e385cf4c-be9a-4389-82ba-bfa85b8ad17c
# package_name_v1_license.ini
[PACKAGE_NAME_V1]
LICENSE_USER=name@example.com
LICENSE_CODE=e385cf4c-be9a-4389-82ba-bfa85b8ad17c

Caveats

Maybe this package is a bad idea. But here’s how I got here:

  1. I occassionally make useful packages.

  2. People use them and occassionally contribute (that’s good!).

  3. Rarely people donate to the projects (the amounts are tiny).

  4. I thought about using GitHub Donors but felt like it required a whole online “personality”. I like making friends but thought maybe old-school software licensing could work.

  5. Real encryption using RSA or whatnot introduces a dependency that is too heavy (my libraries typically have no dependencies).

  6. I don’t want to force code to call a web server either every time it runs (privacy issues and whatnot).

  7. I still believe most people are willing to “do the right thing” especially if it’s more annoying to “do the wrong thing”.

  8. I still want to produce Open Source software so if you want to steal the code, it’s about as easy as ctrl-c ctrl-v. BUT, I’m going to bet that losing the easiness of “pip install thing” is Annoying Enough(TM).

  9. Hence, the Knights Who Say Ni are my paradigm. They’re troublesome enough to bring them a shrubbery but not so troublesome that RSA encryption, and license servers, and lawyers need be involved.

Put into practice, the package works in four parts:

  1. The __license__.py file is added to the Python package for distribution.

  2. The __init__.py file of the Python package is modified for a new encoding.

  3. License checks are injected into the Python package source files.

  4. The Python package source files are encrypted, err, obfuscated, err, obscured, err, encoded with the new encoding.

Which achieves three things:

  1. License checks occur on import of the source files.

  2. The source files in the package are hard to change.

  3. Changes to the package’s __init__.py break the encoding.

Which I’m hoping is just Annoying Enough(TM) to motivate paying for a license rather than working around it.

Some things this does not guard against:

  1. Making your own keygen – correct, RSA is great but too heavyweight.

  2. Decoding the source code – correct, it’s already Open Source online.

  3. Vendoring the unobfuscated code – correct, but then no pip updates.

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

knightswhosayni-0.2.0.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

knightswhosayni-0.2.0-py3-none-any.whl (14.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: knightswhosayni-0.2.0.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for knightswhosayni-0.2.0.tar.gz
Algorithm Hash digest
SHA256 62380fbd7f162f745ef86dca342ae528009bcca9b6d2d3ad59dbc92da15cf4b1
MD5 70cf1e9e0d733311071ce22853ae3321
BLAKE2b-256 c34b1cd28c730bae3406a48693372ce708e10f7850feca80593d683255534f89

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for knightswhosayni-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 48e01a6cd95db98e68398df2a81d0d4332b1dd284ecc2c185cb8439168d4dec8
MD5 30de5d5f9e02e810c88ed9cabe99bc8b
BLAKE2b-256 e48edb0481e782c3e8bf60ac1c7e641a6532b4e5647cfbd2d97d1d798881056f

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