Skip to main content

bwb

Project description

bwb

bot with bot.

Usage

Install with pip install --upgrade bwb.

# Import one of:
from bwb.tanner import bwb
from bwb.jason import bwb
from bwb.tdev import bwb
from bwb.molly import bwb

Handshaking

Boot up:

client.send_message(BOT_WITH_BOT, '000000init ' + bwb.init())

On 000000init [data]:

client.send_message(BOT_WITH_BOT, '000000handshake ' + bwb.handshake(data))

On 000000handshake [data]:

client.send_message(BOT_WITH_BOT, bwb.wrap('secret ' + bwb.secret(data)))
bwb.set_otp(bwb.init_secret)

On OTP authed 123456secret [data]:

bwb.set_secret(data)
client.send_message(BOT_WITH_BOT, bwb.wrap('🤝'))

On OTP authed 123456🤝:

client.send_message(BOT_WITH_BOT, '🤝')

Interaction

Run every incoming message through bwb.parse() since it's inexpensive. This will decrypt and remove base58 encoding.

Once decoded, send it through bwb.check_auth() which will return True or False if the code is valid.

Example:

text = bwb.parse(text)
if text.startswith('!'):
    ...
elif text.startswith('000000'):
    text = text[6:]
elif bwb.check_auth(text):
    authed = True
    text = text[6:]
else:
    return

Use bwb.wrap() to auth and encode outgoing commands.

Params:

wrap(text, target=None, b58=False, enc=False)

Examples:

out = bwb.wrap('ping')  # broadcast all bots
out = bwb.wrap('ping', target=TANNER)  # auth for Tannerbot
out = bwb.wrap('ping', target=JASON, enc=True)  # base58 encrypt
out = bwb.wrap('ping', target=MOLLY, b58=True)  # base58

Development

Setup

Clone the repo.

To test your changes:

pip install --upgrade ~/path/to/bwb

Deployment

Install setuptools:

python3 -m pip install --user --upgrade setuptools wheel
  • Increment version number in setup.py

Build and upload:

bash build-upload.sh

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

bwb-2.0.1.tar.gz (3.7 kB view details)

Uploaded Source

Built Distribution

bwb-2.0.1-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file bwb-2.0.1.tar.gz.

File metadata

  • Download URL: bwb-2.0.1.tar.gz
  • Upload date:
  • Size: 3.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.5.3

File hashes

Hashes for bwb-2.0.1.tar.gz
Algorithm Hash digest
SHA256 d59f9d43235d00d1d42ffc8d195b1b356f9b6b475ddccaecd446e4846e0a9ba9
MD5 1a76c8a1a43a3445c446456570e53602
BLAKE2b-256 33992d676c7f093f3207a70acde35d852e3dea0976439508fc1f9a2ea56d524a

See more details on using hashes here.

File details

Details for the file bwb-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: bwb-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 4.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.5.3

File hashes

Hashes for bwb-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6a6458528ddd215a5738f5a0523bc147d4471a7d85fb7af3202a173ae1ead6e8
MD5 3cab5b4121b1eb779d4524567fb01211
BLAKE2b-256 a35c2e1176b4ea909b825ee047aaef3e5fa146169827b06d8eb2ed9d7df478f3

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