mirror of
https://github.com/wh201906/Proxmark3GUI.git
synced 2025-03-03 13:27:39 +08:00
parent
d60f636881
commit
5a0f0d3e3e
5
deploy/.gitignore
vendored
Normal file
5
deploy/.gitignore
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
/V*-*
|
||||
/V*-*/
|
||||
/32/
|
||||
/64/
|
||||
/client/
|
3
deploy/README.md
Normal file
3
deploy/README.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Deploy helper
|
||||
Just for generating Github release
|
||||
Useless for general users
|
98
deploy/deploy.py
Normal file
98
deploy/deploy.py
Normal file
@ -0,0 +1,98 @@
|
||||
import os, sys, shutil
|
||||
from win32api import GetFileVersionInfo
|
||||
from json import load
|
||||
from re import fullmatch, IGNORECASE
|
||||
|
||||
|
||||
def getPEVersion(fname):
|
||||
try:
|
||||
fileInfo = GetFileVersionInfo(fname, '\\')
|
||||
version = "V%d.%d.%d" % (fileInfo['FileVersionMS'] / 65536,
|
||||
fileInfo['FileVersionMS'] % 65536,
|
||||
fileInfo['FileVersionLS'] / 65536)
|
||||
except Exception:
|
||||
print("Cannot get version number of", fname)
|
||||
return version
|
||||
|
||||
|
||||
os.chdir(sys.path[0])
|
||||
print("Current Directory:", os.getcwd())
|
||||
targetName = os.path.abspath(os.getcwd()).split('\\')[-2]
|
||||
print("Target Name", targetName)
|
||||
|
||||
src32Dir = ""
|
||||
src64Dir = ""
|
||||
dirList = os.listdir("../")
|
||||
|
||||
for i in dirList:
|
||||
if not os.path.isdir("../" + i):
|
||||
continue
|
||||
if not i.startswith("build"):
|
||||
continue
|
||||
|
||||
if i.endswith("32_bit-Release"):
|
||||
src32Dir = "../" + i
|
||||
elif i.endswith("64_bit-Release"):
|
||||
src64Dir = "../" + i
|
||||
|
||||
src32Path = src32Dir + "/release/" + targetName + ".exe"
|
||||
src64Path = src64Dir + "/release/" + targetName + ".exe"
|
||||
print("Target Files:")
|
||||
print(src32Path)
|
||||
print(src64Path)
|
||||
|
||||
ver32 = getPEVersion(src32Path)
|
||||
ver64 = getPEVersion(src64Path)
|
||||
print("Versions:")
|
||||
print("win32:", ver32)
|
||||
print("win64:", ver64)
|
||||
if ver32 != ver64:
|
||||
print("WARNING!")
|
||||
print("Version names are not the same!")
|
||||
dst32Dir = "./" + ver32 + "-win32"
|
||||
dst64Dir = "./" + ver64 + "-win64"
|
||||
dst32Path = dst32Dir + "/" + targetName + ".exe"
|
||||
dst64Path = dst64Dir + "/" + targetName + ".exe"
|
||||
|
||||
if os.path.exists(dst32Dir) and os.path.exists(dst32Path):
|
||||
print(dst32Path, "exists, replacing...")
|
||||
os.remove(dst32Path)
|
||||
elif not os.path.exists(dst32Dir):
|
||||
print(dst32Dir, "doesn't exist, creating...")
|
||||
shutil.copytree("./32", dst32Dir)
|
||||
shutil.copyfile(src32Path, dst32Path)
|
||||
configPath = dst32Dir + "/config"
|
||||
if os.path.exists(configPath):
|
||||
print(configPath, "exists, replacing...")
|
||||
shutil.rmtree(configPath)
|
||||
shutil.copytree("../config", configPath)
|
||||
|
||||
if os.path.exists(dst64Dir) and os.path.exists(dst64Path):
|
||||
print(dst64Path, "exists, replacing...")
|
||||
os.remove(dst64Path)
|
||||
elif not os.path.exists(dst64Dir):
|
||||
print(dst64Dir, "doesn't exist, creating...")
|
||||
shutil.copytree("./64", dst64Dir)
|
||||
shutil.copyfile(src64Path, dst64Path)
|
||||
configPath = dst64Dir + "/config"
|
||||
if os.path.exists(configPath):
|
||||
print(configPath, "exists, replacing...")
|
||||
shutil.rmtree(configPath)
|
||||
shutil.copytree("../config", configPath)
|
||||
|
||||
# TODO: GUI+client
|
||||
|
||||
use7z = input("Compress?(y/N)")
|
||||
if fullmatch("yes|y", use7z, IGNORECASE):
|
||||
archive32Path = dst32Dir + ".7z"
|
||||
archive64Path = dst64Dir + ".7z"
|
||||
|
||||
if os.path.exists(archive32Path):
|
||||
print(archive32Path, "exists, replacing...")
|
||||
os.remove(archive32Path)
|
||||
os.system("7z a -t7z -mmt8 -mx9 " + archive32Path + " " + dst32Dir)
|
||||
|
||||
if os.path.exists(archive64Path):
|
||||
print(archive64Path, "exists, replacing...")
|
||||
os.remove(archive64Path)
|
||||
os.system("7z a -t7z -mmt8 -mx9 " + archive64Path + " " + dst64Dir)
|
@ -27,10 +27,10 @@
|
||||
(4) Go to "Settings" panel. Input the config file path which matching the client you use.
|
||||
data:image/s3,"s3://crabby-images/2d15d/2d15d65a82941406aa852b77a71250d3d7e233d2" alt=""
|
||||
|
||||
(5) If setup.bat is required, input the script path in the "Preload script path" editbox.
|
||||
(5) If setup.bat is required, input the script path in the "Preload script path" editbox.
|
||||
data:image/s3,"s3://crabby-images/642a9/642a9e46da2ad65f6c0ea059b464499bc6e60efd" alt=""
|
||||
|
||||
(6) If using RRG/Iceman repo, input "-p \<port\> -f" in the "Start arguments" editbox.
|
||||
(6) If using RRG/Iceman repo, input "-p \<port\> -f" in the "Start arguments" editbox.
|
||||
data:image/s3,"s3://crabby-images/e1879/e1879deb4c58e1fa46cb876fb53ad57c41c5bd80" alt=""
|
||||
|
||||
***
|
||||
|
@ -715,7 +715,7 @@ void MainWindow::on_MF_File_clearButton_clicked()
|
||||
mifare->data_clearKey();
|
||||
mifare->data_syncWithKeyWidget();
|
||||
}
|
||||
else if(ui->MF_File_keyButton->isChecked())
|
||||
else if(ui->MF_File_dataButton->isChecked())
|
||||
{
|
||||
mifare->data_clearData();
|
||||
mifare->data_syncWithDataWidget();
|
||||
|
Loading…
x
Reference in New Issue
Block a user