Are you sick of players turning your awesome server into a NSFW gallery ? Do you wish to bring back your logic displays without the fear of seing anime girls in questionable situations ? Well, worry no more, xpdustry cooked another banger plugin for just this situation.
Introducing nohorny, the successor of BMI. This mindustry plugin automatically tracks logic displays and canvases and process them when needed with the anti-nsfw API of your choice.
Enjoy this family friendly factory building game as the cat intended it to be.
This plugin requires at least :
-
Mindustry v146
-
Java 17
-
KotlinRuntime latest
-
SLF4MD latest
-
SQL4MD latest
Put the plugin in your config/mods
directory and start your server.
Then, go to the created directory config/mods/nohorny
and create a file named config.yaml
.
Now you can set up the analyzer of your choice:
-
SightEngine: Very nice service with 2000 free operations per month. Also supports gore detection.
analyzer: sight-engine-user: xxx sight-engine-secret: xxx # Optional thresholds tweaks unsafe-threshold: 0.55 warning-threshold: 0.4 kinds: - "NUDITY" # Since gore is very uncommon, it's not enabled by default - "GORE"
-
Debug: The debug analyzer allows you to check if the plugin properly renders the logic and canvases images, by saving them in the directory
config/mods/nohorny/debug
.analyzer: Debug
Once you chose your analyzer, load your changes using the command nohorny-reload
in the console, and enjoy,
the plugin will automatically ban players that have built structures at UNSAFE
Rating.
For those of you who want more control, like implementing a validation system to avoid false positives.
I suggest you to use the nohorny API in your plugin.
To do so, add the following in your build.gradle
repositories {
maven { url = uri("https://maven.xpdustry.com/releases") }
}
dependencies {
compileOnly("com.xpdustry:nohorny:VERSION")
}
Then you will be able to intercept ImageAnalyzerEvent
, which is posted every time a group of NoHornyImage
is processed,
see NoHornyAutoMod for an example.
In config.yaml
:
# NoHorny built-in auto moderator configuration
auto-mod:
# The minimum rating for nohorny to delete suspicious blocks (also refunding the player's team). Set to null to disable.
delete-on: WARNING
# The minimum rating for nohorny to ban the player. Set to null to disable.
ban-on: UNSAFE
# The delay between the last logic or canvas block built and the analysis step,
# lower it on servers with fast build time such as sandbox
processing-delay: 5s
# Display tracker configuration
displays:
# The minimum number of draw instructions in a logic processor to be part of a group
minimum-instruction-count: 100
# The minimum number of logic processors in a group to be eligible for processing
minimum-processor-count: 5
# The search radius of linked logic processors around a group of logic displays,
# tweak depending on the average size of your server maps
processor-search-radius: 10
# Canvas tracker configuration
canvases:
# The minimum number of canvases in a group to be eligible for processing,
# relatively high since you a lot of canvases are needed for a clear picture
minimum-group-size: 9
# Image cache configuration, set it to None (image-cache: None) to disable caching
image-cache:
# The retention period of a cached image, if "(now - retention) >= last-match", the image is removed
retention: 24h
# The maximum number of images to cache, if the cache is overflowing, the least matched images are removed
max-size: 1000
-
./gradlew shadowJar
to compile the plugin into a usable jar (will be located atbuilds/libs/nohorny.jar
). -
./gradlew runMindustryServer
to run the plugin in a local Mindustry server. -
./gradlew runMindustryClient
to start a local Mindustry client that will let you test the plugin. -
./gradlew spotlessApply
to apply the code formatting and the licence header.
Need a helping hand ? You can talk to the maintainers in the Chaotic Neutral discord in
the #support
channel.