blackspherefollower / buttplug4j

Java Implementation of the Buttplug WebSocket Client
https://buttplug.io/
Other
9 stars 3 forks source link
hardware sex sex-toys teledildonics

Buttplug for Java - A Buttplug Client Implementation for Native Java

Build Status Patreon donate button

Learn more about buttplug.io at https://buttplug.io

Platform Support

Buttplug Java should run on any 1.8 or later JRE (including Android). In depth testing is still pending, so your mileage may vary.

Usage

The core buttplug4j library does not contain a transport implementation, as the connector layer is intended to be extensible. In reality, you'll probably just want the Jetty websocket client connector (this depends on the core client library, so there's no need to add a separate dependency); see the 2 dependency import examples below.

For Gradle:

dependencies {
    implementation 'io.github.blackspherefollower:buttplug4j.connectors.jetty.websocket.client:3.1.105'
}

For Maven:

<dependencies>
    <dependency>
        <groupId>io.github.blackspherefollower</groupId>
        <artifactId>buttplug4j.connectors.jetty.websocket.client</artifactId>
        <version>3.1.105</version>
    </dependency>
</dependencies>

For an all-in-one example project, please see https://github.com/blackspherefollower/buttplug4j-example

In general, you'll want to create a ButtplugClientWSClient object in a scope where it will not get garbage collected before you're done, add callbacks for error and event handling, then connect it to the address Intiface is listening on. Then you can scan for devices, iterate over them and send commands.

Snapshots

Snapshot libraries from the buttplug4j repo are available via Maven from the following repository: https://s01.oss.sonatype.org/content/repositories/snapshots Releases will be available from maven central.

<repositories>
    <repository>
        <id>OSSRH</id>
        <url>https://s01.oss.sonatype.org/content/repositories/snapshots</url>
        <snapshots>
            <enabled>true</enabled>
        </snapshots>
    </repository>
</repositories>
<dependencies>
    <dependency>
        <groupId>io.github.blackspherefollower</groupId>
        <artifactId>buttplug4j.connectors.jetty.websocket.client</artifactId>
        <version>[3.0-SNAPSHOT,)</version>
    </dependency>
</dependencies>

Support The Project

If you find this project helpful, you can support my projects via Patreon! Every donation helps us afford more hardware to reverse, document, and write code for!

License

Buttplug for Java is BSD licensed.

Copyright (c) 2016-2024, BlackSphereFollower
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright notice, this
  list of conditions and the following disclaimer.

* Redistributions in binary form must reproduce the above copyright notice,
  this list of conditions and the following disclaimer in the documentation
  and/or other materials provided with the distribution.

* Neither the name of buttplug nor the names of its
  contributors may be used to endorse or promote products derived from
  this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.