2018-08-11 00:15:04 +02:00
|
|
|
<?php
|
|
|
|
/*
|
2020-05-07 19:42:14 +02:00
|
|
|
Copyright 2020 whatever127
|
2018-08-11 00:15:04 +02:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
function uupApiPrintBrand() {
|
|
|
|
global $uupApiBrandPrinted;
|
|
|
|
|
|
|
|
if(!isset($uupApiBrandPrinted)) {
|
|
|
|
consoleLogger('UUP dump API v'.uupApiVersion());
|
|
|
|
$uupApiBrandPrinted = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function randStr($length = 4) {
|
|
|
|
$characters = '0123456789abcdef';
|
|
|
|
$charactersLength = strlen($characters);
|
|
|
|
$randomString = '';
|
|
|
|
for ($i = 0; $i < $length; $i++) {
|
|
|
|
$randomString .= $characters[rand(0, $charactersLength - 1)];
|
|
|
|
}
|
|
|
|
return $randomString;
|
|
|
|
}
|
|
|
|
|
2018-12-13 21:19:51 +01:00
|
|
|
function genUUID() {
|
|
|
|
return sprintf('%04x%04x-%04x-%04x-%04x-%04x%04x%04x',
|
|
|
|
rand(0, 0xffff),
|
|
|
|
rand(0, 0xffff),
|
|
|
|
|
|
|
|
rand(0, 0xffff),
|
|
|
|
|
|
|
|
rand(0, 0x0fff) | 0x4000,
|
|
|
|
|
|
|
|
rand(0, 0x3fff) | 0x8000,
|
|
|
|
|
|
|
|
rand(0, 0xffff),
|
|
|
|
rand(0, 0xffff),
|
|
|
|
rand(0, 0xffff)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-08-11 00:15:04 +02:00
|
|
|
function sendWuPostRequest($url, $postData) {
|
|
|
|
$req = curl_init($url);
|
|
|
|
|
2021-07-01 17:44:04 +02:00
|
|
|
$proxy = uupDumpApiGetConfig();
|
2019-07-27 19:43:02 +02:00
|
|
|
if(isset($proxy['proxy'])) {
|
|
|
|
curl_setopt($req, CURLOPT_PROXY, $proxy['proxy']);
|
|
|
|
}
|
|
|
|
|
2018-08-11 00:15:04 +02:00
|
|
|
curl_setopt($req, CURLOPT_HEADER, 0);
|
|
|
|
curl_setopt($req, CURLOPT_POST, 1);
|
|
|
|
curl_setopt($req, CURLOPT_RETURNTRANSFER, 1);
|
|
|
|
curl_setopt($req, CURLOPT_ENCODING, '');
|
|
|
|
curl_setopt($req, CURLOPT_POSTFIELDS, $postData);
|
|
|
|
curl_setopt($req, CURLOPT_SSL_VERIFYPEER, 0);
|
|
|
|
curl_setopt($req, CURLOPT_HTTPHEADER, array(
|
2021-10-08 20:57:13 +03:00
|
|
|
'User-Agent: Windows-Update-Agent/10.0.10011.16384 Client-Protocol/2.50',
|
2018-08-11 00:15:04 +02:00
|
|
|
'Content-Type: application/soap+xml; charset=utf-8',
|
|
|
|
));
|
|
|
|
|
|
|
|
$out = curl_exec($req);
|
2020-05-07 19:42:14 +02:00
|
|
|
$error = curl_getinfo($req, CURLINFO_RESPONSE_CODE);
|
|
|
|
|
2018-08-11 00:15:04 +02:00
|
|
|
curl_close($req);
|
|
|
|
|
2020-05-07 19:42:14 +02:00
|
|
|
/*
|
|
|
|
Replace an expired cookie with a new one by replacing it in existing
|
|
|
|
postData. This has to be done this way, because handling it properly would
|
|
|
|
most likely require a rewrite of half of the project.
|
|
|
|
*/
|
|
|
|
if($error == 500 && preg_match('/<ErrorCode>(ConfigChanged|CookieExpired)<\/ErrorCode>/', $out)) {
|
|
|
|
$oldCookie = uupEncryptedData();
|
|
|
|
@unlink(dirname(__FILE__).'/cookie.json');
|
|
|
|
$postData = str_replace($oldCookie, uupEncryptedData(), $postData);
|
|
|
|
|
|
|
|
return sendWuPostRequest($url, $postData);
|
|
|
|
}
|
|
|
|
|
2018-08-11 00:15:04 +02:00
|
|
|
$outDecoded = html_entity_decode($out);
|
2018-12-13 21:19:51 +01:00
|
|
|
preg_match('/<NewCookie>.*?<\/NewCookie>|<GetCookieResult>.*?<\/GetCookieResult>/', $outDecoded, $cookieData);
|
2018-08-11 00:15:04 +02:00
|
|
|
|
|
|
|
if(!empty($cookieData)) {
|
|
|
|
preg_match('/<Expiration>.*<\/Expiration>/', $cookieData[0], $expirationDate);
|
|
|
|
preg_match('/<EncryptedData>.*<\/EncryptedData>/', $cookieData[0], $encryptedData);
|
|
|
|
|
|
|
|
$expirationDate = preg_replace('/<Expiration>|<\/Expiration>/', '', $expirationDate[0]);
|
|
|
|
$encryptedData = preg_replace('/<EncryptedData>|<\/EncryptedData>/', '', $encryptedData[0]);
|
|
|
|
|
|
|
|
$fileData = array(
|
|
|
|
'expirationDate' => $expirationDate,
|
|
|
|
'encryptedData' => $encryptedData,
|
|
|
|
);
|
|
|
|
|
|
|
|
@file_put_contents(dirname(__FILE__).'/cookie.json', json_encode($fileData));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
function consoleLogger($message, $showTime = 1) {
|
|
|
|
if(php_sapi_name() != 'cli') return
|
|
|
|
$currTime = '';
|
|
|
|
if($showTime) {
|
|
|
|
$currTime = '['.date('Y-m-d H:i:s T', time()).'] ';
|
|
|
|
}
|
|
|
|
|
|
|
|
$msg = $currTime.$message;
|
|
|
|
fwrite(STDERR, $msg."\n");
|
|
|
|
}
|
2019-07-27 19:43:02 +02:00
|
|
|
|
2021-07-01 17:44:04 +02:00
|
|
|
function uupDumpApiGetConfig() {
|
|
|
|
if(!file_exists('config.ini')) {
|
2019-07-27 19:43:02 +02:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2021-07-01 17:44:04 +02:00
|
|
|
return parse_ini_file('config.ini');
|
2019-07-27 19:43:02 +02:00
|
|
|
}
|
2019-09-14 17:26:57 +02:00
|
|
|
|
|
|
|
function uupApiCheckUpdateId($updateId) {
|
|
|
|
return preg_match(
|
|
|
|
'/^[\da-fA-F]{8}-([\da-fA-F]{4}-){3}[\da-fA-F]{12}(_rev\.\d+)?$/',
|
|
|
|
$updateId
|
|
|
|
);
|
|
|
|
}
|