Metadata-Version: 2.0
Name: buttshock
Version: 0.2.1
Summary: Python Libraries for Estim Unit (ErosTek ET312, Erostek ET232, Estim Systems 2B) Control
Home-page: http://github.com/metafetish/buttshock-py
Author: qDot
Author-email: kyle@machul.is
License: BSD License
Download-URL: http://pypi.python.org/packages/source/b/buttshock
Keywords: estim,buttshock,teledildonics,electrostim
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Topic :: System :: Hardware :: Hardware Drivers

buttshock-py
============

Python implementation of serial based control of the following devices:

- Erostek ET-312 Electrostimulation Device
- Erostek ET-232 Electrostimulation Device
- Estim Systems 2B Electrostimulation Device

.. start-badges

.. list-table::
    :stub-columns: 1

    * - docs
      - |docs|
    * - tests
      - |travis| |coverage| |health|
    * - package
      - |license| |version| |pyversion|

.. |docs| image:: https://readthedocs.org/projects/buttshock-py/badge/?version=latest
   :target: http://buttshock-py.readthedocs.io/en/latest/?badge=latest
   :alt: Documentation Status

.. |travis| image:: https://img.shields.io/travis/metafetish/buttplug-py/master.svg?label=build
   :target: https://travis-ci.org/metafetish/buttshock-py
   :alt: Travis CI build status

.. |health| image:: https://codeclimate.com/github/metafetish/buttshock-py/badges/gpa.svg
   :target: https://codeclimate.com/github/metafetish/buttshock-py
   :alt: Code coverage

.. |coverage| image:: https://codeclimate.com/github/metafetish/buttshock-py/badges/coverage.svg
   :target: https://codeclimate.com/github/metafetish/buttshock-py/coverage
   :alt: Code health

.. |license| image:: https://img.shields.io/pypi/l/buttshock.svg
   :target: https://pypi.python.org/pypi/buttshock/
   :alt: Latest PyPI version

.. |version| image:: https://img.shields.io/pypi/v/buttshock.svg
   :target: https://pypi.python.org/pypi/buttshock/
   :alt: Latest PyPI version

.. |pyversion| image:: https://img.shields.io/pypi/pyversions/buttshock.svg
   :target: https://pypi.python.org/pypi/buttshock/
   :alt: Latest PyPI version


.. end-badges

Using pyserial 3.1.1 (thought may work with pyserial 2.6+, but untested)

Buttshock Project Goals
-----------------------

If you're going to shock yourself in the butt (or other places) for
sexual pleasure, don't you want to be able to know exactly what and
how you're doing it? Even if you can't understand it, wouldn't it be
nice for people that do to have access to the knowledge and data they
need to make sure things are safe? Why is the best encryption open
source, but electrostim toys are closed?

The Buttshock project exists to reverse engineer and document
eletrostim devices so that any developer that wants to control their
devices can, via their own code.

Some of the goals of this project include:

- Documenting the communications protocols (serial or otherwise)
- Reverse engineering the firmware (where possible)
- Mapping the circuit boards and creating schematics

Installation
------------

To install:

.. code:: shell

    $ pip install buttshock --upgrade

Package is also available on PyPi at http://pypi.python.org/pypi/buttshock

Python Implementation Details
-----------------------------

This is a python implementation of the RS-232 control protocol for the
ErosTek ET-312 electrostimulation box.

Documentation of the link cable, protocol, and other information is at:

https://buttshock.com/doc/et312

This library was developed and tested using a ET-312B running v1.6
firmware. The ET-232 and 2B libraries are untested, but please let us
know if you've used them and they do/don't work!

Requirements
------------

buttshock-py requires the pyserial library if you want to actually
connect via serial. However, it can pass packets for each box over
whatever medium you like.

Repo Contents
-------------

This repo contains the following:

- src - Source code for the library
- examples - Example code that uses the library

License
-------

tl;dr: BSD 3-Clause license

Copyright (c) 2016, Buttshock Project

See LICENSE file for full text.

Versions
========

0.2.0 (2016-07-05)
------------------

- Change module layout to plan for new hardware implementations
- Add documentation tree
- More tests 

0.1.2 (2016-07-05)
------------------

- Fixed serial initialization issue

0.1.1 (2016-07-04)
------------------

- CI/automation changes

0.1.0 (2016-07-04)
------------------

- Initial Release
- Basic ET-312 functionality



