KMS Server Emulator written in Python
Find a file
2018-02-28 23:16:02 +01:00
wiki Update GVLK.md 2018-02-21 00:11:08 +01:00
CHANGELOG.md modified changelog 2017-06-14 23:43:01 +02:00
kmsRequestV6.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
LICENSE Create LICENSE 2017-06-14 23:57:16 +02:00
py-kms-ClientKeys.pdf Upload pdf files 2017-06-18 22:38:55 +02:00
py-kms_Guide.pdf Upload pdf files 2017-06-18 22:38:55 +02:00
randomHWID.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
randomPID.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
README.md Update README.md 2018-02-20 23:20:55 +01:00
rpcBase.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
rpcBind.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
rpcRequest.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
server.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
structure.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00
timezones.py Uploaded py-kms_2017-06-01 2017-06-14 23:08:03 +02:00

History

py-kms is a port of node-kms created by cyrozap, which is a port of either the C#, C++, or .NET implementations of KMS Emulator. 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
    • Windows 7
    • Windows 8
    • Windows 8.1
    • Windows 10 ( 1511 / 1607 / 1703 / 1709 )
    • Windows Server 2008
    • Windows Server 2008 R2
    • Windows Server 2012
    • Windows Server 2012 R2
    • Windows Server 2016
    • Microsoft Office 2010 ( Volume License )
    • Microsoft Office 2013 ( Volume License )
    • Microsoft Office 2016 ( Volume License )
  • It's written in Python:
    • py2-kms tested with Python 2.7.12
    • py3-kms tested with Python 3.5.2

Dependencies

  • Python 3.x or 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"

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.

License

License