• Stars
    star
    137
  • Rank 265,079 (Top 6 %)
  • Language
    C#
  • License
    Other
  • Created over 1 year ago
  • Updated 6 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

AntiRip (Kanna Protecc) - Free and insanely strong VRChat Anti Rip. Let us rid of rippers, together.

Fuck Rippers! This project was previously owned by rygo6. It has been passed on for me to own and work on. This is the official repository for this project.

This is free. Actually read all of this.

NOTE: Rather pathetically, some are spreading the false rumor this has been bypassed. It has not been bypassed. This is from the malicious scene to try to stop this becoming too common.

Kanna Protecc

This is a rather invasive anti-avatar-ripping system to be used for VRChat. It will protect against your avatar being ripped, extracted and edited. It will also protect against your avatar being ripped and re-uploaded without edits.

This system will randomize all the vertices of your avatar's mesh, then write that to disk. Then rely on a custom shader with a 32 bit key to un-randomize the vertex positions in game. This is not done through blend shapes. Rather this will copy, and destructively edit, the 'Basis' layer of your mesh. It will also obfuscate pretty much everything else on your avatar to confusing as a extra middle finger for the ripper.

Tutorial Video (Click The Image!)

Contents

  1. Caveats of this System

  2. Supported Shaders

  3. Simple Usage Instructions

  4. Testing in Unity

  5. FAQs

  6. How secure is this?

  7. Support

  8. Roadmap

  9. Hall Of Shame

Caveats of this System

  1. For a user to see your avatar properly in VRChat, they must have your avatar fully shown. Shaders, animations and all. You are invisible otherwise.

  2. This synchronizes the key with Avatar 3.0 parameters and does take up 32 bits. So this system can only work with avatars that use the VRChat Avatar 3.0 SDK.

  3. Only a shader from Supported Shaders will work with this. To request another shader to be supported, feel free to ask in the discussions tab here, or in the discord, seen in the Support section.

  4. Proper integration with VRCFury is currently in development.

Supported Shaders

Supported Shader Name Download
Poiyomi https://github.com/poiyomi/PoiyomiToonShader
Unity-Chan Toon Shader (UTS) https://unity-chan.com/download/releaseNote.php?id=UTS2_0&lang=en
Sunao Shader https://booth.pm/ja/items/1723985
XSToon https://github.com/Xiexe/Xiexes-Unity-Shaders
GTAvaToon https://github.com/rygo6/GTAvaToon

Quick Start Guide

Click me!

Backup your project before running these operations in case it doesn't work properly and causes difficult to fix, or impossible to fix, changes in your project.

Really do it. Close Unity, and make a full clean copy of your entire Unity Project folder. A small percentage of avatars did have odd things in their mesh that just wouldn't work, or could cause errors, and the script could leave some assets in the project in a rather messed up state.


Install Kanna Protecc and a supported shader

  1. Ensure you are using latest VRChat Avatars SDK.
  2. Download the supported shader of your choice from Supported Shaders, and import it into your Unity project.
  3. Click (Download). Once downloaded, extract it. Once you have the folder, put that into your assets folder of your unity project.

Prep Your FBX's.

Be sure all of this is set correctly on your FBX's. (Legacy blend shape normals and read/write on too!)

Model


Setup Kanna Protecc Component.

  1. Add the KannaProteccRoot component onto the root GameObject of your avatar, next to the VRCAvatarDescriptor component.

Steps 1

Materials Settings

Materials

Additional Materials is intended for materials used in animations. DO NOT PUT NORMAL NON-ADDITIONAL MATERIALS IN HERE.

The Auto Detect button tries to find material references in all animations! If you have material swaps setup on your avatar it should be a one click solution!

Ignored Materials allows you to use a material with a supported shader on a part of your avatar you don't want encrypted. Materials in this list will not be encrypted. Do not add materials to this list that are on parts of your avatar you want to protect.

Custom Bit Key Length

You can change the 'BitKeys Length' under 'Debug' settings. This allows users with fewer parameters to spare to still use Kanna Protecc. However know that using a shorter bit key reduces the security of the encryption. Its recommended that you use as large of a 'BitKeys Length' as possible.

Obfuscator Settings

By default Kanna Protecc Obfuscates all objects, parameter names, and animator layers on a user's avatar. Features of VRChat that users may want to take advantage of. Such as contact senders, OSC integrations, etc, often require specific names to be unaltered to maintain functionality.

Obfuscator

Kanna Protecc allows for exceptions to be added for renaming. For maximum security only add exceptions for parameters that are required to be unaltered. Note that contact parameter names not intended to interact with other avatars will function perfectly fine obfuscated. Physbone parameters also function perfectly obfuscated. Neither need to be added to exceptions.

The Auto Detect buttons try and detect common setups like face tracking or gogoloco that require exclusions! Its a good idea to click them!

Examples for Face tracking and GoGoLoco.

Link Animator

  1. Ensure your VRCAvatarDescriptor has an AnimatorController specified in the 'FX Playable Layer' slot. Ensure there is also an Animator component on this root GameObject, and that its 'Controller' slot points to the same AnimatorController in the 'FX Playable Layer' slot on the VRCAvatarDescriptor.

Steps 2

The AnimatorController you specify should not be shared between multiple avatars, Kanna Protecc is going to write states into the controller which will need to be different for different avatars.

  1. In the 'Parameters' slot of your VRCAvatarDescriptor ensure you have an 'Expression Parameters' object.

Step 3


Delete your old Un-Encrypted Avatar from VRC Backend!

VRC API stores old uploads of your avatar! So if you start uploading an encrypted avatar with an ID that you previously uploaded non-encrypted, it may entirely negate any benefit this provides as rippers can just download an older version that was not encrypted.

  1. Go into the VRChat SDK Inspector in the Unity Editor, then under 'Content Manager' find the avatar you wish to protect and delete it entirely from the VRC backend.
  2. Go to your current avatar's Pipeline Manager component and click the Detach (Optional) button so it will generate a new avatar id on upload.

Encrypting and Uploading

  1. Ensure any meshes you wish to have encrypted are using a compatible shader, such as Poiyomi.
  2. On the KannaProteccRoot component click the 'Protecc Avatar' button. This will produce a garbled version of your avatar with '_KannaProteccted' appended to the name. Step 4 The mesh appearing scrambled is intended behavior.
  3. Go to the VRChat SDK Menu then 'Build and Publish' your avatar which has '_KannaProteccted' appended to the name.

I found some Poi 8/8.1 materials get into a weird state with Lock/Unlock and Kanna Protecc can't lock them. If you get errors that say something like 'Trying to Inject not-locked shader?!' go to the Poi 8/8.1 material it is complaining about and manually click the Lock/Unlock button to get it out of its weird state.


Writing Keys

Ensure VRChat is closed! Otherwise when you write keys VRChat may prevent writing!

  1. This is important. After upload completes, go to the GameObject of your encrypted avatar. Find the Pipeline Manager component and copy it's blueprint ID. Then paste the blueprint ID into the Pipeline Manager on the un-encrypted avatar and click 'Attach'.
  2. Now on the KannaProteccRoot component click the 'Write Keys' button. This will actually read in and alter the saved 3.0 parameters from your VRChat folder to include the new key so you don't have to enter them in-game.
  3. Ensure no errors came up!. It should popup a success dialogue if it did it correctly. If there were issues make sure the 'Vrc Saved Params Path' actually points to your LocalAvatarData folder.

You only need to run 'Write Keys' once on first setup, or when you change keys.

If you "Reset Avatar" in game through the 3.0 menu, it will reset your keys and you will need to re-export them with the 'Write Keys' button!


Un-Encrypting, Editing and Re-uploading Your Avatar

If you wish to see your avatar again as normal and not encrypted, or make changes to your avatar:

  1. Click on your original un-encrypted avatar, where "Encrypted" is not in the name; then select Un-Protecc Avatar.

You should now be able to edit your avatar as normal.

Do not upload the avatar without encrypting it!

  1. Click 'Protecc Avatar' again. Follow the steps in Encrypting and uploading
  2. Writing keys should not be necessary unless you genereated new keys.

Testing the Avatar

Entering play mode will not decrypt the protected avatar on its own. Click here for how to test your avatar in play mode.


Back to Contents


How secure is this?

I will keep transparent here without guiding rippers on how to attack your works. This is not foolproof, but the best you can get at this time. Rip wise, this cannot be currently ripped without a insane amount of work, as ripping compiled shadercode, reversing it back to unity compatible code and also getting hold of the keys would be hell. Hotswap wise, a dedicated enough ripper with experience with mods could hotswap your avatar. This is not immune to that. (Soon to be countered with traps making even that extremely harder to do) You can however put a watermark on your avatar to drive hotswappers into being banned which they wont be able to remove, as the meshes will be encrypted, regardless of hotswap. A hotswap done with the high amount of work i have mentioned here would only get the avatar working normally in game; not in unity.

A typical hotswap will not bypass this. It would take a specialized one.

Support

If you have any more questions, or suggestions, feel free to join the Kanna Protecc discord: https://discord.gg/SyZcuTPXZA

Roadmap

This will let you keep up to date with major features that will take time to implement. This does not act as a changelog, nor will it have every upcoming feature listed. Only time-consuming ones. https://trello.com/b/k88bNBvd/kanna-protecc

Hall Of Shame

Not only does this show they endorse ripping in sars, but also shows he is clueless; even to how this works. Not only does Kanna Protecc not make you lose the original, it also has numerous layers to make re-obtaining your original possible. Not for rippers, however. This screws them over fully.

image

Furthermore, one that not only makes crashers, but is completely clueless. Kanna Protecc doesn't effect any original files of your avatar, with the single exception of changing the shader on your materials; which is easily fixed.

image

People who lied claiming they could bypass this yet would never put their money where their mouth is, or just terrible people in general, such as contributors to the ripping scene.

image

Idiot dev of sars who claims he doesn't endorse ripping, meanwhile majority admins rip and AC outright told someone they can rip any avatar. Even in cool people role has people openly expressing they make and use crashers.

image Proof of admin endorsing it:

Discord_FKMcypHblz.mp4

Member of SARS community panicking at Kanna Protecc existing:

image

Soy boy

image

More Repositories

1

PlagueButtonAPI

The Best VRChat Button API By Plague. - Supports Beta & Non-Beta VRChat.
C#
8
star
2

RealFeel

RealFeel Is A Paid Tool By Plague That Brings Lovense Support Into VRChat Very Nicely, Works Regardless Of The EAC / EasyAntiCheat Update, Global Support & Can Be Used With Your Lovense On Mobile Or PC. To Buy It, Join Here And Read About Such: http://RealFeel.uk
7
star
3

LeashMod

Ever wanted a PROPER leash in VRChat? Here it finally is. With the combination of a mod and avatar objects, you can have a FULLY dynamic, visible to all and functional leash in VRChat, being pulled back, being able to be yanked by your master (or vice versa), being able to be locked somewhere in the world and much, much more!
7
star
4

KannaTools

KannaTools is a bunch of scripts for Unity for use with VRChat avatars. The main use case is for updating an avatar to a new FBX build easier. This solves FBX updates breaking your avatar causing hours of work to remake it on the new FBX.
C#
6
star
5

UniversalFavsExporter

A VRChat MelonLoader/ModpackLoader Mod To Export Any Avatar Favourites List To .json For Importing Into Plagues Modpack, Found At: https://vrcanticrash.com
C#
3
star
6

DBT_API

A C# API for making Unity DBTs (Direct Blend Trees) - These are used as numerous layers is a big performance killer.
C#
2
star
7

AvatarConfigTransfer

A tool to lazily find & transfer local avatar configs.
C#
2
star
8

NoPostProcessing

A Simple Universal MelonLoader Mod To Toggle Post Processing - Supports UIExpansionKit If Present.
C#
2
star
9

GithubModUpdater

A Simple Plugin To Auto Update Mods With A Direct releases/latest/download/filename.dll DownloadLink In The MelonInfo Attribute. Made For PlagueButtonAPI, But Works Globally.
C#
2
star
10

VRCAntiCrash

VRCAntiCrash Is A QoL AntiCrash Mod For MelonLoader Made For VRChat With Many More Features Which Doesn't Kill Your FPS. Server To Get It: https://VRCAntiCrash.com
1
star
11

ModBaseMaker

A Tool For Creating Mods Fast. Creates A Mod Template With Your Name And Your Chosen Mod Name That Is Heavily Modular. Extremely Useful.
C#
1
star
12

ButtonImageChanger

A Mod That Changes The Entire Look Of VRChat's QuickMenu With A Image Of Your Choice, A Plain Black .png Is Nicest IMO.
C#
1
star
13

Bouncer

VRChat Security Mod For Stopping Force Joining, Crashing & More In Events/Clubs.
1
star
14

UnityExplorerHelper_VRC

A Helper Mod To Freeze Controls If UnityExplorer's UI Is Open.
C#
1
star
15

GizmosAPI

A API For Mods To Create Gizmos For Debugging.
C#
1
star
16

VRCAntiCrash_Loader

The Loader For VRCAntiCrash. This Code Is Unlicensed Meaning None Of It May Be Used Elsewhere.
C#
1
star
17

PublicBouncerBlacklist

Public Blacklist For Bouncer: https://bouncer.carrd.co
1
star
18

Kanna-Protecc-OSC

Tool utilizing OSC to automatically fix an avatar that was reset using Kanna Protecc, fixing user error issues mid-game.
C#
1
star