As it's named, this project is a keygen of Artifactory from JFrog.
Tested on 7.59.11 (Latest version), 7.9.2 (Latest version on releases-docker)
If you think this project is useful to you please leave a star! Thanks!
ALERT!! YOU SHOULD NEVER USE THIS PROJECT TO CRACK / PATCH / ILLEGAL USE ANY SOFTWARE FROM JFROG
ALERT!! THIS PROJECT IS FOR EDUCATIONAL PURPOSES!
ALERT!! THE CONSEQUENCES CAUSED BY THE USE OF THIS SOFTWARE SHALL BE BORNE BY THE USER
Click for different languages of this file
Table of Contents
Download ArtifactoryKeygen
and ArtifactoryAgent
both from Github Releases
Run ArtifactoryKeygen
with Java 11 or above.
$ java -jar /path/to/ArtifactoryKeygen-1.0-SNAPSHOT-all.jar [sub-command]
Leaving sub-command empty will eventually prompt you to enter a sub-command later
Use thegen
sub-command to generate a license
Of course, the license generated by Keygen cannot be used directly.
You'll need ArtifactoryAgent
to patch some files.
Navigate to Artifactory's Tomcat folder then edit bin/setenv.sh
(It should be named setenv.bat
on Windows)
Add the following line to that file. Don't forget to change the path!
# Linux / macOS(But why macOS??)
CATALINA_OPTS=-javaagent:/path/to/ArtifactoryAgent-1.0-SNAPSHOT-all.jar
:: Windows
SET CATALINA_OPTS=-javaagent:path\to\ArtifactoryAgent-1.0-SNAPSHOT-all.jar
DON'T FORGET: YOU SHOULD NEVER USE Artifactory
ILLEGALLY
Currently, this is not supported. I may add this feature future.
Currently, override the default public key is the only configurable entry.
First, you need to generate a proper configuration using Keygen, although you can do it manually.
Run the keygen with the sub-command 'mkconfig' and then enter your public key.
To be noticed that the public key should be a RSA Public Key in X509 Format and have at least 4096 bits of modulus of the key
Copy the generated text and put it in agent arguments like this:
# Linux
CATALINA_OPTS=-javaagent:/path/to/ArtifactoryAgent-1.0-SNAPSHOT-all.jar=<GeneratedConfigHere>
:: Windows
SET CATALINA_OPTS=-javaagent:/path/to/ArtifactoryAgent-1.0-SNAPSHOT-all.jar=<GeneratedConfigHere>
The configuration should be in hexadecimal format with all letters capitalized
Edit the template below and use Base64 to encode it then convert the encoded result into a hexadecimal string with all letters capitalized.
<config>
<publicKey>Your public key here</publicKey>
</config>
You can get any text hexadecimal-ized by passing your text into the agent (Yes the agent is executable!)
$ java -jar /path/to/ArtifactoryAgent-1.0-SNAPSHOT-all.jar <Text>
Also, you can generate a proper key pair(RSA 4096) with the genkey
sub-command in Keygen
You can retrieve all available sub-commands by using the sub-command 'help'
I'm lazy to write a help again so I copied from the sub-command 'help'
println("""
List of all sub-commands:
obf <text>:
Obfuscate text with JFrog's 'ObfuscatedString' class
pub:
Get the current public key (RSA)
pri:
Get the current private key (RSA)
genkey:
Generate a key pair
gen:
Generate a license with the current private key
verify <license>:
Verify a license with the current public key
enc: [ NOT TESTED ]
Encrypt a license (I guess this is used for the license of the old version)
verifyAgent:
You can verify ArtifactoryAgent by attaching the agent to ArtifactoryKeygen
mkconfig:
Create agent config but friendly!
To inject into artifactory
Open Artifactory's tomcat folder and add the following JVM options to tomcat.
In case you don't know how to pass extra JVM args you can see the README of this project
OR Google it by yourself!
-javaagent:</path/to/this/jar/file>
his will patch class 'org.jfrog.license.api.a'
""".trimIndent())
Compiling the code might be a little different compared to other gradle projects.
You will notice that I've used a library from JFrog which looks like not a public one.
So I decided not to upload it. However, you can extract it from artifactory.war
I assume that you are familiar with web development with Java and SpringFramework. So there will be no tutorial here about how to extract it. If you meet any problem while extracting google first!
After extracting the necessary libraries you should put them into libs
.
If those libraries have changed their version don't forget to update in build.gradle.kts
To compile the code and pack a jar file with all dependencies use the following gradle task
# Root project (Keygen)
$ gradlew :shadowJar
# Agent
$ graldew :ArtifactoryAgent:shadowJar
PRs are always welcome! Thanks for your contributions to this project!
- Code Cleanup
- Add more configurables to both Keygen and Agent
- Artifactory version detection
- Migrate from
artifactory-addons-manager
toLicenseManager
(Which is a de-obfuscated version ofartifactory-addons-manager
) - Chinese version of README.MD