Compare commits
67 Commits
b9083d4698
...
1.10.1224
Author | SHA1 | Date | |
---|---|---|---|
de2929896d | |||
58e341082d | |||
f9d4256679 | |||
cf94bf3d1d | |||
a0b895438c | |||
438e2b9de7 | |||
825aa46fae | |||
d39a16cab8 | |||
e1623ab184 | |||
6689d8110f | |||
392b6c94b5 | |||
8cd5fc28e4 | |||
428854f25a | |||
63b9c7935b | |||
9899395cf9 | |||
7e461db7a9 | |||
f90b10f948 | |||
53f1d4e8f4 | |||
217a73182a | |||
a3f3604a1f | |||
41391b0ef1 | |||
3965844b6b | |||
b633fac5a0 | |||
4e841301f7 | |||
ad59c3ba00 | |||
5c06db3681 | |||
94558d32a9 | |||
b8b9b5f8f7 | |||
53124ed7c4 | |||
0fbdcb826a | |||
448d09ca4a | |||
80c29c4f11 | |||
f09e6eed0d | |||
4c89488950 | |||
d1a822fff0 | |||
8fa6e6374f | |||
35406026f0 | |||
607589d44a | |||
858e9f07fe | |||
c0ae2d2b75 | |||
0c8627fe97 | |||
c157154b1c | |||
e4774abf19 | |||
2aa9f907b5 | |||
7b1e543428 | |||
aa84a5ad79 | |||
6f83fc7162 | |||
00a9436dad | |||
b82bd6d9e7 | |||
e5d86f1f90 | |||
6173a653f9 | |||
b70400b456 | |||
4060a92a0e | |||
980c5a9010 | |||
8d657f7c09 | |||
4574f1416e | |||
e25bc154ea | |||
bc8dd7fe6d | |||
9667bf0690 | |||
c87ba4493d | |||
101a2167b6 | |||
b6555974ea | |||
357cae2d2a | |||
7aa3cd75fe | |||
2601b7b0ce | |||
0b9eec8d1d | |||
7b4226c704 |
516
.idea/workspace.xml
generated
@ -4,11 +4,15 @@
|
|||||||
<option name="autoReloadType" value="SELECTIVE" />
|
<option name="autoReloadType" value="SELECTIVE" />
|
||||||
</component>
|
</component>
|
||||||
<component name="ChangeListManager">
|
<component name="ChangeListManager">
|
||||||
<list default="true" id="940e1630-c825-4d4c-be80-bc11f543c122" name="Changes" comment="add Label Interface and Peer to new FrameWidget one and two. when import Tunnel then add to list works and remove of list when Tunnel delete.(with Label active on and off) add to class and methods open a avtive Tunnel when Wire-Py open, when import and start a Tunnel">
|
<list default="true" id="940e1630-c825-4d4c-be80-bc11f543c122" name="Changes" comment="Fix msg_window and remove x , y argument Install further adapted and with colored text if user is not in group sudo or wheel. Added to install Opensuse for installation">
|
||||||
<change afterPath="$PROJECT_DIR$/dict_to_address" afterDir="false" />
|
<change afterPath="$PROJECT_DIR$/settings" afterDir="false" />
|
||||||
|
<change afterPath="$PROJECT_DIR$/theme" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/main.py" beforeDir="false" afterPath="$PROJECT_DIR$/main.py" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/Changelog" beforeDir="false" afterPath="$PROJECT_DIR$/Changelog" afterDir="false" />
|
||||||
|
<change beforePath="$PROJECT_DIR$/install" beforeDir="false" afterPath="$PROJECT_DIR$/install" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/wg_func.py" beforeDir="false" afterPath="$PROJECT_DIR$/wg_func.py" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/wg_func.py" beforeDir="false" afterPath="$PROJECT_DIR$/wg_func.py" afterDir="false" />
|
||||||
|
<change beforePath="$PROJECT_DIR$/wg_main.py" beforeDir="false" afterPath="$PROJECT_DIR$/wg_main.py" afterDir="false" />
|
||||||
|
<change beforePath="$PROJECT_DIR$/wire-py1.10.0424.tar.gz" beforeDir="false" />
|
||||||
</list>
|
</list>
|
||||||
<option name="SHOW_DIALOG" value="false" />
|
<option name="SHOW_DIALOG" value="false" />
|
||||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||||
@ -29,6 +33,7 @@
|
|||||||
</map>
|
</map>
|
||||||
</option>
|
</option>
|
||||||
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
|
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
|
||||||
|
<option name="UPDATE_TYPE" value="REBASE" />
|
||||||
</component>
|
</component>
|
||||||
<component name="ProjectColorInfo">{
|
<component name="ProjectColorInfo">{
|
||||||
"associatedIndex": 3
|
"associatedIndex": 3
|
||||||
@ -44,15 +49,31 @@
|
|||||||
<component name="PropertiesComponent">{
|
<component name="PropertiesComponent">{
|
||||||
"keyToString": {
|
"keyToString": {
|
||||||
"ASKED_ADD_EXTERNAL_FILES": "true",
|
"ASKED_ADD_EXTERNAL_FILES": "true",
|
||||||
|
"Python.INSTALL.executor": "Run",
|
||||||
|
"Python.install.executor": "Run",
|
||||||
"Python.main.executor": "Run",
|
"Python.main.executor": "Run",
|
||||||
|
"Python.messagebox.executor": "Run",
|
||||||
|
"Python.start_wg.executor": "Run",
|
||||||
|
"Python.wg_func.executor": "Run",
|
||||||
|
"Python.wg_main.executor": "Run",
|
||||||
"RunOnceActivity.ShowReadmeOnStart": "true",
|
"RunOnceActivity.ShowReadmeOnStart": "true",
|
||||||
|
"Shell Script.install.executor": "Run",
|
||||||
"git-widget-placeholder": "main",
|
"git-widget-placeholder": "main",
|
||||||
"last_opened_file_path": "/home/punix/Pyapps/wire-py",
|
"last_opened_file_path": "/home/punix/Pyapps/wire-py",
|
||||||
"settings.editor.selected.configurable": "preferences.lookFeel"
|
"settings.editor.selected.configurable": "preferences.lookFeel"
|
||||||
}
|
}
|
||||||
}</component>
|
}</component>
|
||||||
<component name="RunManager">
|
<component name="RecentsManager">
|
||||||
<configuration name="main" type="PythonConfigurationType" factoryName="Python" nameIsGenerated="true">
|
<key name="CopyFile.RECENT_KEYS">
|
||||||
|
<recent name="$PROJECT_DIR$" />
|
||||||
|
</key>
|
||||||
|
<key name="MoveFile.RECENT_KEYS">
|
||||||
|
<recent name="$PROJECT_DIR$" />
|
||||||
|
<recent name="$PROJECT_DIR$/wire-py" />
|
||||||
|
</key>
|
||||||
|
</component>
|
||||||
|
<component name="RunManager" selected="Python.wg_main">
|
||||||
|
<configuration name="start_wg" type="PythonConfigurationType" factoryName="Python" temporary="true" nameIsGenerated="true">
|
||||||
<module name="wire-py" />
|
<module name="wire-py" />
|
||||||
<option name="ENV_FILES" value="" />
|
<option name="ENV_FILES" value="" />
|
||||||
<option name="INTERPRETER_OPTIONS" value="" />
|
<option name="INTERPRETER_OPTIONS" value="" />
|
||||||
@ -65,7 +86,7 @@
|
|||||||
<option name="IS_MODULE_SDK" value="true" />
|
<option name="IS_MODULE_SDK" value="true" />
|
||||||
<option name="ADD_CONTENT_ROOTS" value="true" />
|
<option name="ADD_CONTENT_ROOTS" value="true" />
|
||||||
<option name="ADD_SOURCE_ROOTS" value="true" />
|
<option name="ADD_SOURCE_ROOTS" value="true" />
|
||||||
<option name="SCRIPT_NAME" value="$PROJECT_DIR$/main.py" />
|
<option name="SCRIPT_NAME" value="$PROJECT_DIR$/start_wg.py" />
|
||||||
<option name="PARAMETERS" value="" />
|
<option name="PARAMETERS" value="" />
|
||||||
<option name="SHOW_COMMAND_LINE" value="false" />
|
<option name="SHOW_COMMAND_LINE" value="false" />
|
||||||
<option name="EMULATE_TERMINAL" value="false" />
|
<option name="EMULATE_TERMINAL" value="false" />
|
||||||
@ -74,11 +95,38 @@
|
|||||||
<option name="INPUT_FILE" value="" />
|
<option name="INPUT_FILE" value="" />
|
||||||
<method v="2" />
|
<method v="2" />
|
||||||
</configuration>
|
</configuration>
|
||||||
|
<configuration name="wg_main" type="PythonConfigurationType" factoryName="Python" nameIsGenerated="true">
|
||||||
|
<module name="wire-py" />
|
||||||
|
<option name="ENV_FILES" value="" />
|
||||||
|
<option name="INTERPRETER_OPTIONS" value="" />
|
||||||
|
<option name="PARENT_ENVS" value="true" />
|
||||||
|
<envs>
|
||||||
|
<env name="PYTHONUNBUFFERED" value="1" />
|
||||||
|
</envs>
|
||||||
|
<option name="SDK_HOME" value="" />
|
||||||
|
<option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
|
||||||
|
<option name="IS_MODULE_SDK" value="true" />
|
||||||
|
<option name="ADD_CONTENT_ROOTS" value="true" />
|
||||||
|
<option name="ADD_SOURCE_ROOTS" value="true" />
|
||||||
|
<option name="SCRIPT_NAME" value="$PROJECT_DIR$/wg_main.py" />
|
||||||
|
<option name="PARAMETERS" value="" />
|
||||||
|
<option name="SHOW_COMMAND_LINE" value="false" />
|
||||||
|
<option name="EMULATE_TERMINAL" value="false" />
|
||||||
|
<option name="MODULE_MODE" value="false" />
|
||||||
|
<option name="REDIRECT_INPUT" value="false" />
|
||||||
|
<option name="INPUT_FILE" value="" />
|
||||||
|
<method v="2" />
|
||||||
|
</configuration>
|
||||||
|
<recent_temporary>
|
||||||
|
<list>
|
||||||
|
<item itemvalue="Python.start_wg" />
|
||||||
|
</list>
|
||||||
|
</recent_temporary>
|
||||||
</component>
|
</component>
|
||||||
<component name="SharedIndexes">
|
<component name="SharedIndexes">
|
||||||
<attachedChunks>
|
<attachedChunks>
|
||||||
<set>
|
<set>
|
||||||
<option value="bundled-python-sdk-8336bb23522e-31b6be0877a2-com.jetbrains.pycharm.community.sharedIndexes.bundled-PC-241.19072.16" />
|
<option value="bundled-python-sdk-0e3be3396995-c546a90a8094-com.jetbrains.pycharm.community.sharedIndexes.bundled-PC-242.23339.19" />
|
||||||
</set>
|
</set>
|
||||||
</attachedChunks>
|
</attachedChunks>
|
||||||
</component>
|
</component>
|
||||||
@ -91,66 +139,410 @@
|
|||||||
<option name="presentableId" value="Default" />
|
<option name="presentableId" value="Default" />
|
||||||
<updated>1723279982210</updated>
|
<updated>1723279982210</updated>
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00001" summary="Tunnel Start and Stop Work">
|
<task id="LOCAL-00009" summary="add Class StartStopBTN to wg_func.py">
|
||||||
<option name="closed" value="true" />
|
<option name="closed" value="true" />
|
||||||
<created>1723666001005</created>
|
<created>1724237471056</created>
|
||||||
<option name="number" value="00001" />
|
<option name="number" value="00009" />
|
||||||
<option name="presentableId" value="LOCAL-00001" />
|
<option name="presentableId" value="LOCAL-00009" />
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1723666001005</updated>
|
<updated>1724237471056</updated>
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00002" summary="Tunnel Start and Stop Work">
|
<task id="LOCAL-00010" summary="Set Style to Clam Improved layout of widgets">
|
||||||
<option name="closed" value="true" />
|
<option name="closed" value="true" />
|
||||||
<created>1723666477079</created>
|
<created>1724272761629</created>
|
||||||
<option name="number" value="00002" />
|
<option name="number" value="00010" />
|
||||||
<option name="presentableId" value="LOCAL-00002" />
|
<option name="presentableId" value="LOCAL-00010" />
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1723666477079</updated>
|
<updated>1724272761629</updated>
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00003" summary="wg_import_select in wg_func.py extended">
|
<task id="LOCAL-00011" summary="Remove open file function, add Show Address Labels with tk.StrVar when remove a not active Tunnel Labels of Active Tunnel removed!">
|
||||||
<option name="closed" value="true" />
|
<option name="closed" value="true" />
|
||||||
<created>1723847456806</created>
|
<created>1724371229008</created>
|
||||||
<option name="number" value="00003" />
|
<option name="number" value="00011" />
|
||||||
<option name="presentableId" value="LOCAL-00003" />
|
<option name="presentableId" value="LOCAL-00011" />
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1723847456806</updated>
|
<updated>1724371229008</updated>
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00004" summary="add class Frame and class Massage, delete funktion go 100%, add resize window">
|
<task id="LOCAL-00012" summary="fixed error when active tunnel is deleted, now also the Address Label is emptied">
|
||||||
<option name="closed" value="true" />
|
<option name="closed" value="true" />
|
||||||
<created>1724013210356</created>
|
<created>1724400463791</created>
|
||||||
<option name="number" value="00004" />
|
<option name="number" value="00012" />
|
||||||
<option name="presentableId" value="LOCAL-00004" />
|
<option name="presentableId" value="LOCAL-00012" />
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1724013210356</updated>
|
<updated>1724400463791</updated>
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00005" summary="add class Frame and class Massage, delete funktion go 100%, add resize window, add warning pic">
|
<task id="LOCAL-00013" summary="In FrameWidged Class else Block StrVar, this resorts reference and variable assignment together">
|
||||||
<option name="closed" value="true" />
|
<option name="closed" value="true" />
|
||||||
<created>1724013251954</created>
|
<created>1724401340512</created>
|
||||||
<option name="number" value="00005" />
|
<option name="number" value="00013" />
|
||||||
<option name="presentableId" value="LOCAL-00005" />
|
<option name="presentableId" value="LOCAL-00013" />
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1724013251954</updated>
|
<updated>1724401340512</updated>
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00006" summary="add class ListTunnels and class ImportTunnel, and add class ExportTunnels (ExportTunnels no finish)">
|
<task id="LOCAL-00014" summary="add method init_and_report and label_empty to Class ShowAddress">
|
||||||
<option name="closed" value="true" />
|
<option name="closed" value="true" />
|
||||||
<created>1724048994613</created>
|
<created>1724410630021</created>
|
||||||
<option name="number" value="00006" />
|
<option name="number" value="00014" />
|
||||||
<option name="presentableId" value="LOCAL-00006" />
|
<option name="presentableId" value="LOCAL-00014" />
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1724048994613</updated>
|
<updated>1724410630021</updated>
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00007" summary="add Label Interface and Peer to new FrameWidget one and two. when import Tunnel then add to list works and remove of list when Tunnel delete.(with Label active on and off) add to class and methods open a avtive Tunnel when Wire-Py open, when import and start a Tunnel">
|
<task id="LOCAL-00015" summary="little fixes in Class Import">
|
||||||
<option name="closed" value="true" />
|
<option name="closed" value="true" />
|
||||||
<created>1724102937260</created>
|
<created>1724416642213</created>
|
||||||
<option name="number" value="00007" />
|
<option name="number" value="00015" />
|
||||||
<option name="presentableId" value="LOCAL-00007" />
|
<option name="presentableId" value="LOCAL-00015" />
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1724102937260</updated>
|
<updated>1724416642213</updated>
|
||||||
</task>
|
</task>
|
||||||
<option name="localTasksCounter" value="8" />
|
<task id="LOCAL-00016" summary="fix label when laat Tunnel delete and fix Tuple error in delete and Start/Stop when listbox empty">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1724495688099</created>
|
||||||
|
<option name="number" value="00016" />
|
||||||
|
<option name="presentableId" value="LOCAL-00016" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1724495688099</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00017" summary="remove a ',' in DNS Name">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1724576599289</created>
|
||||||
|
<option name="number" value="00017" />
|
||||||
|
<option name="presentableId" value="LOCAL-00017" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1724576599289</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00018" summary="fix when Filname > 17 first copy file after rename">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1724593165879</created>
|
||||||
|
<option name="number" value="00018" />
|
||||||
|
<option name="presentableId" value="LOCAL-00018" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1724593165879</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00019" summary="add export Tunnel as zip">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1724610514657</created>
|
||||||
|
<option name="number" value="00019" />
|
||||||
|
<option name="presentableId" value="LOCAL-00019" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1724610514658</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00020" summary="columnconfigure on all widgets set">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1724778892233</created>
|
||||||
|
<option name="number" value="00020" />
|
||||||
|
<option name="presentableId" value="LOCAL-00020" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1724778892233</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00021" summary="little fixes a " " to ' '">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725119445803</created>
|
||||||
|
<option name="number" value="00021" />
|
||||||
|
<option name="presentableId" value="LOCAL-00021" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725119445803</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00022" summary="add class FileHandle, add Label to show autoconnect Tunnel disable checkbox when Listbox is empty or no select Tunnel">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725391658456</created>
|
||||||
|
<option name="number" value="00022" />
|
||||||
|
<option name="presentableId" value="LOCAL-00022" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725391658456</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00023" summary="add if question and add autoconnect, autoconnect_var to class Filehandle in box_set no finish!">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725434328731</created>
|
||||||
|
<option name="number" value="00023" />
|
||||||
|
<option name="presentableId" value="LOCAL-00023" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725434328731</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00024" summary="fixes on empty Listbox now is disable and now works autoconnect label with read and write, delete works now with read and write">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725475967338</created>
|
||||||
|
<option name="number" value="00024" />
|
||||||
|
<option name="presentableId" value="LOCAL-00024" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725475967338</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00025" summary="add Frame widget 3 for Buttons and Listbox with Scrollbar. all Widgets new format delete works now of disable checkbox when Listbox empty (part two)">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725567453540</created>
|
||||||
|
<option name="number" value="00025" />
|
||||||
|
<option name="presentableId" value="LOCAL-00025" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725567453540</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00026" summary="little fixes">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725639633873</created>
|
||||||
|
<option name="number" value="00026" />
|
||||||
|
<option name="presentableId" value="LOCAL-00026" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725639633873</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00027" summary="little fixes">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725746027132</created>
|
||||||
|
<option name="number" value="00027" />
|
||||||
|
<option name="presentableId" value="LOCAL-00027" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725746027132</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00028" summary="little fixes replace os.system with check_call first steps in install Script add wg_start.service file">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725820337669</created>
|
||||||
|
<option name="number" value="00028" />
|
||||||
|
<option name="presentableId" value="LOCAL-00028" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725820337669</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00029" summary="little fixes a labels when stop and start, installer first functions works">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1725991610908</created>
|
||||||
|
<option name="number" value="00029" />
|
||||||
|
<option name="presentableId" value="LOCAL-00029" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1725991610908</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00030" summary="little fixes, add msg_window() function for Messagebox to show a tk.Toplevel() replace var = open() with: with open() as var: and remove by classes (tk.tk) and super()">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726349168248</created>
|
||||||
|
<option name="number" value="00030" />
|
||||||
|
<option name="presentableId" value="LOCAL-00030" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726349168248</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00031" summary="in delete replace open with Path install fixes">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726359012150</created>
|
||||||
|
<option name="number" value="00031" />
|
||||||
|
<option name="presentableId" value="LOCAL-00031" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726359012150</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00032" summary="new format little fixes icons sort add policy add .desktop File install Part 2">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726599446537</created>
|
||||||
|
<option name="number" value="00032" />
|
||||||
|
<option name="presentableId" value="LOCAL-00032" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726599446538</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00033" summary="install fix for set dir right">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726599588155</created>
|
||||||
|
<option name="number" value="00033" />
|
||||||
|
<option name="presentableId" value="LOCAL-00033" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726599588155</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00034" summary="fix checkbox disable and policy rename main.py to wg_main.py">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726650691719</created>
|
||||||
|
<option name="number" value="00034" />
|
||||||
|
<option name="presentableId" value="LOCAL-00034" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726650691719</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00035" summary="fix rename in Messagebox warning to error">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726652747322</created>
|
||||||
|
<option name="number" value="00035" />
|
||||||
|
<option name="presentableId" value="LOCAL-00035" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726652747322</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00036" summary="set rights in install and a .conf a import Tunnel Filedialog Part 1 /home when open">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726691611936</created>
|
||||||
|
<option name="number" value="00036" />
|
||||||
|
<option name="presentableId" value="LOCAL-00036" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726691611936</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00037" summary="fix set rights in install and a .conf a import Tunnel Filedialog Part 1 /home when open">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726734843529</created>
|
||||||
|
<option name="number" value="00037" />
|
||||||
|
<option name="presentableId" value="LOCAL-00037" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726734843529</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00038" summary="fix a filedialog for hidden Files work install rollback to bash for start wirepy and wirepy rollback to bash">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726764877546</created>
|
||||||
|
<option name="number" value="00038" />
|
||||||
|
<option name="presentableId" value="LOCAL-00038" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726764877546</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00039" summary="install rollback bash to py wirepy and wirepy rollback to py">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726770649542</created>
|
||||||
|
<option name="number" value="00039" />
|
||||||
|
<option name="presentableId" value="LOCAL-00039" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726770649542</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00040" summary="fix install and .desktop File Tar works now for user home and filebrowser.askfilebrowser start now in user home">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726777434040</created>
|
||||||
|
<option name="number" value="00040" />
|
||||||
|
<option name="presentableId" value="LOCAL-00040" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726777434040</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00041" summary="replace tar with zip and Check if Zip file is empty">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726836930251</created>
|
||||||
|
<option name="number" value="00041" />
|
||||||
|
<option name="presentableId" value="LOCAL-00041" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726836930251</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00042" summary="Create your own message boxes for export">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726841190285</created>
|
||||||
|
<option name="number" value="00042" />
|
||||||
|
<option name="presentableId" value="LOCAL-00042" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726841190285</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00043" summary="chown Export File to 1000:1000">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726860371820</created>
|
||||||
|
<option name="number" value="00043" />
|
||||||
|
<option name="presentableId" value="LOCAL-00043" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726860371820</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00044" summary="add rename Label rename works">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726915238475</created>
|
||||||
|
<option name="number" value="00044" />
|
||||||
|
<option name="presentableId" value="LOCAL-00044" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726915238475</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00045" summary="add con_to_dict in import for write PreSharedKey in .key File to warning if tunnel has already been imported and delete that the key is deleted again">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1726959423800</created>
|
||||||
|
<option name="number" value="00045" />
|
||||||
|
<option name="presentableId" value="LOCAL-00045" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1726959423800</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00046" summary="add con_to_dict in import for write PreSharedKey in .key File to warning if tunnel has already been imported and delete that the key is deleted again now works">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727015078922</created>
|
||||||
|
<option name="number" value="00046" />
|
||||||
|
<option name="presentableId" value="LOCAL-00046" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727015078922</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00047" summary="Descriptions added in wg_func-py">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727018233930</created>
|
||||||
|
<option name="number" value="00047" />
|
||||||
|
<option name="presentableId" value="LOCAL-00047" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727018233930</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00048" summary="If tunnel is renamed and this is in the car start, is now renamed the label">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727028762875</created>
|
||||||
|
<option name="number" value="00048" />
|
||||||
|
<option name="presentableId" value="LOCAL-00048" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727028762875</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00049" summary="fix scrollbar view with set self.y_height = 330 to self.y_height = 340">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727028915701</created>
|
||||||
|
<option name="number" value="00049" />
|
||||||
|
<option name="presentableId" value="LOCAL-00049" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727028915701</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00050" summary="in msg_window two further parameters to be added to the pass, so height and wide can also be specified. In rename, messages come now if new names do not fit Fix Index Error on msg_window()">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727118598759</created>
|
||||||
|
<option name="number" value="00050" />
|
||||||
|
<option name="presentableId" value="LOCAL-00050" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727118598760</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00051" summary="ad max 12-character message, no character message and special_characters message for entry label">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727288788988</created>
|
||||||
|
<option name="number" value="00051" />
|
||||||
|
<option name="presentableId" value="LOCAL-00051" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727288788988</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00052" summary="info icon shadow fix end msg Export fix to">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727347126769</created>
|
||||||
|
<option name="number" value="00052" />
|
||||||
|
<option name="presentableId" value="LOCAL-00052" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727347126769</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00053" summary="little fixes">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727378355274</created>
|
||||||
|
<option name="number" value="00053" />
|
||||||
|
<option name="presentableId" value="LOCAL-00053" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727378355275</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00054" summary="fix msg_boxes when tunnel list = 0 a Start, Delete and Export">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727379755537</created>
|
||||||
|
<option name="number" value="00054" />
|
||||||
|
<option name="presentableId" value="LOCAL-00054" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727379755537</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00055" summary="fix installer add .keys file">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727380793216</created>
|
||||||
|
<option name="number" value="00055" />
|
||||||
|
<option name="presentableId" value="LOCAL-00055" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727380793216</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00056" summary="Changelog create When exporting, the folder is now copied to /tmp and the non .conf files are deleted before the zip file is created. In main.py os import removed. Since os have been replaced by pathlib and shutil. Start with version number 1.4.7 Message window size corrected so text is displayed better">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1727525609727</created>
|
||||||
|
<option name="number" value="00056" />
|
||||||
|
<option name="presentableId" value="LOCAL-00056" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1727525609728</updated>
|
||||||
|
</task>
|
||||||
|
<task id="LOCAL-00057" summary="Fix msg_window and remove x , y argument Install further adapted and with colored text if user is not in group sudo or wheel. Added to install Opensuse for installation">
|
||||||
|
<option name="closed" value="true" />
|
||||||
|
<created>1728059870005</created>
|
||||||
|
<option name="number" value="00057" />
|
||||||
|
<option name="presentableId" value="LOCAL-00057" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1728059870005</updated>
|
||||||
|
</task>
|
||||||
|
<option name="localTasksCounter" value="58" />
|
||||||
<servers />
|
<servers />
|
||||||
</component>
|
</component>
|
||||||
|
<component name="UnknownFeatures">
|
||||||
|
<option featureType="com.intellij.fileTypeFactory" implementationName="*.policy" />
|
||||||
|
</component>
|
||||||
<component name="Vcs.Log.Tabs.Properties">
|
<component name="Vcs.Log.Tabs.Properties">
|
||||||
|
<option name="OPEN_GENERIC_TABS">
|
||||||
|
<map>
|
||||||
|
<entry key="f9756e7d-0c5c-4b84-84e4-660314c46ea4" value="TOOL_WINDOW" />
|
||||||
|
</map>
|
||||||
|
</option>
|
||||||
<option name="TAB_STATES">
|
<option name="TAB_STATES">
|
||||||
<map>
|
<map>
|
||||||
<entry key="MAIN">
|
<entry key="MAIN">
|
||||||
@ -170,17 +562,41 @@
|
|||||||
</State>
|
</State>
|
||||||
</value>
|
</value>
|
||||||
</entry>
|
</entry>
|
||||||
|
<entry key="f9756e7d-0c5c-4b84-84e4-660314c46ea4">
|
||||||
|
<value>
|
||||||
|
<State />
|
||||||
|
</value>
|
||||||
|
</entry>
|
||||||
</map>
|
</map>
|
||||||
</option>
|
</option>
|
||||||
</component>
|
</component>
|
||||||
<component name="VcsManagerConfiguration">
|
<component name="VcsManagerConfiguration">
|
||||||
<option name="ADD_EXTERNAL_FILES_SILENTLY" value="true" />
|
<option name="ADD_EXTERNAL_FILES_SILENTLY" value="true" />
|
||||||
<MESSAGE value="Tunnel Start and Stop Work" />
|
<MESSAGE value="install fix for set dir right" />
|
||||||
<MESSAGE value="wg_import_select in wg_func.py extended" />
|
<MESSAGE value="fix checkbox disable and policy rename main.py to wg_main.py" />
|
||||||
<MESSAGE value="add class Frame and class Massage, delete funktion go 100%, add resize window" />
|
<MESSAGE value="fix rename in Messagebox warning to error" />
|
||||||
<MESSAGE value="add class Frame and class Massage, delete funktion go 100%, add resize window, add warning pic" />
|
<MESSAGE value="set rights in install and a .conf a import Tunnel Filedialog Part 1 /home when open" />
|
||||||
<MESSAGE value="add class ListTunnels and class ImportTunnel, and add class ExportTunnels (ExportTunnels no finish)" />
|
<MESSAGE value="fix set rights in install and a .conf a import Tunnel Filedialog Part 1 /home when open" />
|
||||||
<MESSAGE value="add Label Interface and Peer to new FrameWidget one and two. when import Tunnel then add to list works and remove of list when Tunnel delete.(with Label active on and off) add to class and methods open a avtive Tunnel when Wire-Py open, when import and start a Tunnel" />
|
<MESSAGE value="fix a filedialog for hidden Files work install rollback to bash for start wirepy and wirepy rollback to bash" />
|
||||||
<option name="LAST_COMMIT_MESSAGE" value="add Label Interface and Peer to new FrameWidget one and two. when import Tunnel then add to list works and remove of list when Tunnel delete.(with Label active on and off) add to class and methods open a avtive Tunnel when Wire-Py open, when import and start a Tunnel" />
|
<MESSAGE value="install rollback bash to py wirepy and wirepy rollback to py" />
|
||||||
|
<MESSAGE value="fix install and .desktop File Tar works now for user home and filebrowser.askfilebrowser start now in user home" />
|
||||||
|
<MESSAGE value="replace tar with zip and Check if Zip file is empty" />
|
||||||
|
<MESSAGE value="Create your own message boxes for export" />
|
||||||
|
<MESSAGE value="chown Export File to 1000:1000" />
|
||||||
|
<MESSAGE value="add rename Label rename works" />
|
||||||
|
<MESSAGE value="add con_to_dict in import for write PreSharedKey in .key File to warning if tunnel has already been imported and delete that the key is deleted again" />
|
||||||
|
<MESSAGE value="add con_to_dict in import for write PreSharedKey in .key File to warning if tunnel has already been imported and delete that the key is deleted again now works" />
|
||||||
|
<MESSAGE value="Descriptions added in wg_func-py" />
|
||||||
|
<MESSAGE value="If tunnel is renamed and this is in the car start, is now renamed the label" />
|
||||||
|
<MESSAGE value="fix scrollbar view with set self.y_height = 330 to self.y_height = 340" />
|
||||||
|
<MESSAGE value="in msg_window two further parameters to be added to the pass, so height and wide can also be specified. In rename, messages come now if new names do not fit Fix Index Error on msg_window()" />
|
||||||
|
<MESSAGE value="ad max 12-character message, no character message and special_characters message for entry label" />
|
||||||
|
<MESSAGE value="info icon shadow fix end msg Export fix to" />
|
||||||
|
<MESSAGE value="little fixes" />
|
||||||
|
<MESSAGE value="fix msg_boxes when tunnel list = 0 a Start, Delete and Export" />
|
||||||
|
<MESSAGE value="fix installer add .keys file" />
|
||||||
|
<MESSAGE value="Changelog create When exporting, the folder is now copied to /tmp and the non .conf files are deleted before the zip file is created. In main.py os import removed. Since os have been replaced by pathlib and shutil. Start with version number 1.4.7 Message window size corrected so text is displayed better" />
|
||||||
|
<MESSAGE value="Fix msg_window and remove x , y argument Install further adapted and with colored text if user is not in group sudo or wheel. Added to install Opensuse for installation" />
|
||||||
|
<option name="LAST_COMMIT_MESSAGE" value="Fix msg_window and remove x , y argument Install further adapted and with colored text if user is not in group sudo or wheel. Added to install Opensuse for installation" />
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
65
Changelog
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
Changelog for Wire-Py
|
||||||
|
My standard System: Linux Mint 22 Cinnamon
|
||||||
|
|
||||||
|
## [Unreleased]
|
||||||
|
|
||||||
|
- os import in wg_func replaced by other methods
|
||||||
|
- Guide to menu '?' with pictures
|
||||||
|
- In Gitea Readme enter text, images
|
||||||
|
- Own filedialog for import
|
||||||
|
- If Wire-Py already runs, prevent further start
|
||||||
|
- for loops with lists replaced by List Comprehensions
|
||||||
|
- Keeping Classes Together
|
||||||
|
|
||||||
|
### Added
|
||||||
|
12-10-2024
|
||||||
|
|
||||||
|
- Create file for settings (Autoupdate)
|
||||||
|
- Create file for theme
|
||||||
|
- Autoupdate in Options
|
||||||
|
- Dark Theme for Wire-Py
|
||||||
|
|
||||||
|
|
||||||
|
### Added
|
||||||
|
04-10-2024
|
||||||
|
|
||||||
|
- Fix msg_window and remove x , y argument
|
||||||
|
|
||||||
|
- Install further adapted and with colored text if user
|
||||||
|
is not in group sudo or wheel.
|
||||||
|
|
||||||
|
- Added to install Opensuse for installation
|
||||||
|
|
||||||
|
- Tested on Arch with Mate, Xfce4, Gnome, LXDE Desktop
|
||||||
|
Open Suse Tumbleweed KDE, Fedora 40 KDE and Debian 12 Mate Desktop
|
||||||
|
|
||||||
|
|
||||||
|
### Added
|
||||||
|
29-09-2024
|
||||||
|
|
||||||
|
- installer optimize for another Systems
|
||||||
|
|
||||||
|
- Version number changed to:
|
||||||
|
1 = 1. Year, 01 = Month of the Year, 0124 = Day and Year of the Year
|
||||||
|
Example for this version: 1.09.2924
|
||||||
|
|
||||||
|
- Comments modified by # description to ''' description '''
|
||||||
|
and insert empty lines for better readability
|
||||||
|
|
||||||
|
|
||||||
|
### Added
|
||||||
|
28-09-2024
|
||||||
|
|
||||||
|
- Changelog create
|
||||||
|
|
||||||
|
- When exporting, the folder is now copied to /tmp and the non .conf
|
||||||
|
files are deleted before the zip file is created.
|
||||||
|
|
||||||
|
- In main.py os import removed. Since os have been replaced by pathlib and shutil.
|
||||||
|
|
||||||
|
- Start with version number 1.4.7
|
||||||
|
|
||||||
|
- Message window size corrected so text is displayed better
|
||||||
|
|
||||||
|
- Version lobster assigned to a variable
|
||||||
|
|
7
Wire-Py.desktop
Executable file
@ -0,0 +1,7 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Type=Application
|
||||||
|
Name=Wire-Py
|
||||||
|
Exec=/usr/bin/wirepy.py
|
||||||
|
Terminal=false
|
||||||
|
Categories=Network;
|
||||||
|
Icon=/usr/share/icons/wp-icons/128/wg_vpn.png
|
@ -1,3 +0,0 @@
|
|||||||
192.168.178.158/24
|
|
||||||
192.168.178.1,
|
|
||||||
rj2cexasg9b9oydd.myfritz.net:54775
|
|
Before Width: | Height: | Size: 1.5 KiB |
Before Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 3.5 KiB |
Before Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 30 KiB |
Before Width: | Height: | Size: 5.2 KiB |
Before Width: | Height: | Size: 22 KiB |
131
install
Executable file
@ -0,0 +1,131 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
NORMAL='\033[0m'
|
||||||
|
GREEN='\033[1;32m'
|
||||||
|
RED='\033[31;1;42m'
|
||||||
|
BLUE='\033[30;1;34m'
|
||||||
|
|
||||||
|
install_file_with(){
|
||||||
|
clear
|
||||||
|
sudo apt install python3-tk , tcl-ttkthemes && \
|
||||||
|
sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py /usr/bin/ && \
|
||||||
|
sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && sudo cp -n settings theme /etc/wire_py/ && \
|
||||||
|
sudo cp -uR wp-icons /usr/share/icons/ && \
|
||||||
|
sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \
|
||||||
|
sudo ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \
|
||||||
|
sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \
|
||||||
|
sudo cp -u Wire-Py.desktop /usr/share/applications/ && \
|
||||||
|
sudo cp -u wg_start.service /lib/systemd/system/ && \
|
||||||
|
sudo systemctl enable wg_start.service
|
||||||
|
}
|
||||||
|
|
||||||
|
install_arch_d(){
|
||||||
|
clear
|
||||||
|
sudo pacman -S --noconfirm tk python3 python-requests && \
|
||||||
|
sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py /usr/bin/ && \
|
||||||
|
sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && sudo cp -n settings theme /etc/wire_py/ && \
|
||||||
|
sudo cp -uR wp-icons /usr/share/icons/ && \
|
||||||
|
sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \
|
||||||
|
sudo ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \
|
||||||
|
sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \
|
||||||
|
sudo cp -u Wire-Py.desktop /usr/share/applications/ && \
|
||||||
|
sudo cp -u wg_start.service /lib/systemd/system/ && \
|
||||||
|
sudo systemctl enable wg_start.service
|
||||||
|
}
|
||||||
|
|
||||||
|
if grep -i 'debian' /etc/os-release > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
groups > /tmp/isgroup
|
||||||
|
if grep 'sudo' /tmp/isgroup
|
||||||
|
then
|
||||||
|
install_file_with
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
echo -e "$BLUE"The installer found that they are not in the group sudo.""
|
||||||
|
echo -e "with "$RED"su -"$BLUE" "they can enter the root shell in which they then""
|
||||||
|
echo -e "enter "$GREEN""usermod -aG sudo $USER.""$BLUE""
|
||||||
|
echo -e ""after logging in from the system, they can then run Wire-Py install again." $NORMAL"
|
||||||
|
read -n 1 -s -r -p $"To close the Window press a button"
|
||||||
|
clear
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
elif grep -i 'mint\|ubuntu\|pop|' /etc/os-release > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
install_file_with
|
||||||
|
|
||||||
|
|
||||||
|
elif grep -i 'arch' /etc/os-release > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
groups > /tmp/isgroup
|
||||||
|
clear
|
||||||
|
if grep 'wheel' /tmp/isgroup
|
||||||
|
then
|
||||||
|
install_arch_d
|
||||||
|
else
|
||||||
|
echo "The installer found that they are not in the group sudo."
|
||||||
|
echo "The sudoers file must be edited with"
|
||||||
|
echo -e "$RED""su -""$NORMAL"
|
||||||
|
echo -e "$GREEN"""EDITOR=nano visudo"""$NORMAL"
|
||||||
|
echo "Find the line:"
|
||||||
|
echo "## Uncomment to allow members of group wheel to execute any command"
|
||||||
|
echo "remove '#' on # %wheel ALL=(ALL) ALL and save the file"
|
||||||
|
echo -e "then enter "$GREEN"gpasswd -a $USER wheel.""$NORMAL"
|
||||||
|
echo "after logging in from the system, they can then run Wire-Py install again."
|
||||||
|
read -n 1 -s -r -p $"To close the Window press a button"
|
||||||
|
clear
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
elif grep -i '|manjaro\|garuda\|endeavour|' /etc/os-release > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
install_arch_d
|
||||||
|
|
||||||
|
|
||||||
|
elif grep -i 'fedora' /etc/os-release > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
if ! which python3-tkinter &> /dev/null
|
||||||
|
then sudo dnf install python3-tkinter -y
|
||||||
|
|
||||||
|
sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py /usr/bin/ && \
|
||||||
|
sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && \
|
||||||
|
sudo cp -n settings theme /etc/wire_py/ && \
|
||||||
|
sudo cp -uR wp-icons /usr/share/icons/ && \
|
||||||
|
sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \
|
||||||
|
sudo ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \
|
||||||
|
sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \
|
||||||
|
sudo cp -u Wire-Py.desktop /usr/share/applications/ && \
|
||||||
|
sudo cp -u wg_start.service /lib/systemd/system/ && \
|
||||||
|
sudo systemctl enable wg_start.service
|
||||||
|
|
||||||
|
fi
|
||||||
|
elif grep -i 'suse' /etc/os-release > /dev/null 2>&1
|
||||||
|
then
|
||||||
|
if ! which python311-tk &> /dev/null
|
||||||
|
then sudo zypper install python311-tk
|
||||||
|
sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py /usr/bin/ && \
|
||||||
|
sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && \
|
||||||
|
sudo cp -n settings theme /etc/wire_py/ && \
|
||||||
|
sudo cp -uR wp-icons /usr/share/icons/ && \
|
||||||
|
sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \
|
||||||
|
sudo ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \
|
||||||
|
sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \
|
||||||
|
sudo cp -u Wire-Py.desktop /usr/share/applications/ && \
|
||||||
|
sudo cp -u wg_start.service /lib/systemd/system/ && \
|
||||||
|
sudo systemctl enable wg_start.service
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
clear
|
||||||
|
echo $"Your System could not be determined."
|
||||||
|
echo
|
||||||
|
read -n 1 -s -r -p $"To close the window press a button"
|
||||||
|
clear
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
clear
|
||||||
|
read -n 1 -s -r -p $"To close the Window press a button"
|
||||||
|
clear
|
||||||
|
|
||||||
|
|
172
main.py
@ -1,172 +0,0 @@
|
|||||||
#!/usr/bin/python3
|
|
||||||
import os
|
|
||||||
import tkinter as tk
|
|
||||||
from tkinter import ttk
|
|
||||||
|
|
||||||
from wg_func import (TunnelActiv, ListTunnels, ImportTunnel,
|
|
||||||
ConToDict, GreenLabel, ExportTunnels)
|
|
||||||
|
|
||||||
|
|
||||||
class MainWindow(tk.Tk):
|
|
||||||
def __init__(self, *args, **kwargs):
|
|
||||||
super().__init__(*args, **kwargs)
|
|
||||||
|
|
||||||
self.switch_on = None
|
|
||||||
self.switch_off = None
|
|
||||||
self.x_width = 600
|
|
||||||
self.y_height = 350
|
|
||||||
self.monitor_center_x = self.winfo_screenwidth() / 2 - (self.x_width / 2)
|
|
||||||
self.monitor_center_y = self.winfo_screenheight() / 2 - (self.y_height / 2)
|
|
||||||
self.resizable(width=False, height=False)
|
|
||||||
self.title('Wire-Py')
|
|
||||||
self.configure()
|
|
||||||
self.geometry('%dx%d+%d+%d' % (self.x_width, self.y_height, self.monitor_center_x, self.monitor_center_y))
|
|
||||||
# Load the image file from disk.
|
|
||||||
self.wg_icon = tk.PhotoImage(file=r'icons/wg-vpn-48.png')
|
|
||||||
# Set it as the window icon.
|
|
||||||
self.iconphoto(True, self.wg_icon)
|
|
||||||
|
|
||||||
FrameWidgets(self).grid()
|
|
||||||
|
|
||||||
|
|
||||||
class FrameWidgets(ttk.Frame):
|
|
||||||
def __init__(self, container, **kwargs):
|
|
||||||
super().__init__(container, **kwargs)
|
|
||||||
|
|
||||||
self.lb_tunnel = None
|
|
||||||
self.wg_read = None
|
|
||||||
self.wg_vpn_start = tk.PhotoImage(file=r'icons/wg-vpn-start-48.png')
|
|
||||||
self.wg_vpn_stop = tk.PhotoImage(file=r'icons/wg-vpn-stop-48.png')
|
|
||||||
self.wgi_on = tk.PhotoImage(file=r'icons/wire-switch-on-48.png')
|
|
||||||
self.wgi_off = tk.PhotoImage(file=r'icons/wire-switch-off-48.png')
|
|
||||||
self.imp_pic = tk.PhotoImage(file=r'icons/wg-import.png')
|
|
||||||
self.tr_pic = tk.PhotoImage(file=r'icons/wg-trash-48.png')
|
|
||||||
self.exp_pic = tk.PhotoImage(file=r'icons/wg-export-48.png')
|
|
||||||
self.warning_pic = tk.PhotoImage(file=r'icons/warning_64.png')
|
|
||||||
# Show active Tunnel
|
|
||||||
self.a = TunnelActiv.active()
|
|
||||||
# Label 2
|
|
||||||
self.lb_frame = ttk.Frame(self)
|
|
||||||
self.lb_frame.configure(relief='solid')
|
|
||||||
self.lb_frame.grid(column=2, row=2, sticky='n', padx=10)
|
|
||||||
self.lb_frame2 = ttk.Frame(self)
|
|
||||||
self.lb_frame2.configure(relief='solid')
|
|
||||||
self.lb_frame2.grid(column=2, row=3, sticky='nw', padx=10)
|
|
||||||
# Show active Label
|
|
||||||
self.select_tunnel = None
|
|
||||||
self.lb = tk.Label(self, text='Active:')
|
|
||||||
self.lb.config(font=("Ubuntu", 11, "bold"))
|
|
||||||
self.lb.grid(column=2, row=1, padx=5, sticky="we")
|
|
||||||
|
|
||||||
# Label to Show active Tunnel
|
|
||||||
self.StrVar = tk.StringVar(value=self.a)
|
|
||||||
GreenLabel.green_show_label(self)
|
|
||||||
|
|
||||||
# Interface Label
|
|
||||||
self.interface = tk.Label(self.lb_frame, text='Interface')
|
|
||||||
self.interface.grid(column=0, row=4, sticky="n", padx=10)
|
|
||||||
self.interface.config(font=("Ubuntu", 9))
|
|
||||||
# Address Label
|
|
||||||
self.address = tk.Label(self.lb_frame, text='address')
|
|
||||||
self.address.grid(column=0, row=5, sticky="n", padx=10)
|
|
||||||
self.address.config(font=("Ubuntu", 9))
|
|
||||||
# DNS Label
|
|
||||||
self.dns = tk.Label(self.lb_frame, text='dns')
|
|
||||||
self.dns.grid(column=0, row=6, sticky="n", padx=10)
|
|
||||||
self.dns.config(font=("Ubuntu", 9))
|
|
||||||
# Peer Label
|
|
||||||
self.peer = tk.Label(self.lb_frame2, text='Peer')
|
|
||||||
self.peer.config(font=("Ubuntu", 9))
|
|
||||||
self.peer.grid(column=0, row=7, sticky="n", padx=10)
|
|
||||||
# Endpoint Label
|
|
||||||
self.endpoint = tk.Label(self.lb_frame2, text='Endpoint')
|
|
||||||
self.endpoint.config(font=("Ubuntu", 9))
|
|
||||||
self.endpoint.grid(column=0, row=8, sticky="n", padx=10)
|
|
||||||
|
|
||||||
self.scrollbar = tk.Scrollbar(self)
|
|
||||||
self.l_box = tk.Listbox(self, fg='#606060', selectmode='single')
|
|
||||||
self.l_box.config(highlightthickness=0, relief='flat')
|
|
||||||
self.scrollbar.config(command=self.l_box.yview)
|
|
||||||
self.l_box.config(font=("Ubuntu", 12, "bold"))
|
|
||||||
self.l_box.grid(column=1, rowspan=3, row=1, )
|
|
||||||
|
|
||||||
self.tl = ListTunnels.tl_list()
|
|
||||||
for tunnels in self.tl:
|
|
||||||
self.l_box.insert("end", tunnels)
|
|
||||||
self.l_box.update()
|
|
||||||
|
|
||||||
# Button Vpn
|
|
||||||
if self.a != '':
|
|
||||||
self.btn_stst = tk.Button(self, image=self.wg_vpn_stop, bd=0, command=self.wg_switch)
|
|
||||||
self.btn_stst.grid(column=0, row=1, padx=15, pady=15, sticky="s")
|
|
||||||
wg_read = os.environ['HOME'] + '/tester/' + str(self.a) + '.conf'
|
|
||||||
file = open(wg_read, 'r')
|
|
||||||
ConToDict.covert_to_dict(file)
|
|
||||||
file.close()
|
|
||||||
else:
|
|
||||||
self.btn_stst = tk.Button(self, image=self.wg_vpn_start, bd=0, command=self.wg_switch)
|
|
||||||
self.btn_stst.grid(column=0, row=1, padx=15, pady=15, sticky="s")
|
|
||||||
# Button Import
|
|
||||||
self.btn_i = tk.Button(self, image=self.imp_pic, bd=0, command=lambda: ImportTunnel.wg_import_select(self))
|
|
||||||
self.btn_i.grid(column=0, row=2, padx=15, pady=15)
|
|
||||||
|
|
||||||
def delete():
|
|
||||||
self.select_tunnel = self.l_box.curselection()
|
|
||||||
select_tl = self.l_box.get(self.select_tunnel[0])
|
|
||||||
os.system('nmcli connection delete ' + str(select_tl))
|
|
||||||
self.l_box.delete(self.select_tunnel[0])
|
|
||||||
os.remove(os.environ['HOME'] + '/tester/' + str(select_tl) + '.conf')
|
|
||||||
if self.a != '':
|
|
||||||
self.StrVar.set(value='')
|
|
||||||
self.btn_stst = tk.Button(self, image=self.wg_vpn_start, bd=0, command=self.wg_switch)
|
|
||||||
self.btn_stst.grid(column=0, row=1, padx=15, pady=15, sticky="s")
|
|
||||||
self.l_box.update()
|
|
||||||
|
|
||||||
# Button Trash
|
|
||||||
self.btn_tr = tk.Button(self, image=self.tr_pic, bd=0, command=delete)
|
|
||||||
self.btn_tr.grid(column=0, row=3, padx=15, pady=15)
|
|
||||||
# Button Export
|
|
||||||
self.btn_exp = tk.Button(self, image=self.exp_pic, bd=0)
|
|
||||||
self.btn_exp.grid(column=0, row=4, padx=15, pady=15)
|
|
||||||
|
|
||||||
# Check Buttons
|
|
||||||
self.wg_autostart = tk.Checkbutton(self, text='Autoconnect on PC Start')
|
|
||||||
self.wg_autostart.grid(column=1, rowspan=3, row=3)
|
|
||||||
self.wg_update = tk.Checkbutton(self, text='Search automatically for\nWire-Py updates')
|
|
||||||
self.wg_update.grid(column=1, rowspan=3, row=4)
|
|
||||||
|
|
||||||
def wg_switch(self):
|
|
||||||
self.a = TunnelActiv.active()
|
|
||||||
if self.a == '':
|
|
||||||
|
|
||||||
self.select_tunnel = self.l_box.curselection()
|
|
||||||
select_tl = self.l_box.get(self.select_tunnel[0])
|
|
||||||
os.system('nmcli connection up ' + str(select_tl))
|
|
||||||
wg_read = os.environ['HOME'] + '/tester/' + str(select_tl) + '.conf'
|
|
||||||
file = open(wg_read, 'r')
|
|
||||||
ConToDict.covert_to_dict(file)
|
|
||||||
file.close()
|
|
||||||
# Button Start/Stop
|
|
||||||
self.btn_stst = tk.Button(self, image=self.wg_vpn_stop, bd=0, command=self.wg_switch)
|
|
||||||
self.btn_stst.grid(column=0, row=1, padx=15, pady=15, sticky="s")
|
|
||||||
self.a = TunnelActiv.active()
|
|
||||||
self.StrVar = tk.StringVar()
|
|
||||||
self.StrVar.set(self.a)
|
|
||||||
GreenLabel.green_show_label(self)
|
|
||||||
elif self.a != '':
|
|
||||||
# Button Start/Stop
|
|
||||||
self.btn_stst = tk.Button(self, image=self.wg_vpn_stop, bd=0, command=self.wg_switch)
|
|
||||||
self.btn_stst.grid(column=0, row=1, padx=15, pady=15, sticky="s")
|
|
||||||
os.system('nmcli connection down ' + str(self.a))
|
|
||||||
# Button Start/Stop
|
|
||||||
self.btn_stst = tk.Button(self, image=self.wg_vpn_start, bd=0, command=self.wg_switch)
|
|
||||||
self.btn_stst.grid(column=0, row=1, padx=15, pady=15, sticky="s")
|
|
||||||
self.a = TunnelActiv.active()
|
|
||||||
self.StrVar = tk.StringVar()
|
|
||||||
self.StrVar.set(value=' ')
|
|
||||||
GreenLabel.green_show_label(self)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
window = MainWindow()
|
|
||||||
window.mainloop()
|
|
16
org.wirepy.policy
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE policyconfig PUBLIC "-//freedesktop//DTD PolicyKit Policy Configuration 1.0//EN" "http://www.freedesktop.org/standards/PolicyKit/1/policyconfig.dtd">
|
||||||
|
<policyconfig>
|
||||||
|
<vendor>Project Wire-Py</vendor>
|
||||||
|
<vendor_url>https://git.ilunix.de/punix/Wire-Py</vendor_url>
|
||||||
|
<icon_name>wg-vpn</icon_name>
|
||||||
|
<action id="org.wirepy">
|
||||||
|
<defaults>
|
||||||
|
<allow_any>auth_admin_keep</allow_any>
|
||||||
|
<allow_inactive>auth_admin_keep</allow_inactive>
|
||||||
|
<allow_active>yes</allow_active>
|
||||||
|
</defaults>
|
||||||
|
<annotate key="org.freedesktop.policykit.exec.path">/usr/bin/wg_main.py</annotate>
|
||||||
|
<annotate key="org.freedesktop.policykit.exec.allow_gui">true</annotate>
|
||||||
|
</action>
|
||||||
|
</policyconfig>
|
12
start_wg.py
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
from subprocess import check_call
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
|
path_to_file = Path('/etc/wire_py/wg_py')
|
||||||
|
|
||||||
|
if Path.exists(path_to_file):
|
||||||
|
a_con = Path.read_text(path_to_file)
|
||||||
|
check_call(['nmcli', 'connection', 'up', a_con])
|
||||||
|
else:
|
||||||
|
pass
|
||||||
|
|
569
wg_func.py
Normal file → Executable file
@ -1,59 +1,216 @@
|
|||||||
# Wireguard functions for Wire-Py
|
""" Wireguard Classes and Method for Wire-Py """
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
import shutil
|
||||||
import subprocess
|
import subprocess
|
||||||
from tkinter import filedialog, ttk
|
|
||||||
import tkinter as tk
|
import tkinter as tk
|
||||||
|
import zipfile
|
||||||
|
from datetime import datetime
|
||||||
|
from pathlib import Path
|
||||||
|
from subprocess import check_call
|
||||||
|
from tkinter import filedialog, ttk
|
||||||
|
import requests
|
||||||
|
|
||||||
|
''' 1 = 1. Year, 09 = Month of the Year, 2924 = Day and Year of the Year '''
|
||||||
|
version = 'v. 1.10.1224'
|
||||||
|
|
||||||
|
path_to_file = Path('/etc/wire_py/wg_py')
|
||||||
|
path_to_file2 = Path('/etc/wire_py/settings')
|
||||||
|
path_to_file3 = Path('/etc/wire_py/theme')
|
||||||
|
_u = Path.read_text(Path('/tmp/_u'))
|
||||||
|
|
||||||
|
UPDATE_API_URL = 'https://git.ilunix.de/api/v1/repos/punix/Wire-Py/releases'
|
||||||
|
|
||||||
|
class WirePyUpdate:
|
||||||
|
@staticmethod
|
||||||
|
def api_down():
|
||||||
|
try:
|
||||||
|
response = requests.get(UPDATE_API_URL)
|
||||||
|
response_dict = response.json()
|
||||||
|
response_dict = response_dict[0]
|
||||||
|
with open(path_to_file2, 'r') as set_file:
|
||||||
|
set_file = set_file.read()
|
||||||
|
if 'Update on' in set_file:
|
||||||
|
if version[3:] != response_dict['tag_name']:
|
||||||
|
return response_dict['tag_name']
|
||||||
|
else:
|
||||||
|
return 'No Updates'
|
||||||
|
else:
|
||||||
|
return 'False'
|
||||||
|
except requests.exceptions.ConnectionError:
|
||||||
|
return 'No Internet Connection!'
|
||||||
|
|
||||||
|
|
||||||
class Message(tk.Tk):
|
@staticmethod
|
||||||
def __init__(self, *args, **kwargs):
|
def download():
|
||||||
super().__init__(*args, **kwargs)
|
try:
|
||||||
|
url = f'https://git.ilunix.de/punix/Wire-Py/archive/{res}.zip'
|
||||||
|
to_down = 'wget -qP ' + str(_u) + ' ' + url
|
||||||
|
result = subprocess.call(to_down, shell=True)
|
||||||
|
if result == 0:
|
||||||
|
shutil.chown(str(_u) + f'/{res}.zip', 1000, 1000)
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_vpn.png'
|
||||||
|
wt = 'Download Successful'
|
||||||
|
msg_t = 'Your zip file is in home directory'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
self.warning_pic = None
|
else:
|
||||||
self.x_width = 300
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
self.y_height = 120
|
iw = r'/usr/share/icons/wp-icons/64/error.png'
|
||||||
self.monitor_center_x = self.winfo_screenwidth() / 2 - (self.x_width / 2)
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
self.monitor_center_y = self.winfo_screenheight() / 2 - (self.y_height / 2)
|
wt = 'Download error'
|
||||||
self.resizable(width=False, height=False)
|
msg_t = 'Download failed! Please try again'
|
||||||
self.title('Import error!')
|
msg_window(iw, ii, wt, msg_t)
|
||||||
self.configure()
|
except subprocess.CalledProcessError:
|
||||||
self.geometry('%dx%d+%d+%d' % (self.x_width, self.y_height, self.monitor_center_x, self.monitor_center_y))
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
self.columnconfigure(0, weight=1)
|
iw = r'/usr/share/icons/wp-icons/64/error.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
self.label = tk.Label(self, image=self.warning_pic,
|
wt = 'Download error'
|
||||||
text='Oh... no valid Wireguard File!\nPlease select a valid Wireguard File')
|
msg_t = 'Download failed! No internet connection!'
|
||||||
self.label.config(font=("Ubuntu", 11), padx=15, pady=15)
|
msg_window(iw, ii, wt, msg_t)
|
||||||
self.label.grid(column=0, row=0)
|
|
||||||
self.button = tk.Button(self, text="OK", command=self.destroy)
|
|
||||||
self.button.config(padx=15, pady=5)
|
|
||||||
self.button.grid(column=0, row=1)
|
|
||||||
|
|
||||||
|
|
||||||
class GreenLabel(tk.Tk):
|
res = WirePyUpdate.api_down()
|
||||||
def __init__(self, container, **kwargs):
|
|
||||||
super().__init__(container, **kwargs)
|
|
||||||
|
class Themes:
|
||||||
|
@staticmethod
|
||||||
|
def dark():
|
||||||
|
global back_gd
|
||||||
|
with open(path_to_file3, 'w') as theme_set2:
|
||||||
|
theme_set2.write('black')
|
||||||
|
back_gd = '#424242'
|
||||||
|
return back_gd
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def light():
|
||||||
|
global back_gd
|
||||||
|
with open(path_to_file3, 'w') as theme_set2:
|
||||||
|
theme_set2.write('light')
|
||||||
|
back_gd = '#f5f6f7'
|
||||||
|
return back_gd
|
||||||
|
|
||||||
|
def light_dark():
|
||||||
|
|
||||||
|
with open(path_to_file3) as theme_set:
|
||||||
|
if 'black' in theme_set:
|
||||||
|
theme = 'black'
|
||||||
|
else:
|
||||||
|
theme = 'arc'
|
||||||
|
return theme
|
||||||
|
|
||||||
|
bg = light_dark()
|
||||||
|
if bg == 'black':
|
||||||
|
back_gd = '#424242'
|
||||||
|
fore_gd = 'white'
|
||||||
|
font_color_active = 'yellow'
|
||||||
|
font_color = '#5e87da'
|
||||||
|
else:
|
||||||
|
back_gd = '#f5f6f7'
|
||||||
|
fore_gd = 'black'
|
||||||
|
font_color_active = 'green'
|
||||||
|
font_color = '#4011a7'
|
||||||
|
|
||||||
|
def msg_window(img_w, img_i, w_title, w_txt):
|
||||||
|
"""
|
||||||
|
Function for different message windows for the user. with 4 arguments to be passed.
|
||||||
|
To create messages with your own images, icons, and titles. As an alternative to Python Messagebox.
|
||||||
|
Paths to images must be specified: r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
img_w = Image for Tk Window
|
||||||
|
img_i = Image for Icon
|
||||||
|
w_title = Windows Title
|
||||||
|
w_txt = Text for Tk Window
|
||||||
|
"""
|
||||||
|
|
||||||
|
msg = tk.Toplevel()
|
||||||
|
msg.resizable(width=False, height=False)
|
||||||
|
msg.title(w_title)
|
||||||
|
msg.configure(pady=15, padx=15, background=back_gd)
|
||||||
|
msg.img = tk.PhotoImage(file=img_w)
|
||||||
|
msg.i_window = tk.Label(msg, image=msg.img, background=back_gd)
|
||||||
|
msg.i_window.grid(column=0, row=0)
|
||||||
|
label = tk.Label(msg, text=w_txt)
|
||||||
|
label.config(font=('Ubuntu', 11), padx=15, background=back_gd, foreground=fore_gd)
|
||||||
|
label.grid(column=1, row=0)
|
||||||
|
button = ttk.Button(msg, text='OK', command=msg.destroy, padding=4)
|
||||||
|
button.config()
|
||||||
|
button.grid(column=0, columnspan=2, row=1)
|
||||||
|
img_i = tk.PhotoImage(file=img_i)
|
||||||
|
msg.iconphoto(True, img_i)
|
||||||
|
msg.columnconfigure(0, weight=1)
|
||||||
|
msg.rowconfigure(0, weight=1)
|
||||||
|
msg.winfo_toplevel()
|
||||||
|
|
||||||
|
|
||||||
|
class GreenLabel:
|
||||||
|
"""
|
||||||
|
Show the active tunnel in green in the label
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
self.StrVar = None
|
self.StrVar = None
|
||||||
self.lb_tunnel = None
|
self.lb_tunnel = None
|
||||||
|
|
||||||
def green_show_label(self):
|
def green_show_label(self):
|
||||||
self.lb_tunnel = tk.Label(self, textvariable=self.StrVar, fg='green')
|
self.lb_tunnel = tk.Label(self, textvariable=self.StrVar, foreground=font_color_active, background=back_gd)
|
||||||
self.lb_tunnel.config(font=("Ubuntu", 11, "bold"))
|
self.lb_tunnel.config(font=('Ubuntu', 11, 'bold'))
|
||||||
self.lb_tunnel.grid(column=3, row=1, sticky="w")
|
self.lb_tunnel.grid(column=2, padx=10, row=0)
|
||||||
|
self.columnconfigure(2, weight=1)
|
||||||
|
self.rowconfigure(0, weight=1)
|
||||||
|
|
||||||
|
def columnconfigure(self, param, weight):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def rowconfigure(self, param, weight):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class StartStopBTN:
|
||||||
|
"""
|
||||||
|
Show Start and Stop Button in Label
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
self.lb_frame_btn_lbox = None
|
||||||
|
self.wg_switch = None
|
||||||
|
self.btn_stst = None
|
||||||
|
self.wg_vpn_start = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn-start.png')
|
||||||
|
self.wg_vpn_stop = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn-stop.png')
|
||||||
|
|
||||||
|
def button_stop(self):
|
||||||
|
self.btn_stst = tk.Button(self.lb_frame_btn_lbox, image=self.wg_vpn_stop, bd=0, command=self.wg_switch,
|
||||||
|
background=back_gd, highlightthickness=0, activebackground=back_gd)
|
||||||
|
self.btn_stst.grid(column=0, row=0, padx=15, pady=8)
|
||||||
|
|
||||||
|
def button_start(self):
|
||||||
|
self.btn_stst = tk.Button(self.lb_frame_btn_lbox, image=self.wg_vpn_start, bd=0, command=self.wg_switch,
|
||||||
|
background=back_gd, highlightthickness=0, activebackground=back_gd)
|
||||||
|
self.btn_stst.grid(column=0, row=0, padx=15, pady=8)
|
||||||
|
|
||||||
|
|
||||||
class ConToDict:
|
class ConToDict:
|
||||||
|
"""
|
||||||
|
The config file is packed into a dictionary,
|
||||||
|
to display the values Address , DNS and Peer in the labels
|
||||||
|
"""
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def covert_to_dict(cls, file):
|
def covert_to_dict(cls, file):
|
||||||
|
|
||||||
dictlist = []
|
dictlist = []
|
||||||
for lines in file.readlines():
|
for lines in file.readlines():
|
||||||
lineplit = lines.split()
|
line_plit = lines.split()
|
||||||
dictlist = dictlist + lineplit
|
dictlist = dictlist + line_plit
|
||||||
dictlist.remove('[Interface]')
|
dictlist.remove('[Interface]')
|
||||||
dictlist.remove('[Peer]')
|
dictlist.remove('[Peer]')
|
||||||
for items in dictlist:
|
for items in dictlist:
|
||||||
if items == '=':
|
if items == '=':
|
||||||
dictlist.remove(items)
|
dictlist.remove(items)
|
||||||
for i in dictlist:
|
|
||||||
|
''' Here is the beginning (Loop) of convert List to Dictionary '''
|
||||||
|
for _ in dictlist:
|
||||||
a = [dictlist[0], dictlist[1]]
|
a = [dictlist[0], dictlist[1]]
|
||||||
b = [dictlist[2], dictlist[3]]
|
b = [dictlist[2], dictlist[3]]
|
||||||
c = [dictlist[4], dictlist[5]]
|
c = [dictlist[4], dictlist[5]]
|
||||||
@ -62,24 +219,33 @@ class ConToDict:
|
|||||||
f = [dictlist[10], dictlist[11]]
|
f = [dictlist[10], dictlist[11]]
|
||||||
g = [dictlist[12], dictlist[13]]
|
g = [dictlist[12], dictlist[13]]
|
||||||
h = [dictlist[14], dictlist[15]]
|
h = [dictlist[14], dictlist[15]]
|
||||||
newlist = [a, b, c, d, e, f, g, h]
|
new_list = [a, b, c, d, e, f, g, h]
|
||||||
finaldict = {}
|
final_dict = {}
|
||||||
for elements in newlist:
|
for elements in new_list:
|
||||||
finaldict[elements[0]] = elements[1]
|
final_dict[elements[0]] = elements[1]
|
||||||
|
|
||||||
address = finaldict['Address']
|
''' end... result a Dictionary '''
|
||||||
dns = finaldict['DNS']
|
|
||||||
endpoint = finaldict['Endpoint']
|
address = final_dict['Address']
|
||||||
with open('dict_to_address', 'w+') as data:
|
dns = final_dict['DNS']
|
||||||
data.write(address + '\n')
|
if ',' in dns:
|
||||||
data.write(dns + '\n')
|
dns = dns[:-1]
|
||||||
data.write(endpoint + '\n')
|
endpoint = final_dict['Endpoint']
|
||||||
data.close()
|
if 'PresharedKey' in final_dict:
|
||||||
|
pre_key = final_dict['PresharedKey']
|
||||||
|
else:
|
||||||
|
pre_key = final_dict['PreSharedKey']
|
||||||
|
return address, dns, endpoint, pre_key
|
||||||
|
|
||||||
|
|
||||||
class TunnelActiv:
|
class TunnelActiv:
|
||||||
|
"""
|
||||||
|
Shows the Active Tunnel
|
||||||
|
"""
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def active(): # Shows the active tunnel
|
def active():
|
||||||
|
|
||||||
active = os.popen('nmcli con show --active | grep -iPo "(.*)(wireguard)"').read().split()
|
active = os.popen('nmcli con show --active | grep -iPo "(.*)(wireguard)"').read().split()
|
||||||
if not active:
|
if not active:
|
||||||
active = ''
|
active = ''
|
||||||
@ -89,16 +255,81 @@ class TunnelActiv:
|
|||||||
return active
|
return active
|
||||||
|
|
||||||
|
|
||||||
|
class ShowAddress:
|
||||||
|
"""
|
||||||
|
Displays the value address, DNS and peer in the labels
|
||||||
|
or empty it again
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
self.lb_frame2 = None
|
||||||
|
self.lb_frame = None
|
||||||
|
self.endpoint = None
|
||||||
|
self.dns = None
|
||||||
|
self.address = None
|
||||||
|
self.enp = None
|
||||||
|
self.DNS = None
|
||||||
|
self.add = None
|
||||||
|
|
||||||
|
def init_and_report(self, data=None):
|
||||||
|
""" Address Label """
|
||||||
|
self.add = tk.StringVar()
|
||||||
|
self.add.set('Address: ' + data[0])
|
||||||
|
self.DNS = tk.StringVar()
|
||||||
|
self.DNS.set(' DNS: ' + data[1])
|
||||||
|
self.enp = tk.StringVar()
|
||||||
|
self.enp.set('Endpoint: ' + data[2])
|
||||||
|
|
||||||
|
def label_empty(self):
|
||||||
|
self.add.set('')
|
||||||
|
self.DNS.set('')
|
||||||
|
self.enp.set('')
|
||||||
|
|
||||||
|
def show_data(self):
|
||||||
|
""" Address Label """
|
||||||
|
self.address = tk.Label(self.lb_frame, textvariable=self.add, background=back_gd, foreground=font_color)
|
||||||
|
self.address.grid(column=0, row=4, sticky='w', padx=10, pady=6)
|
||||||
|
self.address.config(font=('Ubuntu', 9))
|
||||||
|
|
||||||
|
''' DNS Label '''
|
||||||
|
self.dns = tk.Label(self.lb_frame, textvariable=self.DNS, background=back_gd, foreground=font_color)
|
||||||
|
self.dns.grid(column=0, row=6, sticky='w', padx=10, pady=6)
|
||||||
|
self.dns.config(font=('Ubuntu', 9))
|
||||||
|
|
||||||
|
''' Endpoint Label '''
|
||||||
|
self.endpoint = tk.Label(self.lb_frame2, textvariable=self.enp, background=back_gd, foreground=font_color)
|
||||||
|
self.endpoint.grid(column=0, row=7, sticky='w', padx=10, pady=10)
|
||||||
|
self.endpoint.config(font=('Ubuntu', 9))
|
||||||
|
|
||||||
|
|
||||||
class ListTunnels:
|
class ListTunnels:
|
||||||
|
"""
|
||||||
|
Shows all existing Wireguard tunnels
|
||||||
|
"""
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def tl_list():
|
def tl_list():
|
||||||
wg_s = os.popen('nmcli con show | grep -iPo "(.*)(wireguard)"').read().split()
|
wg_s = os.popen('nmcli con show | grep -iPo "(.*)(wireguard)"').read().split()
|
||||||
tl = wg_s[::3] # tl = Tunnel list # Show of 4.Element in list
|
|
||||||
|
''' tl = Tunnel list # Show of 4.Element in list '''
|
||||||
|
tl = wg_s[::3]
|
||||||
return tl
|
return tl
|
||||||
|
|
||||||
|
|
||||||
class ImportTunnel:
|
class ImportTunnel:
|
||||||
|
"""
|
||||||
|
Import Class for Wireguard config Files.
|
||||||
|
Before importing, it is checked whether PrivateKey and PublicKey are in the file.
|
||||||
|
If True then it is checked whether the PreSharedKey is already in the key file
|
||||||
|
to avoid an import error so that no double wgconf are imported.
|
||||||
|
Thus, tunnels can be renamed without the problems arise. If False then the key is written into the file.
|
||||||
|
Furthermore, it is checked whether the name is longer than 12 characters.
|
||||||
|
If True then the name is automatically shortened to 12 characters and then imported.
|
||||||
|
If in each case false comes out, a corresponding window comes to inform the user that something is wrong.
|
||||||
|
"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
|
||||||
self.select_tunnel = None
|
self.select_tunnel = None
|
||||||
self.wg_switch = None
|
self.wg_switch = None
|
||||||
self.btn_stst = None
|
self.btn_stst = None
|
||||||
@ -108,58 +339,222 @@ class ImportTunnel:
|
|||||||
self.l_box = None
|
self.l_box = None
|
||||||
|
|
||||||
def wg_import_select(self):
|
def wg_import_select(self):
|
||||||
|
|
||||||
try:
|
try:
|
||||||
filepath = filedialog.askopenfilename(initialdir=os.environ['HOME'], title="Select Wireguard config File",
|
filepath = filedialog.askopenfilename(initialdir=str(_u), title='Select Wireguard config File',
|
||||||
filetypes=[("WG config files", "*.conf")])
|
filetypes=[('WG config files', '*.conf')], )
|
||||||
file = open(filepath, 'r')
|
|
||||||
read = file.read()
|
with open(filepath, 'r') as file:
|
||||||
file.close()
|
read = file.read()
|
||||||
pathsplit = filepath.split("/")
|
path_split = filepath.split('/')
|
||||||
pathsplit1 = pathsplit[-1]
|
path_split1 = path_split[-1]
|
||||||
if "PrivateKey = " in read and "PublicKey = " in read:
|
self.a = TunnelActiv.active()
|
||||||
if len(pathsplit1) > 17:
|
|
||||||
pathsplit = pathsplit1[len(pathsplit1) - 17:]
|
if 'PrivateKey = ' in read and 'PublicKey = ' in read:
|
||||||
os.rename(filepath, os.environ['HOME'] + '/tester/' + str(pathsplit))
|
with open(filepath, 'r') as file:
|
||||||
os.system('nmcli connection down ' + str(TunnelActiv.active()))
|
key = ConToDict.covert_to_dict(file)
|
||||||
os.system('nmcli connection import type wireguard file ' + os.environ['HOME'] + '/tester/' +
|
pre_key = key[3]
|
||||||
str(pathsplit))
|
if len(pre_key) != 0:
|
||||||
os.system('nmcli con mod ' + str(pathsplit[:-5]) + ' connection.autoconnect no')
|
with open('/etc/wire_py/.keys', 'r') as readfile:
|
||||||
else:
|
p_key = readfile.readlines()
|
||||||
subprocess.call('cp ' + str(filepath) + ' ' + os.environ['HOME'] + '/tester/', shell=True)
|
if pre_key in p_key or pre_key + '\n' in p_key:
|
||||||
os.system('nmcli connection down ' + str(TunnelActiv.active()))
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
os.system('nmcli connection import type wireguard file ' + str(filepath))
|
iw = r'/usr/share/icons/wp-icons/64/error.png'
|
||||||
os.system('nmcli con mod ' + str(pathsplit1[:-5]) + ' connection.autoconnect no')
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
self.StrVar.set(value=' ')
|
wt = 'Import Error'
|
||||||
self.a = TunnelActiv.active()
|
msg_t = 'Tunnel already available!\nPlease use another file for import'
|
||||||
self.l_box.insert(0, self.a)
|
msg_window(iw, ii, wt, msg_t)
|
||||||
self.l_box.update()
|
|
||||||
self.StrVar = tk.StringVar()
|
else:
|
||||||
self.StrVar.set(self.a)
|
|
||||||
self.lb_tunnel = tk.Label(self, textvariable=self.StrVar, fg='green')
|
with open('/etc/wire_py/.keys', 'a') as keyfile:
|
||||||
self.lb_tunnel.config(font=("Ubuntu", 11, "bold"))
|
keyfile.write(pre_key + '\r')
|
||||||
self.lb_tunnel.grid(column=3, row=1, sticky="w")
|
if len(path_split1) > 17:
|
||||||
self.btn_stst = tk.Button(self, image=self.wg_vpn_stop, bd=0, command=self.wg_switch)
|
p1 = shutil.copy(filepath, Path('/etc/wire_py/'))
|
||||||
self.btn_stst.grid(column=0, row=1, padx=15, pady=15, sticky="s")
|
path_split = path_split1[len(path_split1) - 17:]
|
||||||
wg_read = os.environ['HOME'] + '/tester/' + str(self.a) + '.conf'
|
os.rename(p1, Path('/etc/wire_py') / str(path_split))
|
||||||
file = open(wg_read, 'r')
|
new_conf = '/etc/wire_py/' + path_split
|
||||||
ConToDict.covert_to_dict(file)
|
if self.a != '':
|
||||||
file.close()
|
check_call(['nmcli', 'connection', 'down', TunnelActiv.active()])
|
||||||
if "PrivateKey = " not in read:
|
ShowAddress.label_empty(self)
|
||||||
Message()
|
|
||||||
|
subprocess.check_output(['nmcli', 'connection', 'import', 'type',
|
||||||
|
'wireguard', 'file', new_conf], text=True)
|
||||||
|
|
||||||
|
else:
|
||||||
|
shutil.copy(filepath, Path('/etc/wire_py/'))
|
||||||
|
if self.a != '':
|
||||||
|
check_call(['nmcli', 'connection', 'down', TunnelActiv.active()])
|
||||||
|
ShowAddress.label_empty(self)
|
||||||
|
|
||||||
|
subprocess.check_output(['nmcli', 'connection', 'import', 'type',
|
||||||
|
'wireguard', 'file', filepath], text=True)
|
||||||
|
|
||||||
|
self.StrVar.set('')
|
||||||
|
self.a = TunnelActiv.active()
|
||||||
|
self.l_box.insert(0, self.a)
|
||||||
|
self.l_box.update()
|
||||||
|
self.StrVar = tk.StringVar()
|
||||||
|
self.StrVar.set(self.a)
|
||||||
|
GreenLabel.green_show_label(self)
|
||||||
|
StartStopBTN.button_stop(self)
|
||||||
|
wg_read = Path('/etc/wire_py') / str(self.a + '.conf')
|
||||||
|
with open(wg_read, 'r') as file_for_key:
|
||||||
|
data = ConToDict.covert_to_dict(file_for_key)
|
||||||
|
|
||||||
|
''' Address Label '''
|
||||||
|
ShowAddress.init_and_report(self, data)
|
||||||
|
ShowAddress.show_data(self)
|
||||||
|
check_call(['nmcli', 'con', 'mod', self.a, 'connection.autoconnect', 'no'])
|
||||||
|
Path.chmod(wg_read, 0o600)
|
||||||
|
|
||||||
|
if 'PrivateKey = ' not in read:
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/error.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Import Error'
|
||||||
|
msg_t = 'Oh... no valid Wireguard File!\nPlease select a valid Wireguard File'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
except EOFError:
|
except EOFError:
|
||||||
pass
|
pass
|
||||||
except TypeError:
|
except TypeError:
|
||||||
pass
|
pass
|
||||||
except FileNotFoundError:
|
except FileNotFoundError:
|
||||||
pass
|
pass
|
||||||
|
except subprocess.CalledProcessError:
|
||||||
|
|
||||||
|
print('Tunnel exist!')
|
||||||
|
|
||||||
|
|
||||||
|
class FileHandle:
|
||||||
|
"""
|
||||||
|
This class will display the autostart label which
|
||||||
|
Tunnel is automatically started regardless of the active tunnel.
|
||||||
|
The selected tunnel is written into a file to read it after the start of the system.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
|
||||||
|
self.wg_autostart = None
|
||||||
|
self.autoconnect = None
|
||||||
|
self.auto_con = None
|
||||||
|
self.autoconnect_var = None
|
||||||
|
self.tl = None
|
||||||
|
self.selected_option = None
|
||||||
|
self.l_box = None
|
||||||
|
|
||||||
|
def box_set(self):
|
||||||
|
|
||||||
|
try:
|
||||||
|
select_tunnel = self.l_box.curselection()
|
||||||
|
select_tl = self.l_box.get(select_tunnel[0])
|
||||||
|
|
||||||
|
if self.selected_option.get() == 0:
|
||||||
|
Path.unlink(path_to_file)
|
||||||
|
tl = ListTunnels.tl_list()
|
||||||
|
|
||||||
|
if len(tl) == 0:
|
||||||
|
self.wg_autostart.configure(state='disabled')
|
||||||
|
|
||||||
|
if self.selected_option.get() >= 1:
|
||||||
|
Path.write_text(path_to_file, select_tl)
|
||||||
|
|
||||||
|
except IndexError:
|
||||||
|
self.selected_option.set(1)
|
||||||
|
|
||||||
|
OnOff.on_off(self)
|
||||||
|
|
||||||
|
|
||||||
|
class OnOff:
|
||||||
|
"""
|
||||||
|
Here it is checked whether the path to the file is there if not it is created.
|
||||||
|
Set (on), the selected tunnel is displayed in the label.
|
||||||
|
At (off) the label is first emptied then filled with No Autoconnect
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
|
||||||
|
self.wg_autostart = None
|
||||||
|
self.selected_option = None
|
||||||
|
self.auto_con = None
|
||||||
|
self.autoconnect = None
|
||||||
|
self.autoconnect_var = None
|
||||||
|
self.lb_frame_buttons = None
|
||||||
|
|
||||||
|
def on_off(self):
|
||||||
|
|
||||||
|
if Path.exists(path_to_file):
|
||||||
|
self.selected_option.set(1)
|
||||||
|
self.autoconnect_var.set('')
|
||||||
|
if not Path.is_dir(Path('/etc/wire_py')):
|
||||||
|
Path.mkdir(Path('/etc/wire_py'))
|
||||||
|
self.auto_con = Path.read_text(path_to_file)
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
|
self.wg_autostart.configure(state='disabled')
|
||||||
|
self.auto_con = 'no Autoconnect'
|
||||||
|
self.autoconnect_var.set('')
|
||||||
|
self.autoconnect_var = tk.StringVar()
|
||||||
|
self.autoconnect_var.set(self.auto_con)
|
||||||
|
self.autoconnect = tk.Label(self, textvariable=self.autoconnect_var,padx=5,
|
||||||
|
background=back_gd, foreground=font_color)
|
||||||
|
self.autoconnect.config(font=('Ubuntu', 11))
|
||||||
|
self.autoconnect.grid(column=0, row=4, sticky='ne', pady=20)
|
||||||
|
|
||||||
|
|
||||||
class ExportTunnels:
|
class ExportTunnels:
|
||||||
|
"""
|
||||||
|
This will export the tunnels.
|
||||||
|
A zipfile with current date and time is created
|
||||||
|
in the user's home directory with correct right
|
||||||
|
"""
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def wg_export():
|
def wg_export():
|
||||||
|
_u1 = str(_u[6:])
|
||||||
|
now_time = datetime.now()
|
||||||
|
now_datetime = now_time.strftime('wg-exp-' + '%m-%d-%Y' + '-' + '%H:%M')
|
||||||
|
tl = ListTunnels.tl_list()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
wg_exp = os.popen('nmcli con show | grep -iPo "(.*)(wireguard)"').read().split()
|
if len(tl) != 0:
|
||||||
wg_exp = wg_exp[1]
|
wg_tar = str(_u) + '/' + now_datetime
|
||||||
return wg_exp
|
shutil.copytree('/etc/wire_py', '/tmp/wire_py', dirs_exist_ok=True)
|
||||||
except IndexError:
|
source = Path('/tmp/wire_py')
|
||||||
|
Path.unlink(Path(source) / 'wg_py', missing_ok=True)
|
||||||
|
Path.unlink(Path(source) / '.keys', missing_ok=True)
|
||||||
|
shutil.make_archive(wg_tar, 'zip', source)
|
||||||
|
shutil.chown(wg_tar + '.zip', 1000, 1000)
|
||||||
|
shutil.rmtree(source)
|
||||||
|
with zipfile.ZipFile((wg_tar + '.zip'), 'r') as zf:
|
||||||
|
if len(zf.namelist()) != 0:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_vpn.png'
|
||||||
|
wt = 'Export Successful'
|
||||||
|
msg_t = 'Your zip file is in home directory'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/error.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Export error'
|
||||||
|
msg_t = 'Export failed! Please try again'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Select tunnel'
|
||||||
|
msg_t = 'Please first import tunnel.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
except TypeError:
|
||||||
pass
|
pass
|
455
wg_main.py
Executable file
@ -0,0 +1,455 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
|
||||||
|
import tkinter as tk
|
||||||
|
from subprocess import check_call
|
||||||
|
from tkinter import *
|
||||||
|
from pathlib import Path
|
||||||
|
from tkinter import ttk
|
||||||
|
from wg_func import (TunnelActiv, ListTunnels, ImportTunnel, ConToDict, GreenLabel, StartStopBTN, ShowAddress,
|
||||||
|
FileHandle, ExportTunnels, OnOff, msg_window, WirePyUpdate, res, version, Themes, bg, font_color,
|
||||||
|
path_to_file2, back_gd, fore_gd)
|
||||||
|
|
||||||
|
label_bg = '#d9d9d9'
|
||||||
|
if bg == 'black':
|
||||||
|
back_gd = '#424242'
|
||||||
|
fore_gd = 'white'
|
||||||
|
lbox_color = '#5c5c5c'
|
||||||
|
font_color_update = 'yellow'
|
||||||
|
else:
|
||||||
|
back_gd = '#f5f6f7'
|
||||||
|
fore_gd = 'black'
|
||||||
|
lbox_color = 'white'
|
||||||
|
lbox_font_color = 'grey'
|
||||||
|
font_color_update = 'green'
|
||||||
|
|
||||||
|
class MainWindow(tk.Tk):
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
super().__init__(*args, **kwargs)
|
||||||
|
|
||||||
|
self.switch_on = None
|
||||||
|
self.switch_off = None
|
||||||
|
self.x_width = 600
|
||||||
|
self.y_height = 340
|
||||||
|
self.monitor_center_x = self.winfo_screenwidth() / 2 - (self.x_width / 2)
|
||||||
|
self.monitor_center_y = self.winfo_screenheight() / 2 - (self.y_height / 2)
|
||||||
|
self.resizable(width=False, height=False)
|
||||||
|
self.title('Wire-Py')
|
||||||
|
self.configure(background=back_gd)
|
||||||
|
self.geometry('%dx%d+%d+%d' % (self.x_width, self.y_height, self.monitor_center_x, self.monitor_center_y))
|
||||||
|
self.columnconfigure(0, weight=1)
|
||||||
|
self.rowconfigure(0, weight=1)
|
||||||
|
self.style = ttk.Style(self)
|
||||||
|
self.style.theme_use(bg)
|
||||||
|
|
||||||
|
''' Load the image file from disk. '''
|
||||||
|
self.wg_icon = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn.png')
|
||||||
|
# Set it as the window icon.
|
||||||
|
self.iconphoto(True, self.wg_icon)
|
||||||
|
|
||||||
|
#Set on or off in file
|
||||||
|
def on_off():
|
||||||
|
if set_option.get() == 1:
|
||||||
|
with open(path_to_file2, 'w') as set_file2:
|
||||||
|
set_file2.write('Update off')
|
||||||
|
|
||||||
|
if set_option.get() == 0:
|
||||||
|
with open(path_to_file2, 'w') as set_file2:
|
||||||
|
set_file2.write('Update on')
|
||||||
|
|
||||||
|
# App Menu
|
||||||
|
self.app_menu = tk.Menu(self, borderwidth=0, tearoff=tk.NO, disabledforeground=font_color,
|
||||||
|
background=back_gd, foreground=fore_gd)
|
||||||
|
self.configure(menu=self.app_menu)
|
||||||
|
set_option = tk.IntVar()
|
||||||
|
|
||||||
|
self.settings = tk.Menu(self.app_menu, tearoff=tk.NO, background=back_gd)
|
||||||
|
self.settings.add_checkbutton(label='Disable updates', command=on_off,
|
||||||
|
variable=set_option, foreground=fore_gd)
|
||||||
|
self.settings.add_command(label='Dark', command=Themes.dark, background=back_gd, foreground=fore_gd)
|
||||||
|
self.settings.add_command(label='Light', command=Themes.light, background=back_gd, foreground=fore_gd)
|
||||||
|
self.to_load = tk.Menu(self.app_menu, tearoff=tk.NO, background=back_gd)
|
||||||
|
self.to_load.add_command(label='Download Update', command=WirePyUpdate.download,
|
||||||
|
foreground=fore_gd, background=back_gd)
|
||||||
|
self.app_menu.add_cascade(label=version, state='disabled')
|
||||||
|
self.app_menu.add_cascade(label='Options', menu=self.settings, background=back_gd, foreground=fore_gd)
|
||||||
|
self.app_menu.add_cascade(label='?')
|
||||||
|
|
||||||
|
if res == 'False':
|
||||||
|
set_option.set(value=1)
|
||||||
|
self.app_menu.add_cascade(label='Update search off', activebackground=back_gd,
|
||||||
|
activeforeground=fore_gd, background=back_gd)
|
||||||
|
elif res == 'No Internet Connection!':
|
||||||
|
self.app_menu.add_cascade(label='No Internet Connection!', foreground='red', activebackground=back_gd,
|
||||||
|
activeforeground='red')
|
||||||
|
elif res == 'No Updates':
|
||||||
|
self.app_menu.add_cascade(label='No Updates', activeforeground=fore_gd, activebackground=back_gd)
|
||||||
|
|
||||||
|
else:
|
||||||
|
set_option.set(value=0)
|
||||||
|
self.app_menu.add_cascade(label=f'Update {res} available!', menu=self.to_load, foreground=font_color_update,
|
||||||
|
activebackground=back_gd, activeforeground=font_color_update)
|
||||||
|
|
||||||
|
FrameWidgets(self).grid()
|
||||||
|
|
||||||
|
|
||||||
|
class FrameWidgets(ttk.Frame):
|
||||||
|
def __init__(self, container, **kwargs):
|
||||||
|
super().__init__(container, **kwargs)
|
||||||
|
self.auto_con = None
|
||||||
|
self.enp = None
|
||||||
|
self.DNS = None
|
||||||
|
self.add = None
|
||||||
|
self.data = None
|
||||||
|
self.peer = None
|
||||||
|
self.lb_tunnel = None
|
||||||
|
self.wg_read = None
|
||||||
|
self.wg_vpn_start = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn-start.png')
|
||||||
|
self.wg_vpn_stop = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn-stop.png')
|
||||||
|
self.imp_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_import.png')
|
||||||
|
self.tr_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_trash.png')
|
||||||
|
self.exp_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_export.png')
|
||||||
|
self.warning_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/64/error.png')
|
||||||
|
|
||||||
|
''' Show active Tunnel '''
|
||||||
|
self.a = TunnelActiv.active()
|
||||||
|
|
||||||
|
''' Label Frame 1 '''
|
||||||
|
self.lb_frame_btn_lbox = ttk.Frame(self)
|
||||||
|
self.lb_frame_btn_lbox.configure(relief='flat')
|
||||||
|
self.lb_frame_btn_lbox.grid(column=0, rowspan=4, row=0)
|
||||||
|
self.columnconfigure(0, weight=1)
|
||||||
|
self.rowconfigure(0, weight=1)
|
||||||
|
|
||||||
|
''' Label Frame 2 '''
|
||||||
|
self.lb_frame = ttk.Frame(self)
|
||||||
|
self.lb_frame.configure(relief='solid')
|
||||||
|
self.lb_frame.grid(column=2, row=1, sticky='snew', padx=20, pady=5)
|
||||||
|
self.columnconfigure(2, weight=1)
|
||||||
|
self.rowconfigure(1, weight=1)
|
||||||
|
|
||||||
|
''' Label Frame 3 '''
|
||||||
|
self.lb_frame2 = ttk.Frame(self)
|
||||||
|
self.lb_frame2.configure(relief='solid')
|
||||||
|
self.lb_frame2.grid(column=2, row=2, sticky='snew', padx=20, pady=5)
|
||||||
|
self.columnconfigure(2, weight=1)
|
||||||
|
self.rowconfigure(2, weight=1)
|
||||||
|
|
||||||
|
''' Show active Label '''
|
||||||
|
self.select_tunnel = None
|
||||||
|
self.lb = tk.Label(self, text='Active: ', background=back_gd, foreground=fore_gd)
|
||||||
|
self.lb.config(font=('Ubuntu', 11, 'bold'))
|
||||||
|
self.lb.grid(column=2, row=0, padx=15, sticky='w')
|
||||||
|
self.columnconfigure(2, weight=1)
|
||||||
|
self.rowconfigure(0, weight=1)
|
||||||
|
|
||||||
|
''' Label to Show active Tunnel '''
|
||||||
|
self.StrVar = tk.StringVar(value=self.a)
|
||||||
|
GreenLabel.green_show_label(self)
|
||||||
|
|
||||||
|
''' Interface Label '''
|
||||||
|
self.interface = tk.Label(self.lb_frame, text='Interface', background=back_gd, foreground=font_color)
|
||||||
|
self.interface.grid(column=0, row=2, sticky='we', padx=120)
|
||||||
|
self.interface.config(font=('Ubuntu', 9))
|
||||||
|
|
||||||
|
''' Peer Label '''
|
||||||
|
self.peer = tk.Label(self.lb_frame2, text='Peer', background=back_gd, foreground=font_color)
|
||||||
|
self.peer.config(font=('Ubuntu', 9))
|
||||||
|
self.peer.grid(column=0, row=3, sticky='we', padx=130)
|
||||||
|
|
||||||
|
''' Listbox with Scrollbar '''
|
||||||
|
def enable_check_box(event):
|
||||||
|
tl = ListTunnels.tl_list()
|
||||||
|
if len(tl) != 0:
|
||||||
|
self.wg_autostart.configure(state='normal')
|
||||||
|
self.lb_rename.config(state='normal')
|
||||||
|
self.lb_rename.delete(0, tk.END)
|
||||||
|
self.btn_rename.config(state='normal')
|
||||||
|
|
||||||
|
self.l_box = tk.Listbox(self.lb_frame_btn_lbox, background=lbox_color, foreground=fore_gd,
|
||||||
|
selectmode='single')
|
||||||
|
self.l_box.config(relief='ridge')
|
||||||
|
self.l_box.config(font=('Ubuntu', 12, 'bold'))
|
||||||
|
self.l_box.grid(column=1, rowspan=4, row=0, sticky='ns')
|
||||||
|
self.l_box.event_add('<<ClickEvent>>', '<Button-1>')
|
||||||
|
self.l_box.bind('<<ClickEvent>>', enable_check_box)
|
||||||
|
self.scrollbar = ttk.Scrollbar(self.lb_frame_btn_lbox, orient='vertical', command=self.l_box.yview)
|
||||||
|
self.scrollbar.grid(column=1, rowspan=4, row=0, sticky='nse')
|
||||||
|
self.l_box.configure(yscrollcommand=self.scrollbar.set)
|
||||||
|
self.rowconfigure(0, weight=1)
|
||||||
|
|
||||||
|
''' Tunnel List '''
|
||||||
|
self.tl = ListTunnels.tl_list()
|
||||||
|
for tunnels in self.tl:
|
||||||
|
self.l_box.insert("end", tunnels)
|
||||||
|
self.l_box.update()
|
||||||
|
|
||||||
|
''' Button Vpn '''
|
||||||
|
if self.a != '':
|
||||||
|
StartStopBTN.button_stop(self)
|
||||||
|
wg_read = Path('/etc/wire_py') / str(self.a + '.conf')
|
||||||
|
with open(wg_read, 'r') as file:
|
||||||
|
data = ConToDict.covert_to_dict(file)
|
||||||
|
|
||||||
|
''' Address Label '''
|
||||||
|
ShowAddress.init_and_report(self, data)
|
||||||
|
ShowAddress.show_data(self)
|
||||||
|
else:
|
||||||
|
StartStopBTN.button_start(self)
|
||||||
|
|
||||||
|
''' Address Label '''
|
||||||
|
self.add = tk.StringVar()
|
||||||
|
self.DNS = tk.StringVar()
|
||||||
|
self.enp = tk.StringVar()
|
||||||
|
ShowAddress.label_empty(self)
|
||||||
|
ShowAddress.show_data(self)
|
||||||
|
|
||||||
|
''' Button Import '''
|
||||||
|
self.btn_i = tk.Button(self.lb_frame_btn_lbox,
|
||||||
|
image=self.imp_pic, bd=0,
|
||||||
|
command=lambda: ImportTunnel.wg_import_select(self), activebackground=back_gd,
|
||||||
|
background=back_gd, borderwidth=0, highlightthickness=0)
|
||||||
|
self.btn_i.grid(column=0, row=1, padx=15, pady=8)
|
||||||
|
|
||||||
|
def delete():
|
||||||
|
|
||||||
|
try:
|
||||||
|
self.select_tunnel = self.l_box.curselection()
|
||||||
|
select_tl = self.l_box.get(self.select_tunnel[0])
|
||||||
|
with open('/etc/wire_py/' + select_tl + '.conf', 'r+') as file2:
|
||||||
|
key = ConToDict.covert_to_dict(file2)
|
||||||
|
pre_key = key[3]
|
||||||
|
check_call(['nmcli', 'connection', 'delete', select_tl])
|
||||||
|
self.l_box.delete(self.select_tunnel[0])
|
||||||
|
if Path.is_file(Path('/etc/wire_py/wg_py')):
|
||||||
|
path_to_file = Path('/etc/wire_py') / 'wg_py'
|
||||||
|
a_con = Path.read_text(path_to_file)
|
||||||
|
if select_tl == a_con:
|
||||||
|
self.selected_option.set(0)
|
||||||
|
self.autoconnect_var.set('no Autoconnect')
|
||||||
|
self.wg_autostart.configure(state='disabled')
|
||||||
|
Path.unlink(path_to_file)
|
||||||
|
Path.unlink(Path('/etc/wire_py') / str(select_tl + '.conf'))
|
||||||
|
with open('/etc/wire_py/.keys', 'r') as readfile:
|
||||||
|
with open('/etc/wire_py/.keys2', 'w') as writefile:
|
||||||
|
for line in readfile:
|
||||||
|
if pre_key not in line.strip("\n"):
|
||||||
|
writefile.write(line)
|
||||||
|
file_one = Path('/etc/wire_py/.keys2')
|
||||||
|
file_two = file_one.with_name('.keys')
|
||||||
|
file_one.replace(file_two)
|
||||||
|
|
||||||
|
''' for disable checkbox when Listbox empty '''
|
||||||
|
tl = ListTunnels.tl_list()
|
||||||
|
if len(tl) == 0:
|
||||||
|
self.wg_autostart.configure(state='disabled')
|
||||||
|
if self.a != '' and self.a == select_tl:
|
||||||
|
self.StrVar.set(value='')
|
||||||
|
StartStopBTN.button_start(self)
|
||||||
|
self.l_box.update()
|
||||||
|
|
||||||
|
''' Address Label '''
|
||||||
|
self.add.set('')
|
||||||
|
self.DNS.set('')
|
||||||
|
self.enp.set('')
|
||||||
|
return select_tl
|
||||||
|
except IndexError:
|
||||||
|
tl = ListTunnels.tl_list()
|
||||||
|
if len(tl) != 0:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Select tunnel'
|
||||||
|
msg_t = 'Please select a tunnel from the list.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Select tunnel'
|
||||||
|
msg_t = 'Please first import tunnel.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
''' Button Trash '''
|
||||||
|
self.btn_tr = tk.Button(self.lb_frame_btn_lbox, image=self.tr_pic, bd=0, command=delete,
|
||||||
|
activebackground=back_gd, background=back_gd, borderwidth=0, highlightthickness=0)
|
||||||
|
self.btn_tr.grid(column=0, row=2, padx=15, pady=8)
|
||||||
|
|
||||||
|
''' Button Export '''
|
||||||
|
self.btn_exp = tk.Button(self.lb_frame_btn_lbox, image=self.exp_pic, bd=0, command=ExportTunnels.wg_export,
|
||||||
|
activebackground=back_gd, background=back_gd, borderwidth=0, highlightthickness=0)
|
||||||
|
self.btn_exp.grid(column=0, row=3, padx=15, pady=8)
|
||||||
|
|
||||||
|
''' Label Entry '''
|
||||||
|
self.lb_rename = ttk.Entry(self, width=20)
|
||||||
|
self.lb_rename.grid(column=2, row=4, padx=30, pady=5, sticky='w')
|
||||||
|
self.lb_rename.insert(0, 'Max. 12 characters!')
|
||||||
|
self.lb_rename.config(state='disable')
|
||||||
|
|
||||||
|
def tl_rename():
|
||||||
|
special_characters = ['\\', '/', '{', '}', ' ']
|
||||||
|
|
||||||
|
if len(self.lb_rename.get()) > 12:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Renaming not possible'
|
||||||
|
msg_t = 'The new name may contain only 12 characters.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
elif len(self.lb_rename.get()) == 0:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Renaming not possible'
|
||||||
|
msg_t = 'At least one character must be entered.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
elif any(ch in special_characters for ch in self.lb_rename.get()):
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Renaming not possible'
|
||||||
|
msg_t = 'No valid sign. These must not be used.\nBlank, Slash, Backslash and { }\n'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
|
try:
|
||||||
|
self.select_tunnel = self.l_box.curselection()
|
||||||
|
select_tl = self.l_box.get(self.select_tunnel[0])
|
||||||
|
|
||||||
|
''' nmcli connection modify old connection.id iphone '''
|
||||||
|
check_call(['nmcli', 'connection', 'modify', select_tl, 'connection.id', self.lb_rename.get()])
|
||||||
|
source = Path('/etc/wire_py') / str(select_tl + '.conf')
|
||||||
|
destination = source.with_name(str(self.lb_rename.get() + '.conf'))
|
||||||
|
source.replace(destination)
|
||||||
|
self.l_box.delete(self.select_tunnel[0])
|
||||||
|
self.l_box.insert("end", self.lb_rename.get())
|
||||||
|
self.l_box.update()
|
||||||
|
new_a_connect = self.lb_rename.get()
|
||||||
|
self.lb_rename.delete(0, tk.END)
|
||||||
|
if self.a != '' and self.a == select_tl:
|
||||||
|
self.a = TunnelActiv.active()
|
||||||
|
self.StrVar.set(value=self.a)
|
||||||
|
if Path.is_file(Path('/etc/wire_py/wg_py')):
|
||||||
|
path_to_file = Path('/etc/wire_py') / 'wg_py'
|
||||||
|
a_con = Path.read_text(path_to_file)
|
||||||
|
if select_tl == a_con:
|
||||||
|
self.autoconnect_var.set(value=new_a_connect)
|
||||||
|
Path.write_text(path_to_file, new_a_connect)
|
||||||
|
return select_tl
|
||||||
|
|
||||||
|
except IndexError:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Renaming not possible'
|
||||||
|
msg_t = 'Please select a tunnel from the list.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
''' Button Rename '''
|
||||||
|
self.btn_rename = ttk.Button(self, text='Rename', state='disable', command=tl_rename, padding=4)
|
||||||
|
self.btn_rename.grid(column=2, row=4, padx=20, pady=10, sticky='e')
|
||||||
|
|
||||||
|
''' Check Buttons '''
|
||||||
|
self.selected_option = tk.IntVar()
|
||||||
|
self.autoconnect_var = tk.StringVar()
|
||||||
|
self.autoconnect_var.set(self.auto_con)
|
||||||
|
self.autoconnect = tk.Label(self, textvariable=self.autoconnect_var, fg='blue', padx=5)
|
||||||
|
self.autoconnect.config(font=('Ubuntu', 11))
|
||||||
|
self.autoconnect.grid(column=0, row=4, sticky='ne', pady=20)
|
||||||
|
self.wg_autostart = tk.Checkbutton(self,
|
||||||
|
text='Autoconnect on:',
|
||||||
|
variable=self.selected_option,
|
||||||
|
command=lambda: FileHandle.box_set(self), activebackground=back_gd,
|
||||||
|
background=back_gd, foreground=fore_gd, selectcolor=back_gd,
|
||||||
|
highlightthickness=0)
|
||||||
|
self.wg_autostart.grid(column=0, row=4, pady=19, padx=15, sticky='nw')
|
||||||
|
|
||||||
|
OnOff.on_off(self)
|
||||||
|
|
||||||
|
def wg_switch(self):
|
||||||
|
self.a = TunnelActiv.active()
|
||||||
|
try:
|
||||||
|
if self.a == '':
|
||||||
|
|
||||||
|
StartStopBTN.button_start(self)
|
||||||
|
self.select_tunnel = self.l_box.curselection()
|
||||||
|
select_tl = self.l_box.get(self.select_tunnel[0])
|
||||||
|
check_call(['nmcli', 'connection', 'up', select_tl])
|
||||||
|
wg_read = Path('/etc/wire_py') / str(select_tl + '.conf')
|
||||||
|
with open(wg_read, 'r') as file:
|
||||||
|
data = ConToDict.covert_to_dict(file)
|
||||||
|
|
||||||
|
''' Address Label '''
|
||||||
|
ShowAddress.init_and_report(self, data)
|
||||||
|
ShowAddress.show_data(self)
|
||||||
|
|
||||||
|
''' Button Start/Stop '''
|
||||||
|
StartStopBTN.button_stop(self)
|
||||||
|
self.a = TunnelActiv.active()
|
||||||
|
self.StrVar = tk.StringVar()
|
||||||
|
self.StrVar.set(self.a)
|
||||||
|
GreenLabel.green_show_label(self)
|
||||||
|
|
||||||
|
elif self.a != '':
|
||||||
|
|
||||||
|
''' Button Start/Stop '''
|
||||||
|
StartStopBTN.button_stop(self)
|
||||||
|
check_call(['nmcli', 'connection', 'down', self.a])
|
||||||
|
|
||||||
|
''' Button Start/Stop '''
|
||||||
|
StartStopBTN.button_start(self)
|
||||||
|
self.a = TunnelActiv.active()
|
||||||
|
self.StrVar.set('')
|
||||||
|
GreenLabel.green_show_label(self)
|
||||||
|
|
||||||
|
''' Address Label '''
|
||||||
|
self.add.set('')
|
||||||
|
self.DNS.set('')
|
||||||
|
self.enp.set('')
|
||||||
|
ShowAddress.show_data(self)
|
||||||
|
|
||||||
|
except IndexError:
|
||||||
|
|
||||||
|
tl = ListTunnels.tl_list()
|
||||||
|
if len(tl) != 0:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Select tunnel'
|
||||||
|
msg_t = 'Please select a tunnel from the list.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
|
"""img_w, img_i, w_title, w_txt hand over"""
|
||||||
|
iw = r'/usr/share/icons/wp-icons/64/info.png'
|
||||||
|
ii = r'/usr/share/icons/wp-icons/48/wg_msg.png'
|
||||||
|
wt = 'Select tunnel'
|
||||||
|
msg_t = 'Please first import tunnel.'
|
||||||
|
msg_window(iw, ii, wt, msg_t)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
window = MainWindow()
|
||||||
|
"""
|
||||||
|
the hidden files are hidden in Filedialog
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
window.tk.call('tk_getOpenFile', '-foobarbaz')
|
||||||
|
except TclError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
window.tk.call('set', '::tk::dialog::file::showHiddenBtn', '0')
|
||||||
|
window.tk.call('set', '::tk::dialog::file::showHiddenVar', '0')
|
||||||
|
window.mainloop()
|
||||||
|
|
10
wg_start.service
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
[Unit]
|
||||||
|
Description=Automatic Tunnel Start
|
||||||
|
After=network-online.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=oneshot
|
||||||
|
ExecStartPre=/bin/sleep 5
|
||||||
|
ExecStart=/usr/bin/start_wg.py
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
6
wirepy.py
Executable file
@ -0,0 +1,6 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
from subprocess import check_call
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
|
Path.write_text(Path('/tmp/_u'), str(Path.home()))
|
||||||
|
check_call(['pkexec', '/usr/bin/wg_main.py'])
|
Before Width: | Height: | Size: 5.7 KiB After Width: | Height: | Size: 5.7 KiB |
BIN
wp-icons/128/info.png
Normal file
After Width: | Height: | Size: 5.7 KiB |
BIN
wp-icons/128/wg_export.png
Normal file
After Width: | Height: | Size: 16 KiB |
BIN
wp-icons/128/wg_import.png
Normal file
After Width: | Height: | Size: 13 KiB |
BIN
wp-icons/128/wg_msg.png
Normal file
After Width: | Height: | Size: 14 KiB |
BIN
wp-icons/128/wg_trash.png
Normal file
After Width: | Height: | Size: 14 KiB |
BIN
wp-icons/128/wg_vpn-start.png
Normal file
After Width: | Height: | Size: 16 KiB |
BIN
wp-icons/128/wg_vpn-stop.png
Normal file
After Width: | Height: | Size: 15 KiB |
BIN
wp-icons/128/wg_vpn.png
Normal file
After Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 12 KiB |
BIN
wp-icons/256/info.png
Normal file
After Width: | Height: | Size: 10 KiB |
Before Width: | Height: | Size: 28 KiB After Width: | Height: | Size: 28 KiB |
Before Width: | Height: | Size: 32 KiB After Width: | Height: | Size: 32 KiB |
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 18 KiB |
Before Width: | Height: | Size: 24 KiB After Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 26 KiB After Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 24 KiB After Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 18 KiB |
Before Width: | Height: | Size: 5.1 KiB After Width: | Height: | Size: 5.1 KiB |
BIN
wp-icons/32/info.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
wp-icons/32/wg_export.png
Normal file
After Width: | Height: | Size: 6.1 KiB |
BIN
wp-icons/32/wg_import.png
Normal file
After Width: | Height: | Size: 6.0 KiB |
BIN
wp-icons/32/wg_msg.png
Normal file
After Width: | Height: | Size: 5.7 KiB |
BIN
wp-icons/32/wg_trash.png
Normal file
After Width: | Height: | Size: 6.1 KiB |
BIN
wp-icons/32/wg_vpn-start.png
Normal file
After Width: | Height: | Size: 6.2 KiB |
BIN
wp-icons/32/wg_vpn-stop.png
Normal file
After Width: | Height: | Size: 6.1 KiB |
BIN
wp-icons/32/wg_vpn.png
Normal file
After Width: | Height: | Size: 5.8 KiB |
BIN
wp-icons/48/error.png
Normal file
After Width: | Height: | Size: 5.7 KiB |
BIN
wp-icons/48/info.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
Before Width: | Height: | Size: 7.3 KiB After Width: | Height: | Size: 7.3 KiB |
Before Width: | Height: | Size: 17 KiB After Width: | Height: | Size: 17 KiB |
BIN
wp-icons/48/wg_msg.png
Normal file
After Width: | Height: | Size: 7.0 KiB |
Before Width: | Height: | Size: 7.3 KiB After Width: | Height: | Size: 7.3 KiB |
Before Width: | Height: | Size: 7.3 KiB After Width: | Height: | Size: 7.3 KiB |
Before Width: | Height: | Size: 7.1 KiB After Width: | Height: | Size: 7.1 KiB |
Before Width: | Height: | Size: 17 KiB After Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 2.7 KiB After Width: | Height: | Size: 2.7 KiB |
BIN
wp-icons/64/info.png
Normal file
After Width: | Height: | Size: 2.7 KiB |
BIN
wp-icons/64/wg_export.png
Normal file
After Width: | Height: | Size: 9.0 KiB |
BIN
wp-icons/64/wg_import.png
Normal file
After Width: | Height: | Size: 8.2 KiB |
BIN
wp-icons/64/wg_msg.png
Normal file
After Width: | Height: | Size: 8.2 KiB |
Before Width: | Height: | Size: 8.3 KiB After Width: | Height: | Size: 8.3 KiB |
BIN
wp-icons/64/wg_vpn-start.png
Normal file
After Width: | Height: | Size: 9.0 KiB |
BIN
wp-icons/64/wg_vpn-stop.png
Normal file
After Width: | Height: | Size: 8.7 KiB |
BIN
wp-icons/64/wg_vpn.png
Normal file
After Width: | Height: | Size: 8.4 KiB |