vlmcs.1.dos.txt 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  1. VLMCS(1) KMS Activation Manual VLMCS(1)
  2. NAME
  3. vlmcs - a client for testing and/or charging KMS servers
  4. SYNOPSIS
  5. vlmcs [ options ] [ target ] [ options ]
  6. target can be one of the following:
  7. hostname|ipaddress[:tcp-port] or to query a specific KMS server
  8. (example: vlmcs kms.example.com:1688).
  9. .domain to automatically detect KMS servers via DNS for domain
  10. (example: vlmcs .example.com). Please note the dot before
  11. domain.
  12. - (a single dash) to detect KMS servers in your own domain.
  13. If you use ipaddress:port as the target, the ipaddress must be enclosed
  14. in brackets if it contains colons, e.g. [2001:db8:dead:beef::1]:1688.
  15. If you use a link-local IPv6 address on Unix systems, you must append a
  16. percent sign and the interface identifier of the source interface, for
  17. example fe80::dead:beef%eth0.
  18. If you omit the target, 127.0.0.1:1688 will be used except if you use
  19. -i6. In this case the default target is [::1]:1688.
  20. DESCRIPTION
  21. vlmcs is a program that can be used to test a KMS server that provides
  22. activation for several Microsoft products. The KMS server may also be
  23. an emulator. It supports KMS protocol versions 4, 5 and 6.
  24. vlmcs generates one or more activation requests for a Microsoft KMS
  25. product and sends it to a KMS server. It then analyzes and displays the
  26. responses of the KMS server.
  27. vlcms checks both the DCE-RPC protocol and the activation message for
  28. correctness and reports any errors that it finds.
  29. vlmcs can also be used to "charge" a KMS server. A Microsoft KMS server
  30. sends correct activation messages only if it detects a certain minimum
  31. of clients (25 for Windows client OSses, 5 otherwise) on the network.
  32. This is Microsoft's futile attempt to prevent running a KMS server in a
  33. home environment.
  34. OPTIONS
  35. -h or -?
  36. Show help.
  37. -x Show valid applications that can be used with -l.
  38. -e Show some examples how to use vlmcs correctly.
  39. -v Be verbose. Instead of just displaying the returned ePID and the
  40. HwId (protocol v6 only) vlmcsd shows all details of the query
  41. and the response.
  42. -l application
  43. Request activation for a specific application. Valid applica‐
  44. tions can be displayed by using -x. The default application is
  45. Windows Vista Business. The list of available applications is
  46. not complete. You may supply GUIDs with -a, -k and -s to specify
  47. applications that are not listed with -x. The -l option is used
  48. as a shortcut for the most common applications.
  49. -4, -5 and -6
  50. Force version 4, 5 or 6 of the KMS protocol. The default is to
  51. select a suitable version according to the application selected.
  52. Plese note that some products (e.g. Office 2013) may use differ‐
  53. ent protocols with different versions of Windows.
  54. -m Let the client pretend to be a virtual machine. Early versions
  55. of Microsoft's KMS server did not increase the client count if
  56. the request came from a virtual machine. Newer versions ignore
  57. this flag.
  58. -d Use NetBIOS names instead of DNS names. By default vlmcsd gener‐
  59. ates some random DNS names for each request. If you prefer Net‐
  60. BIOS names, you may use -d. A real Microsoft activation client
  61. uses DNS names or NetBIOS depending on the client name configu‐
  62. ration. KMS servers treat the workstation name as a comment that
  63. affects logging only. Clients will be identified by a GUID that
  64. can be specified using -c. -d has no effect if you also specify
  65. -w.
  66. -a application-guid
  67. Send requests with a specific application-guid. There are cur‐
  68. rently only three known valid application-guids:
  69. 55c92734-d682-4d71-983e-d6ec3f16059f (Windows)
  70. 59a52881-a989-479d-af46-f275c6370663 (Office 2010)
  71. 0ff1ce15-a989-479d-af46-f275c6370663 (Office 2013)
  72. A Microsoft KMS server uses these GUIDs to have seperate coun‐
  73. ters for the already activated clients. A client that does not
  74. contact the KMS server within 30 days will be deleted from the
  75. database. Emulated KMS servers are always fully charged.
  76. -k kms-guid
  77. Send requests with a specific kms-guid. A Microsoft KMS server
  78. uses these GUIDs as a product id to decide whether to grant
  79. activation or not. A list of current kms-guids can be found in
  80. kms.c (table KmsIdList). Emulated KMS servers grant activation
  81. unconditionally and do not check the kms-guid.
  82. -s activation-guid
  83. The activation-guid defines the actual product, e.g. "Windows
  84. 8.1 Professional WMC KMSCLIENT edition". A activation-guid maps
  85. 1:1 to a product key. However, neither a Microsoft KMS server
  86. nor emulated servers check this id. The activation-guid is use‐
  87. ful in logging to get a specific product description like "Win‐
  88. dows 8.1 Professional WMC". A list of current activation-guids
  89. can be found in kms.c (table ExtendedProductList).
  90. -n requests
  91. Send requests requests to the server. The default is to send at
  92. least one request and enough subsequent requests that the server
  93. is fully charged afterwards for the application-guid you
  94. selected (explicitly with -a or implicitly by using -l).
  95. -T Causes to use a new TCP connection for each request if multiple
  96. requests are sent with vlmcsd. This is useful when you want to
  97. test an emulated KMS server whether it suffers from memory
  98. leaks. To test for memory leaks use -n with a large number of
  99. requests (> 100000) and then test twice (with and without -T).
  100. This option may become neccessary for future versions of Micro‐
  101. soft's KMS server because multiple requests with different
  102. clients-guids for the same kms-id-guid are impossible in a real
  103. KMS szenario over the same TCP connection.
  104. -c client-machine-guid
  105. Normally vlmcs generates a random client-machine-guid for each
  106. request. By using this option you can specify a fixed client-
  107. machine-guid This causes a Microsoft KMS not to increment its
  108. client count because it receives multiple requests for the same
  109. client. Thus do not use -c if you want to charge a real KMS
  110. server.
  111. -o previous-client-machine-guid
  112. If the client-machine-guid changes for some reason, the real KMS
  113. client stores a previous-client-machine-guid which is sent to
  114. the KMS server. This happens rarely and usually
  115. 00000000-0000-0000-0000-000000000000 is used. You can use -o to
  116. specify a different previous-client-machine-guid.
  117. -G filename
  118. Grabs ePIDs and HWIDs from a KMS server and writes the informa‐
  119. tion to filename in format suitable to be used as a configura‐
  120. tion file (aka ini file) for vlmcsd(8). This is especially use‐
  121. ful if you have access to a genuine KMS server and want to use
  122. the same data with vlmcsd(8).
  123. If filename does not exist, it will be created. If you specify
  124. an existing filename, it will be updated to use the information
  125. received from the remote KMS server and a backup filename~ will
  126. be created.
  127. -G cannot be used with -l, -4, -5, -6, -a, -s, -k, -r and -n
  128. -w workstation-name
  129. Send requests with a specific workstation-name. This disables
  130. the random generator for the workstation name. Since it is a
  131. comment only, this option does not have much effect.
  132. -r required-client-count
  133. Also known as the "N count policy". Tells the KMS server that
  134. successful activation requires required-client-count clients.
  135. The default is the required-client-count that the product would
  136. need if the request was a real activation. A Microsoft KMS
  137. server counts clients up to the double amount what was specified
  138. with -r. This option can be used to "overcharge" a Microsoft KMS
  139. server.
  140. -t status
  141. Reports a specific license status to the KMS server. status is a
  142. number that can be from 0 to 6. 0=unlicensed, 1=licensed, 2=OOB
  143. grace, 3=OOT grace, 4=Non-genuinue grace, 5=notification,
  144. 6=extended grace. Refer to TechNet ⟨http://
  145. technet.microsoft.com/en-us/library/ff686879.aspx#_Toc257201371⟩
  146. for more information. A Microsoft KMS server collects this
  147. information for statistics only.
  148. -g binding-expiration
  149. This tells the KMS server how long a client will stay in its
  150. current license status. This can be the remaining OOB time (the
  151. grace peroid that is granted between installation of a product
  152. and when activation is actuall required) or the remaining time
  153. when KMS activation must be renewed. binding-expiration is
  154. specified in minutes. A Microsoft KMS server apparantly does not
  155. use this information.
  156. -i protocol-version
  157. Force the use of Internet protocol protocol-version. Allowed
  158. values are 4 (IPv4) and 6 (IPv6). This option is useful only if
  159. you specfiy a hostname and not an ip-address on the command
  160. line.
  161. -p Do not set the RPC_PF_MULTIPLEX flag in the RPC bind request.
  162. This can be used to test if the KMS server uses the same setting
  163. of this flag in the RPC bind respone. Some KMS emulators don't
  164. set this correctly.
  165. -N0 and -N1
  166. Disables (-N0) or enables (-N1) the NDR64 transfer syntax in the
  167. RPC protocol. Disable NDR64 only in case of problems. If NDR64
  168. is not used, vlmcs cannot detect many RPC protocol errors in KMS
  169. emulators. If you want to test whether a KMS emulator fully sup‐
  170. ports NDR64, you must use the -n option to send at least two
  171. requests. This is because Microsoft's client always sends the
  172. first request using NDR32 syntax and subsequent requests using
  173. NDR64 syntax.
  174. -B0 and -B1
  175. Disables (-B0) or enables (-B1) bind time feature negotiation
  176. (BTFN) in the RPC protocol. Disable BTFN only in case of prob‐
  177. lems. If BTFN is not used, vlmcs cannot detect many RPC protocol
  178. errors in KMS emulators.
  179. Options that do not require an argument can be specified together with
  180. a single dash, e.g. vlmcs -6mvT. If you specify an option more than
  181. once, the last occurence will be in effect.
  182. FILES
  183. vlmcsd.ini(5)
  184. EXAMPLES
  185. vlmcs kms.example.com
  186. Request activation for Windows Vista using v4 protocol from
  187. kms.example.com. Repeat activation requests until server is
  188. charged for all Windows products.
  189. vlmcs -
  190. Request activation for Windows Vista using v4 protocol from a
  191. KMS server that is published via DNS for the current domain.
  192. vlmcs .example.com
  193. Request activation for Windows Vista using v4 protocol from a
  194. KMS server that is published via DNS for domain example.com.
  195. vlmcs -6 -l Office2013 -v -n 1
  196. Request exactly one activation for Office2013 using v6 protocol
  197. from localhost. Display verbose results.
  198. vlmcs kms.bigcompany.com -G /etc/vlmcsd.ini
  199. Get ePIDs and HWIDs from kms.bigcompany.com and create/update
  200. /etc/vlmcsd.ini accordingly.
  201. BUGS
  202. Some platforms (e.g. Solaris) may have a man(7) system that does not
  203. handle URLs. URLs may be omitted in the documentation on those plat‐
  204. forms. Cygwin, Linux, FreeBSD and Mac OS X are known to work correctly.
  205. AUTHOR
  206. Written by Hotbird64
  207. CREDITS
  208. Thanks to CODYQX4, crony12, deagles, DougQaid, eIcn, mikmik38, nos‐
  209. ferati87, qad, Ratiborus, vityan666, ...
  210. SEE ALSO
  211. vlmcsd(7), vlmcsd(8), vlmcsdmulti(1)
  212. Hotbird64 February 2015 VLMCS(1)