mirror of
https://github.com/SystemRage/py-kms.git
synced 2025-01-25 09:32:00 +08:00
KMS Server Emulator written in Python
activatorclientemulatorgvlkkmsofficepy-kmspythonserverstarred-repostarred-systemrage-repovolume-licensewindows
PreviousVersions | ||
aes.py | ||
CHANGELOG.md | ||
client.py | ||
dcerpc.py | ||
filetimes.py | ||
kmsBase.py | ||
kmsPidGenerator.py | ||
kmsRequestUnknown.py | ||
kmsRequestV4.py | ||
kmsRequestV5.py | ||
kmsRequestV6.py | ||
LICENSE | ||
py-kms-ClientKeys.pdf | ||
py-kms_Guide.pdf | ||
randomHWID.py | ||
randomPID.py | ||
README.md | ||
rpcBase.py | ||
rpcBind.py | ||
rpcRequest.py | ||
server.py | ||
structure.py | ||
timezones.py |
History
py-kms is a port of node-kms by markedsword, which is a port of either the C#, C++, or .NET implementations of KMSEmulator. The original version was written by CODYQX4 and is derived from the reverse-engineered code of Microsoft's official KMS.
Features
- Responds to V4, V5, and V6 KMS requests.
- Supports activating Windows Vista / 7 / 8 / 8.1 / 10 / Server 2008 / Server 2008 R2 / Server 2012 / Server 2012 R2 / Server 2016 / Office 2010 / Office 2013 / Office 2016.
- It's written in Python ( Tested with Python 2.7.8 ).
Dependencies
- Python 2.7.x or "Python 2.6.x with the 'argparse' module installed."
- If the "pytz" module is installed, the "Request Time" in the verbose output will be converted into local time. Otherwise, it will be in UTC.
- It can use the "sqlite3" module so you can use the database function. (it stores activation data so it can be recalled again.) (-s)
- Installation Example on Ubuntu:
- "sudo apt-get install python-pip"
- "sudo pip install pytz"
- "sudo apt-get install python-sqlite" or "sudo pip install pysqlite"
- Installation Example on Ubuntu:
Usage
- To start the server, execute "python server.py [listen_IPADDRESS] [PORT]". The default listen_IPADDRESS is "0.0.0.0" ( all interfaces ) and the default PORT is "1688".
- To run the client, use "python client.py server_IPADDRESS [PORT]". The default PORT is "1688".
- To show the help pages type: "python server.py -h" and "python client.py -h"
- To generate a random HWID type: "python randomHWID.py" or directly in the server ( with -w option ) "python server.py -w random"
- To get the HWID from any server use the client, for example type: "python client.py 0.0.0.0 1688 -m Windows81 -v INFO"
- To generate random EPID type: "python randomPID.py"
Other Important Stuff
- Read "py-kms_Guide.pdf" for more informations about activation with py-kms.
- File "py-kms_ClientKeys.pdf" contains GVLK keys.