Compare commits
	
		
			23 Commits
		
	
	
		
			1.11.1124
			...
			03a7e48018
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 03a7e48018 | |||
| 090842ab28 | |||
| 9eb99f0859 | |||
| feb6217637 | |||
| 5f6aaa6cf1 | |||
| 63ed0abc98 | |||
| 3102c685fd | |||
| ec10f912ea | |||
| 96164eb132 | |||
| a19f889950 | |||
| de2929896d | |||
| f9d4256679 | |||
| a0b895438c | |||
| 4c89488950 | |||
| c0ae2d2b75 | |||
| e4774abf19 | |||
| 7b1e543428 | |||
| 6f83fc7162 | |||
| b70400b456 | |||
| e25bc154ea | |||
| 7aa3cd75fe | |||
| 0b9eec8d1d | |||
| b9083d4698 | 
							
								
								
									
										126
									
								
								.idea/workspace.xml
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -4,20 +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="- methods from class MainWindow move to class FrameWidgets for active color_label when theme change
- optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets
- add new Frame for Widgets on Bottom
- optimize from tkinter * to from tkinter import filedialog, ttk, TclError"> |     <list default="true" id="940e1630-c825-4d4c-be80-bc11f543c122" name="Changes" comment="- Optimize Class and Tooltip"> | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/128/error.png" afterDir="false" /> |       <change afterPath="$PROJECT_DIR$/run_as" afterDir="false" /> | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/128/info.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/256/error.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/256/info.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/32/error.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/32/info.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/48/error.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/48/info.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/64/error.png" afterDir="false" /> |  | ||||||
|       <change afterPath="$PROJECT_DIR$/lx-icons/64/info.png" 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$/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$/install" beforeDir="false" afterPath="$PROJECT_DIR$/install" afterDir="false" /> | ||||||
|       <change beforePath="$PROJECT_DIR$/wg_func.py" beforeDir="false" afterPath="$PROJECT_DIR$/cls_mth_fc.py" afterDir="false" /> |       <change beforePath="$PROJECT_DIR$/settings" beforeDir="false" /> | ||||||
|  |       <change beforePath="$PROJECT_DIR$/start_wg.py" beforeDir="false" afterPath="$PROJECT_DIR$/start_wg.py" afterDir="false" /> | ||||||
|  |       <change beforePath="$PROJECT_DIR$/theme" beforeDir="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$/wg_main.py" beforeDir="false" afterPath="$PROJECT_DIR$/wg_main.py" afterDir="false" /> | ||||||
|     </list> |     </list> | ||||||
|     <option name="SHOW_DIALOG" value="false" /> |     <option name="SHOW_DIALOG" value="false" /> | ||||||
| @@ -35,7 +30,7 @@ | |||||||
|   <component name="Git.Settings"> |   <component name="Git.Settings"> | ||||||
|     <option name="RECENT_BRANCH_BY_REPOSITORY"> |     <option name="RECENT_BRANCH_BY_REPOSITORY"> | ||||||
|       <map> |       <map> | ||||||
|         <entry key="$PROJECT_DIR$" value="1.11.0824" /> |         <entry key="$PROJECT_DIR$" value="main" /> | ||||||
|       </map> |       </map> | ||||||
|     </option> |     </option> | ||||||
|     <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" /> |     <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" /> | ||||||
| @@ -56,28 +51,27 @@ | |||||||
|     <option name="hideEmptyMiddlePackages" value="true" /> |     <option name="hideEmptyMiddlePackages" value="true" /> | ||||||
|     <option name="showLibraryContents" value="true" /> |     <option name="showLibraryContents" value="true" /> | ||||||
|   </component> |   </component> | ||||||
|   <component name="PropertiesComponent"><![CDATA[{ |   <component name="PropertiesComponent">{ | ||||||
|   "keyToString": { |   "keyToString": { | ||||||
|     "ASKED_ADD_EXTERNAL_FILES": "true", |     "ASKED_ADD_EXTERNAL_FILES": "true", | ||||||
|     "Python.INSTALL.executor": "Run", |     "Python.INSTALL.executor": "Run", | ||||||
|     "Python.install.executor": "Run", |     "Python.install.executor": "Run", | ||||||
|     "Python.main.executor": "Run", |     "Python.main.executor": "Run", | ||||||
|     "Python.messagebox.executor": "Run", |     "Python.messagebox.executor": "Run", | ||||||
|     "Python.start_wg.executor": "Run", |     "Python.start_wg.executor": "Run", | ||||||
|     "Python.testtheme.executor": "Run", |     "Python.testtheme.executor": "Run", | ||||||
|     "Python.wg_func.executor": "Run", |     "Python.wg_func.executor": "Run", | ||||||
|     "Python.wg_main.executor": "Run", |     "Python.wg_main.executor": "Run", | ||||||
|     "RunOnceActivity.ShowReadmeOnStart": "true", |     "RunOnceActivity.ShowReadmeOnStart": "true", | ||||||
|     "Shell Script.install.executor": "Run", |     "Shell Script.install.executor": "Run", | ||||||
|     "Shell Script.run_as.executor": "Run", |     "Shell Script.run_as.executor": "Run", | ||||||
|     "git-widget-placeholder": "1.11.0824", |     "git-widget-placeholder": "main", | ||||||
|     "last_opened_file_path": "/home/punix/Pyapps/wire-py/lx-icons", |     "last_opened_file_path": "/home/punix/Pyapps/wire-py", | ||||||
|     "settings.editor.selected.configurable": "reference.settingsdialog.IDE.editor.colors" |     "settings.editor.selected.configurable": "reference.settingsdialog.IDE.editor.colors" | ||||||
|   } |   } | ||||||
| }]]></component> | }</component> | ||||||
|   <component name="RecentsManager"> |   <component name="RecentsManager"> | ||||||
|     <key name="CopyFile.RECENT_KEYS"> |     <key name="CopyFile.RECENT_KEYS"> | ||||||
|       <recent name="$PROJECT_DIR$/lx-icons" /> |  | ||||||
|       <recent name="$PROJECT_DIR$" /> |       <recent name="$PROJECT_DIR$" /> | ||||||
|     </key> |     </key> | ||||||
|     <key name="MoveFile.RECENT_KEYS"> |     <key name="MoveFile.RECENT_KEYS"> | ||||||
| @@ -141,7 +135,7 @@ | |||||||
|   <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> | ||||||
| @@ -154,6 +148,30 @@ | |||||||
|       <option name="presentableId" value="Default" /> |       <option name="presentableId" value="Default" /> | ||||||
|       <updated>1723279982210</updated> |       <updated>1723279982210</updated> | ||||||
|     </task> |     </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"> |     <task id="LOCAL-00020" summary="columnconfigure on all widgets set"> | ||||||
|       <option name="closed" value="true" /> |       <option name="closed" value="true" /> | ||||||
|       <created>1724778892233</created> |       <created>1724778892233</created> | ||||||
| @@ -522,37 +540,18 @@ | |||||||
|       <option name="project" value="LOCAL" /> |       <option name="project" value="LOCAL" /> | ||||||
|       <updated>1729938941027</updated> |       <updated>1729938941027</updated> | ||||||
|     </task> |     </task> | ||||||
|     <task id="LOCAL-00066" summary="- methods from class MainWindow move to class FrameWidgets for active color_label when theme change
- optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets
- add new Frame for Widgets on Bottom
- optimize from tkinter * to from tkinter import filedialog, ttk, TclError"> |     <option name="localTasksCounter" value="66" /> | ||||||
|       <option name="closed" value="true" /> |  | ||||||
|       <created>1731097309468</created> |  | ||||||
|       <option name="number" value="00066" /> |  | ||||||
|       <option name="presentableId" value="LOCAL-00066" /> |  | ||||||
|       <option name="project" value="LOCAL" /> |  | ||||||
|       <updated>1731097309468</updated> |  | ||||||
|     </task> |  | ||||||
|     <task id="LOCAL-00067" summary="- methods from class MainWindow move to class FrameWidgets for active color_label when theme change
- optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets
- add new Frame for Widgets on Bottom
- optimize from tkinter * to from tkinter import filedialog, ttk, TclError"> |  | ||||||
|       <option name="closed" value="true" /> |  | ||||||
|       <created>1731097969343</created> |  | ||||||
|       <option name="number" value="00067" /> |  | ||||||
|       <option name="presentableId" value="LOCAL-00067" /> |  | ||||||
|       <option name="project" value="LOCAL" /> |  | ||||||
|       <updated>1731097969344</updated> |  | ||||||
|     </task> |  | ||||||
|     <task id="LOCAL-00068" summary="- methods from class MainWindow move to class FrameWidgets for active color_label when theme change
- optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets
- add new Frame for Widgets on Bottom
- optimize from tkinter * to from tkinter import filedialog, ttk, TclError"> |  | ||||||
|       <option name="closed" value="true" /> |  | ||||||
|       <created>1731098372497</created> |  | ||||||
|       <option name="number" value="00068" /> |  | ||||||
|       <option name="presentableId" value="LOCAL-00068" /> |  | ||||||
|       <option name="project" value="LOCAL" /> |  | ||||||
|       <updated>1731098372497</updated> |  | ||||||
|     </task> |  | ||||||
|     <option name="localTasksCounter" value="69" /> |  | ||||||
|     <servers /> |     <servers /> | ||||||
|   </component> |   </component> | ||||||
|   <component name="UnknownFeatures"> |   <component name="UnknownFeatures"> | ||||||
|     <option featureType="com.intellij.fileTypeFactory" implementationName="*.policy" /> |     <option featureType="com.intellij.fileTypeFactory" implementationName="*.policy" /> | ||||||
|   </component> |   </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"> | ||||||
| @@ -563,7 +562,7 @@ | |||||||
|                   <entry key="branch"> |                   <entry key="branch"> | ||||||
|                     <value> |                     <value> | ||||||
|                       <list> |                       <list> | ||||||
|                         <option value="1.11.0824" /> |                         <option value="origin/wire-py-reformat-14-08-2024" /> | ||||||
|                       </list> |                       </list> | ||||||
|                     </value> |                     </value> | ||||||
|                   </entry> |                   </entry> | ||||||
| @@ -572,11 +571,17 @@ | |||||||
|             </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="fix a filedialog for hidden Files work
install rollback to bash for start wirepy and wirepy rollback to bash" /> | ||||||
|     <MESSAGE value="install rollback bash to py wirepy and wirepy rollback to py" /> |     <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="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="replace tar with zip and Check if Zip file is empty" /> | ||||||
| @@ -601,8 +606,7 @@ | |||||||
|     <MESSAGE value=" - Add Options, Help, Update Label and Update Menubutton 
 - Theme now separate Light and Dark" /> |     <MESSAGE value=" - Add Options, Help, Update Label and Update Menubutton 
 - Theme now separate Light and Dark" /> | ||||||
|     <MESSAGE value="- Optimize Class. Move to wg_main Import Start/StopBTN and Tooltip" /> |     <MESSAGE value="- Optimize Class. Move to wg_main Import Start/StopBTN and Tooltip" /> | ||||||
|     <MESSAGE value="- Optimize Class and Tooltip" /> |     <MESSAGE value="- Optimize Class and Tooltip" /> | ||||||
|     <MESSAGE value="- methods from class MainWindow move to class FrameWidgets for active color_label when theme change
- optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets
- add new Frame for Widgets on Bottom
- optimize from tkinter * to from tkinter import filedialog, ttk, TclError" /> |     <option name="LAST_COMMIT_MESSAGE" value="- Optimize Class and Tooltip" /> | ||||||
|     <option name="LAST_COMMIT_MESSAGE" value="- methods from class MainWindow move to class FrameWidgets for active color_label when theme change
- optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets
- add new Frame for Widgets on Bottom
- optimize from tkinter * to from tkinter import filedialog, ttk, TclError" /> |  | ||||||
|   </component> |   </component> | ||||||
|   <component name="XDebuggerManager"> |   <component name="XDebuggerManager"> | ||||||
|     <breakpoint-manager> |     <breakpoint-manager> | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								Changelog
									
									
									
									
									
								
							
							
						
						| @@ -3,75 +3,55 @@ My standard System: Linux Mint 22 Cinnamon | |||||||
|  |  | ||||||
| ## [Unreleased] | ## [Unreleased] | ||||||
|  |  | ||||||
|  - os import in cls_mth_fc.py replaced by other methods |  - os import in wg_func replaced by other methods | ||||||
|  - If Wire-Py already runs, prevent further start |  - If Wire-Py already runs, prevent further start | ||||||
|  - for loops with lists replaced by List Comprehensions |  - for loops with lists replaced by List Comprehensions | ||||||
|  - Update search after start of Wire-Py |  - Update search after start of Wire-Py | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |   ### Added | ||||||
| 10-11-2024 | 07-11-2024 | ||||||
|  |  | ||||||
|  - Translate file de_De complete | - remove classes and add methods to class FrameWidgets (removed self errors) | ||||||
|  - new FrameWidget for rename Entry and rename Button |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |  | ||||||
| 09-11-2024 |  | ||||||
|  |  | ||||||
|  - Move Tips Method in separate class for Tooltips in another Apps |  | ||||||
|  - Move Version Variable in main script |  | ||||||
|  - Edit Class GiteaUpdate for requests in api_down and download |  | ||||||
|  - Description on Class GiteaUpdate |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |   ### Added | ||||||
| 08-11-2024 | 08-11-2024 | ||||||
|  |  | ||||||
|  - Preparation for language translation part 1 | - methods from class MainWindow move to class FrameWidgets for active color_label when theme change | ||||||
|  - separate folder for general icons | - optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets | ||||||
|  - install edit for new dir lx-icons | - add new Frame for Widgets on Bottom | ||||||
|  | - optimize from tkinter * to from tkinter import filedialog, ttk, TclError | ||||||
|  |  | ||||||
|   ### Added |  | ||||||
| 08-11-2024 |  | ||||||
|  |  | ||||||
|  - methods from class MainWindow move to class FrameWidgets for active color_label when theme change |  | ||||||
|  - optimize columnconfigure, rowconfigure in class MainWindow and FrameWidgets |  | ||||||
|  - add new Frame for Widgets on Bottom |  | ||||||
|  - optimize from tkinter * to from tkinter import filedialog, ttk, TclError |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |   ### Added | ||||||
| 07-11-2024 | 07-11-2024 | ||||||
|  |  | ||||||
|  - remove classes and add methods to class FrameWidgets (removed self errors) | - remove classes and add methods to class FrameWidgets (removed self errors) | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |   ### Added | ||||||
| 27-10-2024 | 27-10-2024 | ||||||
|  |  | ||||||
|  - Add Autoconnect settings to settings.conf | - Add Autoconnect settings to settings.conf | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |   ### Added | ||||||
| 26-10-2024 | 26-10-2024 | ||||||
|  |  | ||||||
|  - Add run_as Bash script and open_gitea.py python script | - Add run_as Bash script and open_gitea.py python script | ||||||
|  - Add Tooltip disable/enable | - Add Tooltip disable/enable | ||||||
|  - Rename settings to settings.conf for theme, updates and tooltip enable in one file | - Rename settings to settings.conf for theme, updates and tooltip enable in one file | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |   ### Added | ||||||
| 25-10-2024 | 25-10-2024 | ||||||
|  |  | ||||||
|  - Optimize Class and Tooltip | - Optimize Class and Tooltip | ||||||
|  |  | ||||||
|  |  | ||||||
|   ### Added |   ### Added | ||||||
| 21-10-2024 | 21-10-2024 | ||||||
|  |  | ||||||
|  - Optimize Class. Move to wg_main Import Start/StopBTN and Tooltip | - Optimize Class. Move to wg_main Import Start/StopBTN and Tooltip | ||||||
|  |  | ||||||
|  |  | ||||||
|  ### Added |  ### Added | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								install
									
									
									
									
									
								
							
							
						
						| @@ -7,11 +7,10 @@ BLUE='\033[30;1;34m' | |||||||
| install_file_with(){ | install_file_with(){ | ||||||
|   clear |   clear | ||||||
|   sudo apt install python3-tk && \ |   sudo apt install python3-tk && \ | ||||||
|   sudo cp -u wg_main.py start_wg.py cls_mth_fc.py wirepy.py run_as open_gitea.py /usr/bin/ && \ |   sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py run_as open_gitea.py /usr/bin/ && \ | ||||||
|   sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && sudo cp -u settings.conf /etc/wire_py/ && \ |   sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && sudo cp -u settings.conf /etc/wire_py/ && \ | ||||||
|   sudo cp -uR wp-icons lx-icons /usr/share/icons/ &&  sudo cp -uR TK-Themes /usr/share/ && \ |   sudo cp -uR wp-icons /usr/share/icons/ &&  sudo cp -uR TK-Themes /usr/share/ && \ | ||||||
|   sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \ |   sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \ | ||||||
|   sudo cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ |  | ||||||
|   sudo ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ |   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 org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||||
|   sudo cp -u Wire-Py.desktop /usr/share/applications/ && \ |   sudo cp -u Wire-Py.desktop /usr/share/applications/ && \ | ||||||
| @@ -22,11 +21,10 @@ install_file_with(){ | |||||||
| install_arch_d(){ | install_arch_d(){ | ||||||
|   clear |   clear | ||||||
|   sudo pacman -S --noconfirm tk python3 python-requests && \ |   sudo pacman -S --noconfirm tk python3 python-requests && \ | ||||||
|   sudo cp -u wg_main.py start_wg.py cls_mth_fc.py wirepy.py run_as open_gitea.py /usr/bin/ && \ |   sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py run_as open_gitea.py /usr/bin/ && \ | ||||||
|   sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && sudo cp -u settings.conf  /etc/wire_py/ && \ |   sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && sudo cp -u settings.conf  /etc/wire_py/ && \ | ||||||
|   sudo cp -uR wp-icons lx-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ |   sudo cp -uR wp-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ | ||||||
|   sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \ |   sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \ | ||||||
|   sudo cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ |  | ||||||
|   sudo ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ |   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 org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||||
|   sudo cp -u Wire-Py.desktop /usr/share/applications/ && \ |   sudo cp -u Wire-Py.desktop /usr/share/applications/ && \ | ||||||
| @@ -91,11 +89,10 @@ elif grep -i 'fedora' /etc/os-release > /dev/null 2>&1 | |||||||
|         if ! which python3-tkinter &> /dev/null |         if ! which python3-tkinter &> /dev/null | ||||||
|             then sudo dnf install python3-tkinter -y |             then sudo dnf install python3-tkinter -y | ||||||
|  |  | ||||||
|                 sudo cp -u wg_main.py start_wg.py cls_mth_fc.py wirepy.py run_as open_gitea.py /usr/bin/ && \ |                 sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py run_as open_gitea.py /usr/bin/ && \ | ||||||
|                 sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && \ |                 sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && \ | ||||||
|                 sudo cp -u settings.conf /etc/wire_py/ && \ |                 sudo cp -u settings.conf /etc/wire_py/ && \ | ||||||
|                 sudo cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ |                 sudo cp -uR wp-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ | ||||||
|                 sudo cp -uR wp-icons lx-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ |  | ||||||
|                 sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \ |                 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 ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ | ||||||
|                 sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ |                 sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||||
| @@ -108,11 +105,10 @@ elif grep -i 'suse' /etc/os-release > /dev/null 2>&1 | |||||||
|     then |     then | ||||||
|         if ! which python311-tk &> /dev/null |         if ! which python311-tk &> /dev/null | ||||||
|             then sudo zypper install python311-tk |             then sudo zypper install python311-tk | ||||||
|                  sudo cp -u wg_main.py start_wg.py cls_mth_fc.py wirepy.py run_as open_gitea.py /usr/bin/ && \ |                  sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py run_as open_gitea.py /usr/bin/ && \ | ||||||
|                  sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && \ |                  sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/.keys && \ | ||||||
|                  sudo cp -u settings.conf /etc/wire_py/ && \ |                  sudo cp -u settings.conf /etc/wire_py/ && \ | ||||||
|                  sudo cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ |                  sudo cp -uR wp-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ | ||||||
|                  sudo cp -uR wp-icons lx-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ |  | ||||||
|                  sudo chown -R root:root /etc/wire_py && sudo chmod 755 /etc/wire_py && \ |                  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 ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ | ||||||
|                  sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ |                  sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||||
|   | |||||||
| Before Width: | Height: | Size: 5.7 KiB | 
| Before Width: | Height: | Size: 5.7 KiB | 
| Before Width: | Height: | Size: 12 KiB | 
| Before Width: | Height: | Size: 10 KiB | 
| Before Width: | Height: | Size: 5.1 KiB | 
| Before Width: | Height: | Size: 1.6 KiB | 
| Before Width: | Height: | Size: 5.7 KiB | 
| Before Width: | Height: | Size: 2.2 KiB | 
| Before Width: | Height: | Size: 2.7 KiB | 
| Before Width: | Height: | Size: 2.7 KiB | 
| @@ -1,44 +1,35 @@ | |||||||
| """ Classes Method and functions for lx apps """ | """ Wireguard Classes and Method for Wire-Py """ | ||||||
| 
 | 
 | ||||||
| import gettext |  | ||||||
| import locale |  | ||||||
| import os | import os | ||||||
| import shutil | import shutil | ||||||
| import subprocess | import subprocess | ||||||
|  | import time | ||||||
| import tkinter as tk | import tkinter as tk | ||||||
| import zipfile | import zipfile | ||||||
| from datetime import datetime | from datetime import datetime | ||||||
| from pathlib import Path | from pathlib import Path | ||||||
|  | from subprocess import check_call | ||||||
| from tkinter import ttk | from tkinter import ttk | ||||||
| import requests | import requests | ||||||
| 
 | 
 | ||||||
| APP = 'cls_mth_fc' |  | ||||||
| LOCALE_DIR = "/usr/share/locale/" |  | ||||||
| locale.bindtextdomain(APP, LOCALE_DIR) |  | ||||||
| gettext.bindtextdomain(APP, LOCALE_DIR) |  | ||||||
| gettext.textdomain(APP) |  | ||||||
| _ = gettext.gettext |  | ||||||
| 
 | 
 | ||||||
| wg_set = Path('/etc/wire_py/settings.conf') | ''' 1 = 1. Year, 09 = Month of the Year, 2924 = Day and Year of the Year ''' | ||||||
|  | version = 'v. 1.11.0824' | ||||||
|  | 
 | ||||||
|  | path_to_file2 = Path('/etc/wire_py/settings.conf') | ||||||
| _u = Path.read_text(Path('/tmp/_u')) | _u = Path.read_text(Path('/tmp/_u')) | ||||||
| 
 | 
 | ||||||
|  | UPDATE_API_URL = 'https://git.ilunix.de/api/v1/repos/punix/Wire-Py/releases' | ||||||
| 
 | 
 | ||||||
| class GiteaUpdate: |  | ||||||
|     """ |  | ||||||
|     Calling api_down requests the URL and the version of the running script. |  | ||||||
|     Example: version = 'v. 1.1.1.1' GiteaUpdate.api_down(http://example.de, version) |  | ||||||
| 
 | 
 | ||||||
|     Calling download requests the download URL of the running script, | class WirePyUpdate: | ||||||
|     the taskbar image for the “Download OK” window, the taskbar image for the |  | ||||||
|     “Download error” window and the variable res |  | ||||||
|     """ |  | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def api_down(update_api_url, version): |     def api_down(): | ||||||
|         try: |         try: | ||||||
|             response = requests.get(update_api_url) |             response = requests.get(UPDATE_API_URL) | ||||||
|             response_dict = response.json() |             response_dict = response.json() | ||||||
|             response_dict = response_dict[0] |             response_dict = response_dict[0] | ||||||
|             with open(wg_set, 'r') as set_file: |             with open(path_to_file2, 'r') as set_file: | ||||||
|                 set_file = set_file.read() |                 set_file = set_file.read() | ||||||
|                 if 'on\n' in set_file: |                 if 'on\n' in set_file: | ||||||
|                     if version[3:] != response_dict['tag_name']: |                     if version[3:] != response_dict['tag_name']: | ||||||
| @@ -51,47 +42,51 @@ class GiteaUpdate: | |||||||
|             return 'No Internet Connection!' |             return 'No Internet Connection!' | ||||||
| 
 | 
 | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def download(urld, down_ok_image, down_not_ok_image, res): |     def download(): | ||||||
|         try: |         try: | ||||||
|             to_down = 'wget -qP ' + str(_u) + ' ' + urld |             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) |             result = subprocess.call(to_down, shell=True) | ||||||
|             if result == 0: |             if result == 0: | ||||||
|                 shutil.chown(str(_u) + f'/{res}.zip', 1000, 1000) |                 shutil.chown(str(_u) + f'/{res}.zip', 1000, 1000) | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' |                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                 ii = down_ok_image |                 ii = r'/usr/share/icons/wp-icons/48/wg_vpn.png' | ||||||
|                 wt = _('Download Successful') |                 wt = 'Download Successful' | ||||||
|                 msg_t = _('Your zip file is in home directory') |                 msg_t = 'Your zip file is in home directory' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
| 
 | 
 | ||||||
|             else: |             else: | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/error.png' |                 iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||||
|                 ii = down_not_ok_image |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Download error') |                 wt = 'Download error' | ||||||
|                 msg_t = _('Download failed! Please try again') |                 msg_t = 'Download failed! Please try again' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
|         except subprocess.CalledProcessError: |         except subprocess.CalledProcessError: | ||||||
|             """img_w, img_i, w_title, w_txt hand over""" |             """img_w, img_i, w_title, w_txt hand over""" | ||||||
|             iw = r'/usr/share/icons/lx-icons/64/error.png' |             iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||||
|             ii = down_not_ok_image |             ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|             wt = _('Download error') |             wt = 'Download error' | ||||||
|             msg_t = _('Download failed! No internet connection!') |             msg_t = 'Download failed! No internet connection!' | ||||||
|             msg_window(iw, ii, wt, msg_t) |             msg_window(iw, ii, wt, msg_t) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | res = WirePyUpdate.api_down() | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| def msg_window(img_w, img_i, w_title, w_txt, txt2=None, com=None): | def msg_window(img_w, img_i, w_title, w_txt, txt2=None, com=None): | ||||||
|     """ |     """ | ||||||
|     Function for different message windows for the user. with 4 arguments to be passed. |     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. |     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/lx-icons/64/info.png' |     Paths to images must be specified: r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|     img_w = Image for Tk Window |     img_w = Image for Tk Window | ||||||
|     img_i = Image for Icon |     img_i = Image for Icon | ||||||
|     w_title = Windows Title |     w_title = Windows Title | ||||||
|     w_txt = Text for Tk Window |     w_txt = Text for Tk Window | ||||||
|     txt2 = Text for Button two |  | ||||||
|     com = function for Button command |  | ||||||
|     """ |     """ | ||||||
|  | 
 | ||||||
|     msg = tk.Toplevel() |     msg = tk.Toplevel() | ||||||
|     msg.resizable(width=False, height=False) |     msg.resizable(width=False, height=False) | ||||||
|     msg.title(w_title) |     msg.title(w_title) | ||||||
| @@ -103,7 +98,7 @@ def msg_window(img_w, img_i, w_title, w_txt, txt2=None, com=None): | |||||||
| 
 | 
 | ||||||
|     label.grid(column=1, row=0) |     label.grid(column=1, row=0) | ||||||
| 
 | 
 | ||||||
|     if txt2 is not None and com is not None: |     if txt2 != None and com != None: | ||||||
|         label.config(font=('Ubuntu', 11), padx=15, justify='left') |         label.config(font=('Ubuntu', 11), padx=15, justify='left') | ||||||
|         msg.i_window.grid(column=0, row=0, sticky='nw') |         msg.i_window.grid(column=0, row=0, sticky='nw') | ||||||
|         button2 = ttk.Button(msg, text=f'{txt2}', command=com, padding=4) |         button2 = ttk.Button(msg, text=f'{txt2}', command=com, padding=4) | ||||||
| @@ -125,6 +120,7 @@ def msg_window(img_w, img_i, w_title, w_txt, txt2=None, com=None): | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class Tunnel: | class Tunnel: | ||||||
|  | 
 | ||||||
|     """ |     """ | ||||||
|     Class of Methods for Wire-Py |     Class of Methods for Wire-Py | ||||||
|     """ |     """ | ||||||
| @@ -133,6 +129,7 @@ class Tunnel: | |||||||
|     The config file is packed into a dictionary, |     The config file is packed into a dictionary, | ||||||
|     to display the values Address , DNS and Peer in the labels |     to display the values Address , DNS and Peer in the labels | ||||||
|     """ |     """ | ||||||
|  | 
 | ||||||
|     @classmethod |     @classmethod | ||||||
|     def con_to_dict(cls, file): |     def con_to_dict(cls, file): | ||||||
| 
 | 
 | ||||||
| @@ -174,9 +171,11 @@ class Tunnel: | |||||||
|             pre_key = final_dict['PreSharedKey'] |             pre_key = final_dict['PreSharedKey'] | ||||||
|         return address, dns, endpoint, pre_key |         return address, dns, endpoint, pre_key | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|     """ |     """ | ||||||
|     Shows the Active Tunnel |     Shows the Active Tunnel | ||||||
|     """ |     """ | ||||||
|  | 
 | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def active(): |     def active(): | ||||||
| 
 | 
 | ||||||
| @@ -191,6 +190,7 @@ class Tunnel: | |||||||
|     """ |     """ | ||||||
|     Shows all existing Wireguard tunnels |     Shows all existing Wireguard tunnels | ||||||
|     """ |     """ | ||||||
|  | 
 | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def list(): |     def 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() | ||||||
| @@ -199,11 +199,13 @@ class Tunnel: | |||||||
|         tl = wg_s[::3] |         tl = wg_s[::3] | ||||||
|         return tl |         return tl | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|     """ |     """ | ||||||
|     This will export the tunnels. |     This will export the tunnels. | ||||||
|     A zipfile with current date and time is created |     A zipfile with current date and time is created | ||||||
|     in the user's home directory with correct right |     in the user's home directory with correct right | ||||||
|     """ |     """ | ||||||
|  | 
 | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def export(): |     def export(): | ||||||
|         _u1 = str(_u[6:]) |         _u1 = str(_u[6:]) | ||||||
| @@ -226,47 +228,40 @@ class Tunnel: | |||||||
|                     if len(zf.namelist()) != 0: |                     if len(zf.namelist()) != 0: | ||||||
| 
 | 
 | ||||||
|                         """img_w, img_i, w_title, w_txt hand over""" |                         """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                         iw = r'/usr/share/icons/lx-icons/64/info.png' |                         iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                         ii = r'/usr/share/icons/wp-icons/48/wg_vpn.png' |                         ii = r'/usr/share/icons/wp-icons/48/wg_vpn.png' | ||||||
|                         wt = _('Export Successful') |                         wt = 'Export Successful' | ||||||
|                         msg_t = _('Your zip file is in home directory') |                         msg_t = 'Your zip file is in home directory' | ||||||
|                         msg_window(iw, ii, wt, msg_t) |                         msg_window(iw, ii, wt, msg_t) | ||||||
| 
 | 
 | ||||||
|                     else: |                     else: | ||||||
| 
 | 
 | ||||||
|                         """img_w, img_i, w_title, w_txt hand over""" |                         """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                         iw = r'/usr/share/icons/lx-icons/64/error.png' |                         iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||||
|                         ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                         ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                         wt = _('Export error') |                         wt = 'Export error' | ||||||
|                         msg_t = _('Export failed! Please try again') |                         msg_t = 'Export failed! Please try again' | ||||||
|                         msg_window(iw, ii, wt, msg_t) |                         msg_window(iw, ii, wt, msg_t) | ||||||
| 
 | 
 | ||||||
|             else: |             else: | ||||||
| 
 | 
 | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' |                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Select tunnel') |                 wt = 'Select tunnel' | ||||||
|                 msg_t = _('Please first import tunnel') |                 msg_t = 'Please first import tunnel.' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
| 
 | 
 | ||||||
|         except TypeError: |         except TypeError: | ||||||
|             pass |             pass | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| class Tipi: |  | ||||||
|     """ |  | ||||||
|     Class for Tooltip setting write in File |  | ||||||
|     Calling request path to file |  | ||||||
|     """ |  | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def if_tip(path): |     def if_tip(): | ||||||
|         with open(path, 'r') as set_file2: |         with open(path_to_file2, 'r') as set_file2: | ||||||
|             lines2 = set_file2.readlines() |                 lines2 = set_file2.readlines() | ||||||
|             if 'False\n' in lines2: |                 if 'False\n' in lines2: | ||||||
|                 return False |                     return False | ||||||
|             else: |                 else: | ||||||
|                 return True |                     return True | ||||||
| 
 | 
 | ||||||
| 
 | tips = Tunnel.if_tip() | ||||||
| wg_tips = Tipi.if_tip(wg_set) |  | ||||||
							
								
								
									
										283
									
								
								wg_main.py
									
									
									
									
									
								
							
							
						
						| @@ -1,7 +1,4 @@ | |||||||
| #!/usr/bin/python3 | #!/usr/bin/python3 | ||||||
|  |  | ||||||
| import gettext |  | ||||||
| import locale |  | ||||||
| import os | import os | ||||||
| import shutil | import shutil | ||||||
| import subprocess | import subprocess | ||||||
| @@ -9,23 +6,11 @@ import tkinter as tk | |||||||
| from pathlib import Path | from pathlib import Path | ||||||
| from subprocess import check_call | from subprocess import check_call | ||||||
| from tkinter import filedialog, ttk, TclError | from tkinter import filedialog, ttk, TclError | ||||||
| from cls_mth_fc import (Tunnel, msg_window, GiteaUpdate, _u, wg_tips, wg_set) |  | ||||||
|  | from wg_func import (Tunnel, msg_window, WirePyUpdate, res, _u, version, path_to_file2, tips) | ||||||
|  |  | ||||||
| tcl_path = Path('/usr/share/TK-Themes') | tcl_path = Path('/usr/share/TK-Themes') | ||||||
|  |  | ||||||
| ''' 1 = 1. Year, 09 = Month of the Year, 2924 = Day and Year of the Year ''' |  | ||||||
| version = 'v. 1.11.1024' |  | ||||||
|  |  | ||||||
| res = GiteaUpdate.api_down('https://git.ilunix.de/api/v1/repos/punix/Wire-Py/releases', version) |  | ||||||
|  |  | ||||||
| ''' Translate ''' |  | ||||||
| APP = 'wirepy' |  | ||||||
| LOCALE_DIR = "/usr/share/locale/" |  | ||||||
| locale.bindtextdomain(APP, LOCALE_DIR) |  | ||||||
| gettext.bindtextdomain(APP, LOCALE_DIR) |  | ||||||
| gettext.textdomain(APP) |  | ||||||
| _ = gettext.gettext |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class MainWindow(tk.Tk): | class MainWindow(tk.Tk): | ||||||
|  |  | ||||||
| @@ -37,7 +22,7 @@ class MainWindow(tk.Tk): | |||||||
|         self.y_height = 383 |         self.y_height = 383 | ||||||
|         self.monitor_center_x = self.winfo_screenwidth() / 2 - (self.x_width / 2) |         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.monitor_center_y = self.winfo_screenheight() / 2 - (self.y_height / 2) | ||||||
|         self.resizable(width=False, height=False) |         self.resizable(width=True, height=True) | ||||||
|         self.title('Wire-Py') |         self.title('Wire-Py') | ||||||
|         self.geometry('%dx%d+%d+%d' % (self.x_width, self.y_height, self.monitor_center_x, self.monitor_center_y)) |         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.columnconfigure(0, weight=1) | ||||||
| @@ -46,7 +31,7 @@ class MainWindow(tk.Tk): | |||||||
|         self.style = ttk.Style(self) |         self.style = ttk.Style(self) | ||||||
|         self.tk.call('source', str(tcl_path) + '/water.tcl') |         self.tk.call('source', str(tcl_path) + '/water.tcl') | ||||||
|         ''' self.tk.call('source', 'TK-Themes/water.tcl') ''' |         ''' self.tk.call('source', 'TK-Themes/water.tcl') ''' | ||||||
|         with open(wg_set, 'r') as read_file: |         with open(path_to_file2, 'r') as read_file: | ||||||
|             lines = read_file.readlines() |             lines = read_file.readlines() | ||||||
|             if 'light\n' in lines: |             if 'light\n' in lines: | ||||||
|                 self.tk.call('set_theme', 'light') |                 self.tk.call('set_theme', 'light') | ||||||
| @@ -77,7 +62,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|         self.imp_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_import.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.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.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/lx-icons/64/error.png') |         self.warning_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/64/error.png') | ||||||
|         self.wg_vpn_start = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn-start.png') |         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.wg_vpn_stop = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn-stop.png') | ||||||
|  |  | ||||||
| @@ -85,34 +70,34 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def update(): |         def update(): | ||||||
|             if set_update.get() == 1: |             if set_update.get() == 1: | ||||||
|                 with open(wg_set, 'r') as set_file2: |                 with open(path_to_file2, 'r') as set_file2: | ||||||
|                     lines2 = set_file2.readlines() |                     lines2 = set_file2.readlines() | ||||||
|                     lines2[1] = 'off\n' |                     lines2[1] = 'off\n' | ||||||
|                 with open(wg_set, 'w') as set_file2: |                 with open(path_to_file2, 'w') as set_file2: | ||||||
|                     set_file2.writelines(lines2) |                     set_file2.writelines(lines2) | ||||||
|  |  | ||||||
|             if set_update.get() == 0: |             if set_update.get() == 0: | ||||||
|                 with open(wg_set, 'r') as set_file2: |                 with open(path_to_file2, 'r') as set_file2: | ||||||
|                     lines2 = set_file2.readlines() |                     lines2 = set_file2.readlines() | ||||||
|                     lines2[1] = 'on\n' |                     lines2[1] = 'on\n' | ||||||
|                 with open(wg_set, 'w') as set_file2: |                 with open(path_to_file2, 'w') as set_file2: | ||||||
|                     set_file2.writelines(lines2) |                     set_file2.writelines(lines2) | ||||||
|  |  | ||||||
|         ''' Set True or False in file ''' |         ''' Set True or False in file ''' | ||||||
|  |  | ||||||
|         def tooltip(): |         def tooltip(): | ||||||
|             if set_tip.get(): |             if set_tip.get(): | ||||||
|                 with open(wg_set, 'r') as set_file2: |                 with open(path_to_file2, 'r') as set_file2: | ||||||
|                     lines2 = set_file2.readlines() |                     lines2 = set_file2.readlines() | ||||||
|                     lines2[5] = 'False\n' |                     lines2[5] = 'False\n' | ||||||
|                 with open(wg_set, 'w') as set_file2: |                 with open(path_to_file2, 'w') as set_file2: | ||||||
|                     set_file2.writelines(lines2) |                     set_file2.writelines(lines2) | ||||||
|  |  | ||||||
|             else: |             else: | ||||||
|                 with open(wg_set, 'r') as set_file2: |                 with open(path_to_file2, 'r') as set_file2: | ||||||
|                     lines2 = set_file2.readlines() |                     lines2 = set_file2.readlines() | ||||||
|                     lines2[5] = 'True\n' |                     lines2[5] = 'True\n' | ||||||
|                 with open(wg_set, 'w') as set_file2: |                 with open(path_to_file2, 'w') as set_file2: | ||||||
|                     set_file2.writelines(lines2) |                     set_file2.writelines(lines2) | ||||||
|  |  | ||||||
|         ''' Set dark or light ''' |         ''' Set dark or light ''' | ||||||
| @@ -121,10 +106,10 @@ class FrameWidgets(ttk.Frame): | |||||||
|             if self.tk.call("ttk::style", "theme", "use") == "water-dark": |             if self.tk.call("ttk::style", "theme", "use") == "water-dark": | ||||||
|                 ''' Set light theme ''' |                 ''' Set light theme ''' | ||||||
|                 self.tk.call('set_theme', 'light') |                 self.tk.call('set_theme', 'light') | ||||||
|                 with open(wg_set, 'r') as theme_set2: |                 with open(path_to_file2, 'r') as theme_set2: | ||||||
|                     lines3 = theme_set2.readlines() |                     lines3 = theme_set2.readlines() | ||||||
|                     lines3[3] = 'light\n' |                     lines3[3] = 'light\n' | ||||||
|                 with open(wg_set, 'w') as theme_set2: |                 with open(path_to_file2, 'w') as theme_set2: | ||||||
|                     theme_set2.writelines(lines3) |                     theme_set2.writelines(lines3) | ||||||
|                 self.color_label() |                 self.color_label() | ||||||
|  |  | ||||||
| @@ -132,10 +117,10 @@ class FrameWidgets(ttk.Frame): | |||||||
|             if not self.tk.call("ttk::style", "theme", "use") == "water-dark": |             if not self.tk.call("ttk::style", "theme", "use") == "water-dark": | ||||||
|                 ''' Set dark theme ''' |                 ''' Set dark theme ''' | ||||||
|                 self.tk.call('set_theme', 'dark') |                 self.tk.call('set_theme', 'dark') | ||||||
|                 with open(wg_set, 'r') as theme_set2: |                 with open(path_to_file2, 'r') as theme_set2: | ||||||
|                     lines4 = theme_set2.readlines() |                     lines4 = theme_set2.readlines() | ||||||
|                     lines4[3] = 'dark\n' |                     lines4[3] = 'dark\n' | ||||||
|                 with open(wg_set, 'w') as theme_set2: |                 with open(path_to_file2, 'w') as theme_set2: | ||||||
|                     theme_set2.writelines(lines4) |                     theme_set2.writelines(lines4) | ||||||
|                 self.color_label() |                 self.color_label() | ||||||
|  |  | ||||||
| @@ -148,12 +133,12 @@ class FrameWidgets(ttk.Frame): | |||||||
|             """img_w, img_i, w_title, w_txt , txt2, com hand over""" |             """img_w, img_i, w_title, w_txt , txt2, com hand over""" | ||||||
|             iw = r'/usr/share/icons/wp-icons/48/wg_vpn.png' |             iw = r'/usr/share/icons/wp-icons/48/wg_vpn.png' | ||||||
|             ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |             ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|             wt = _('Info') |             wt = 'Info' | ||||||
|             msg_t = (_('Wire-Py a simple Wireguard Gui for Linux systems.\n\n' |             msg_t = ('Wire-Py a simple Wireguard Gui for Linux systems.\n\n' | ||||||
|                        'Wire-Py is open source software written in Python.\n\n' |                      'Wire-Py is open source software written in Python.\n\n' | ||||||
|                        'Email: polunga40@unity-mail.de also likes for donation.\n\n' |                      'Email: polunga40@unity-mail.de also likes for donation.\n\n' | ||||||
|                        'Use without warranty!\n')) |                      'Use without warranty!\n') | ||||||
|             txt2 = _('Go to Wire-Py git') |             txt2 = 'Go to Wire-Py git' | ||||||
|             com = link_btn |             com = link_btn | ||||||
|  |  | ||||||
|             msg_window(iw, ii, wt, msg_t, txt2, com) |             msg_window(iw, ii, wt, msg_t, txt2, com) | ||||||
| @@ -177,12 +162,12 @@ class FrameWidgets(ttk.Frame): | |||||||
|             ''' Remove Tool-Tip ''' |             ''' Remove Tool-Tip ''' | ||||||
|             window.my_tool_tip.destroy() |             window.my_tool_tip.destroy() | ||||||
|  |  | ||||||
|         self.options_btn = ttk.Menubutton(self.menu_frame, text=_('Options')) |         self.options_btn = ttk.Menubutton(self.menu_frame, text='Options') | ||||||
|         self.options_btn.grid(column=1, columnspan=1, row=0) |         self.options_btn.grid(column=1, row=0) | ||||||
|  |  | ||||||
|         def sets_enter(event): |         def sets_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Click for Settings')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'Click for Settings') | ||||||
|  |  | ||||||
|         def sets_leave(_): |         def sets_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -198,21 +183,21 @@ class FrameWidgets(ttk.Frame): | |||||||
|         set_tip = tk.BooleanVar() |         set_tip = tk.BooleanVar() | ||||||
|         self.settings = tk.Menu(self, relief='flat') |         self.settings = tk.Menu(self, relief='flat') | ||||||
|         self.options_btn.configure(menu=self.settings, style='Toolbutton') |         self.options_btn.configure(menu=self.settings, style='Toolbutton') | ||||||
|         self.settings.add_checkbutton(label=_('Disable Updates'), command=update, variable=set_update) |         self.settings.add_checkbutton(label='Disable Updates', command=update, variable=set_update) | ||||||
|         self.settings.add_checkbutton(label=_('Disable Tooltips'), command=tooltip, variable=set_tip) |         self.settings.add_checkbutton(label='Disable Tooltips', command=tooltip, variable=set_tip) | ||||||
|         self.settings.add_command(label=_('Light'), command=theme_change_light) |         self.settings.add_command(label='Light', command=theme_change_light) | ||||||
|         self.settings.add_command(label=_('Dark'), command=theme_change_dark) |         self.settings.add_command(label='Dark', command=theme_change_dark) | ||||||
|  |  | ||||||
|         ''' About BTN Menu / Label ''' |         ''' About BTN Menu / Label ''' | ||||||
|         self.about_btn = ttk.Button(self.menu_frame, text=_('About'), style='Toolbutton', command=info) |         self.about_btn = ttk.Button(self.menu_frame, text='About', style='Toolbutton', command=info) | ||||||
|         self.about_btn.grid(column=2, columnspan=2, row=0) |         self.about_btn.grid(column=2, row=0) | ||||||
|         self.readme = tk.Menu(self) |         self.readme = tk.Menu(self) | ||||||
|  |  | ||||||
|         ''' Update and Tooltip Label ''' |         ''' Update and Tooltip Label ''' | ||||||
|         self.updates_lb = ttk.Label(self.menu_frame) |         self.updates_lb = ttk.Label(self.menu_frame) | ||||||
|         self.updates_lb.grid(column=4, columnspan=3, row=0, padx=10) |         self.updates_lb.grid(column=3, row=0, padx=10) | ||||||
|         '''View Checkbox for enable or disable Tooltip ''' |         '''View Checkbox for enable or disable Tooltip ''' | ||||||
|         if wg_tips: |         if tips: | ||||||
|             set_tip.set(value=False) |             set_tip.set(value=False) | ||||||
|         else: |         else: | ||||||
|             set_tip.set(value=True) |             set_tip.set(value=True) | ||||||
| @@ -220,11 +205,11 @@ class FrameWidgets(ttk.Frame): | |||||||
|         '''View Checkbox for enable or disable Updates ''' |         '''View Checkbox for enable or disable Updates ''' | ||||||
|         if res == 'False': |         if res == 'False': | ||||||
|             set_update.set(value=1) |             set_update.set(value=1) | ||||||
|             self.updates_lb.configure(text=_('Update search off')) |             self.updates_lb.configure(text='Update search off') | ||||||
|  |  | ||||||
|             def disable_enter(event): |             def disable_enter(event): | ||||||
|                 """ The mouse moves into the entry widget """ |                 """ The mouse moves into the entry widget """ | ||||||
|                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Updates you have disabled')) |                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'Updates you have disabled') | ||||||
|  |  | ||||||
|             def disable_leave(_): |             def disable_leave(_): | ||||||
|                 """ The mouse moves from the entry widget """ |                 """ The mouse moves from the entry widget """ | ||||||
| @@ -234,13 +219,14 @@ class FrameWidgets(ttk.Frame): | |||||||
|             self.updates_lb.bind('<Enter>', disable_enter) |             self.updates_lb.bind('<Enter>', disable_enter) | ||||||
|             self.updates_lb.bind('<Leave>', disable_leave) |             self.updates_lb.bind('<Leave>', disable_leave) | ||||||
|         elif res == 'No Internet Connection!': |         elif res == 'No Internet Connection!': | ||||||
|             self.updates_lb.configure(text=_('No Server Connection!'), foreground='red') |             self.updates_lb.configure(text='No Server Connection!', foreground='red') | ||||||
|         elif res == 'No Updates': |         elif res == 'No Updates': | ||||||
|             self.updates_lb.configure(text=_('No Updates')) |             self.updates_lb.configure(text='No Updates') | ||||||
|  |  | ||||||
|             def congratulations_enter(event): |             def congratulations_enter(event): | ||||||
|                 """ The mouse moves into the entry widget """ |                 """ The mouse moves into the entry widget """ | ||||||
|                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Congratulations! Wire-Py is up to date')) |                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|  |                                                'Congratulations! Wire-Py is up to date') | ||||||
|  |  | ||||||
|             def congratulations_leave(_): |             def congratulations_leave(_): | ||||||
|                 """ The mouse moves from the entry widget """ |                 """ The mouse moves from the entry widget """ | ||||||
| @@ -251,15 +237,15 @@ class FrameWidgets(ttk.Frame): | |||||||
|             self.updates_lb.bind('<Leave>', congratulations_leave) |             self.updates_lb.bind('<Leave>', congratulations_leave) | ||||||
|         else: |         else: | ||||||
|             set_update.set(value=0) |             set_update.set(value=0) | ||||||
|             text = f'Update {res} ' + _('available!') |             text = f'Update {res} available!' | ||||||
|  |  | ||||||
|             ''' Update BTN Menu''' |             ''' Update BTN Menu''' | ||||||
|             self.update_btn = ttk.Menubutton(self.menu_frame, text=text) |             self.update_btn = ttk.Menubutton(self.menu_frame, text=text) | ||||||
|             self.update_btn.grid(column=4, columnspan=3, row=0, padx=0) |             self.update_btn.grid(column=4, row=0, padx=0) | ||||||
|  |  | ||||||
|             def download_enter(event): |             def download_enter(event): | ||||||
|                 """ The mouse moves into the entry widget """ |                 """ The mouse moves into the entry widget """ | ||||||
|                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Click to download new version')) |                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'Click to download new version') | ||||||
|  |  | ||||||
|             def download_leave(_): |             def download_leave(_): | ||||||
|                 """ The mouse moves from the entry widget """ |                 """ The mouse moves from the entry widget """ | ||||||
| @@ -272,15 +258,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|             self.download = tk.Menu(self, relief='flat') |             self.download = tk.Menu(self, relief='flat') | ||||||
|  |  | ||||||
|             self.update_btn.configure(menu=self.download, style='Toolbutton') |             self.update_btn.configure(menu=self.download, style='Toolbutton') | ||||||
|             self.download.add_command(label=_('Download'), |             self.download.add_command(label='Download', command=WirePyUpdate.download) | ||||||
|                                       command=lambda: GiteaUpdate.download(f'https://git.ilunix.de/punix' |  | ||||||
|                                                                            f'/Wire-Py/archive/' |  | ||||||
|                                                                            f'{res}.zip', r'/usr/' |  | ||||||
|                                                                                          r'share/icons/wp-icons' |  | ||||||
|                                                                                          r'/48/wg_vpn.png', |  | ||||||
|                                                                            r'/usr/share/icons/wp-icons' |  | ||||||
|                                                                            r'/48/wg_msg.png', res)) |  | ||||||
|  |  | ||||||
|         ''' Show active Tunnel ''' |         ''' Show active Tunnel ''' | ||||||
|         self.a = Tunnel.active() |         self.a = Tunnel.active() | ||||||
|  |  | ||||||
| @@ -304,14 +282,9 @@ class FrameWidgets(ttk.Frame): | |||||||
|         self.lb_frame3.configure(relief='flat') |         self.lb_frame3.configure(relief='flat') | ||||||
|         self.lb_frame3.grid(column=0, row=5, columnspan=4, sticky='snew', padx=2, pady=2) |         self.lb_frame3.grid(column=0, row=5, columnspan=4, sticky='snew', padx=2, pady=2) | ||||||
|  |  | ||||||
|         ''' Bottom Frame 5 ''' |  | ||||||
|         self.lb_frame4 = ttk.Frame(self) |  | ||||||
|         self.lb_frame4.configure(relief='flat') |  | ||||||
|         self.lb_frame4.grid(column=2, row=5, columnspan=3, sticky='e', padx=15) |  | ||||||
|  |  | ||||||
|         ''' Show active Label ''' |         ''' Show active Label ''' | ||||||
|         self.select_tunnel = None |         self.select_tunnel = None | ||||||
|         self.lb = ttk.Label(self, text=_('Active: ')) |         self.lb = ttk.Label(self, text='Active: ') | ||||||
|         self.lb.config(font=('Ubuntu', 11, 'bold')) |         self.lb.config(font=('Ubuntu', 11, 'bold')) | ||||||
|         self.lb.grid(column=2, row=1, padx=15, pady=4, sticky='w') |         self.lb.grid(column=2, row=1, padx=15, pady=4, sticky='w') | ||||||
|  |  | ||||||
| @@ -320,12 +293,12 @@ class FrameWidgets(ttk.Frame): | |||||||
|         self.color_label() |         self.color_label() | ||||||
|  |  | ||||||
|         ''' Interface Label ''' |         ''' Interface Label ''' | ||||||
|         self.interface = ttk.Label(self.lb_frame, text=_('Interface')) |         self.interface = ttk.Label(self.lb_frame, text='Interface') | ||||||
|         self.interface.grid(column=0, row=3, sticky='we', padx=120) |         self.interface.grid(column=0, row=3, sticky='we', padx=120) | ||||||
|         self.interface.config(font=('Ubuntu', 9)) |         self.interface.config(font=('Ubuntu', 9)) | ||||||
|  |  | ||||||
|         ''' Peer Label ''' |         ''' Peer Label ''' | ||||||
|         self.peer = ttk.Label(self.lb_frame2, text=_('Peer')) |         self.peer = ttk.Label(self.lb_frame2, text='Peer') | ||||||
|         self.peer.config(font=('Ubuntu', 9)) |         self.peer.config(font=('Ubuntu', 9)) | ||||||
|         self.peer.grid(column=0, row=4, sticky='we', padx=130) |         self.peer.grid(column=0, row=4, sticky='we', padx=130) | ||||||
|  |  | ||||||
| @@ -356,7 +329,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def list_empty_enter(event): |         def list_empty_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('You must first import\na Wireguard tunnel')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|  |                                            'You must first import\na Wireguard tunnel') | ||||||
|  |  | ||||||
|         def list_empty_leave(_): |         def list_empty_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -365,7 +339,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def list_not_empty_enter(event): |         def list_not_empty_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Select a Tunnel')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'Select a Tunnel') | ||||||
|  |  | ||||||
|         def list_not_empty_leave(_): |         def list_not_empty_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -405,7 +379,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def imp_enter(event): |         def imp_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Click to import a Wireguard Tunnel')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'Click to import a Wireguard Tunnel') | ||||||
|  |  | ||||||
|         def imp_leave(_): |         def imp_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -425,14 +399,14 @@ class FrameWidgets(ttk.Frame): | |||||||
|                     pre_key = key[3] |                     pre_key = key[3] | ||||||
|                 check_call(['nmcli', 'connection', 'delete', select_tl]) |                 check_call(['nmcli', 'connection', 'delete', select_tl]) | ||||||
|                 self.l_box.delete(self.select_tunnel[0]) |                 self.l_box.delete(self.select_tunnel[0]) | ||||||
|                 with open(wg_set, 'r') as set_file6: |                 with open(path_to_file2, 'r') as set_file6: | ||||||
|                     lines6 = set_file6.readlines() |                     lines6 = set_file6.readlines() | ||||||
|                     if select_tl == lines6[7].strip() and 'off' not in lines6[7].strip(): |                     if select_tl == lines6[7].strip() and 'off' not in lines6[7].strip(): | ||||||
|                         lines6[7] = 'off' |                         lines6[7] = 'off' | ||||||
|                         with open(wg_set, 'w') as set_file7: |                         with open(path_to_file2, 'w') as set_file7: | ||||||
|                             set_file7.writelines(lines6) |                             set_file7.writelines(lines6) | ||||||
|                         self.selected_option.set(0) |                         self.selected_option.set(0) | ||||||
|                         self.autoconnect_var.set(_('no Autoconnect')) |                         self.autoconnect_var.set('no Autoconnect') | ||||||
|  |  | ||||||
|                 Path.unlink(Path('/etc/wire_py') / str(select_tl + '.conf')) |                 Path.unlink(Path('/etc/wire_py') / str(select_tl + '.conf')) | ||||||
|                 with open('/etc/wire_py/.keys', 'r') as readfile: |                 with open('/etc/wire_py/.keys', 'r') as readfile: | ||||||
| @@ -449,7 +423,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|                 def empty_list_start_enter(event): |                 def empty_list_start_enter(event): | ||||||
|                     """ The mouse moves into the entry widget """ |                     """ The mouse moves into the entry widget """ | ||||||
|                     window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('No tunnels to start in the list')) |                     window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|  |                                                    'No tunnels to start in the list') | ||||||
|  |  | ||||||
|                 def empty_list_start_leave(_): |                 def empty_list_start_leave(_): | ||||||
|                     """ The mouse moves from the entry widget """ |                     """ The mouse moves from the entry widget """ | ||||||
| @@ -471,7 +446,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|                     self.btn_stst.bind('<Leave>', empty_list_start_leave) |                     self.btn_stst.bind('<Leave>', empty_list_start_leave) | ||||||
|                     self.lb_rename.bind('<Enter>', rename_no_active_enter) |                     self.lb_rename.bind('<Enter>', rename_no_active_enter) | ||||||
|                     self.lb_rename.bind('<Leave>', rename_no_active_leave) |                     self.lb_rename.bind('<Leave>', rename_no_active_leave) | ||||||
|                     self.lb_rename.insert(0, _('Max. 12 characters!')) |                     self.lb_rename.insert(0, 'Max. 12 characters!') | ||||||
|  |  | ||||||
|                 if self.a != '' and self.a == select_tl: |                 if self.a != '' and self.a == select_tl: | ||||||
|                     self.StrVar.set(value='') |                     self.StrVar.set(value='') | ||||||
| @@ -489,19 +464,19 @@ class FrameWidgets(ttk.Frame): | |||||||
|                 if self.l_box.size() != 0: |                 if self.l_box.size() != 0: | ||||||
|  |  | ||||||
|                     """img_w, img_i, w_title, w_txt hand over""" |                     """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                     iw = r'/usr/share/icons/lx-icons/64/info.png' |                     iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                     wt = _('Select tunnel') |                     wt = 'Select tunnel' | ||||||
|                     msg_t = _('Please select a tunnel from the list') |                     msg_t = 'Please select a tunnel from the list.' | ||||||
|                     msg_window(iw, ii, wt, msg_t) |                     msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|                 else: |                 else: | ||||||
|  |  | ||||||
|                     """img_w, img_i, w_title, w_txt hand over""" |                     """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                     iw = r'/usr/share/icons/lx-icons/64/info.png' |                     iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                     wt = _('Select tunnel') |                     wt = 'Select tunnel' | ||||||
|                     msg_t = _('Please first import tunnel') |                     msg_t = 'Please first import tunnel.' | ||||||
|                     msg_window(iw, ii, wt, msg_t) |                     msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|         ''' Button Trash ''' |         ''' Button Trash ''' | ||||||
| @@ -511,7 +486,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def empty_list_enter(event): |         def empty_list_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('No tunnels to delete in the list')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'No tunnels to delete in the list') | ||||||
|  |  | ||||||
|         def empty_list_leave(_): |         def empty_list_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -521,7 +496,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|         def del_enter(event): |         def del_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                            _('Click to delete a Wireguard Tunnel\nSelect from the list!')) |                                            'Click to delete a Wireguard Tunnel\nSelect from the list!') | ||||||
|  |  | ||||||
|         def del_leave(_): |         def del_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -541,7 +516,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def empty_list_enter(event): |         def empty_list_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('No Tunnels in List for Export')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'No Tunnels in List for Export') | ||||||
|  |  | ||||||
|         def empty_list_leave(_): |         def empty_list_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -551,7 +526,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|         def exp_enter(event): |         def exp_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                            _('         Click to export all\nWireguard Tunnel to Zipfile')) |                                            '         Click to export all\nWireguard Tunnel to Zipfile') | ||||||
|  |  | ||||||
|         def exp_leave(_): |         def exp_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -566,9 +541,9 @@ class FrameWidgets(ttk.Frame): | |||||||
|             self.btn_exp.bind('<Leave>', exp_leave) |             self.btn_exp.bind('<Leave>', exp_leave) | ||||||
|  |  | ||||||
|         ''' Label Entry ''' |         ''' Label Entry ''' | ||||||
|         self.lb_rename = ttk.Entry(self.lb_frame4, width=20) |         self.lb_rename = ttk.Entry(self.lb_frame3, width=20) | ||||||
|         self.lb_rename.grid(column=2, row=0, padx=8, pady=10, sticky='ne') |         self.lb_rename.grid(column=2, row=0, padx=8, pady=10, sticky='ne') | ||||||
|         self.lb_rename.insert(0, _('Max. 12 characters!')) |         self.lb_rename.insert(0, 'Max. 12 characters!') | ||||||
|         self.lb_rename.config(state='disable') |         self.lb_rename.config(state='disable') | ||||||
|  |  | ||||||
|         def rename_no_active_leave(_): |         def rename_no_active_leave(_): | ||||||
| @@ -579,12 +554,12 @@ class FrameWidgets(ttk.Frame): | |||||||
|         def rename_no_active_enter(event): |         def rename_no_active_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                            _('To rename a tunnel, at least one must be in the list')) |                                            'To rename a tunnel, at least one must be in the list') | ||||||
|  |  | ||||||
|         def rename_enter(event): |         def rename_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                            _('To rename a tunnel, you need to\nselect a tunnel from the list')) |                                            'To rename a tunnel, you need to\nselect a tunnel from the list') | ||||||
|  |  | ||||||
|         def rename_leave(_): |         def rename_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -604,28 +579,28 @@ class FrameWidgets(ttk.Frame): | |||||||
|             if len(self.lb_rename.get()) > 12: |             if len(self.lb_rename.get()) > 12: | ||||||
|  |  | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' |                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Renaming not possible') |                 wt = 'Renaming not possible' | ||||||
|                 msg_t = _('The new name may contain only 12 characters') |                 msg_t = 'The new name may contain only 12 characters.' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|             elif len(self.lb_rename.get()) == 0: |             elif len(self.lb_rename.get()) == 0: | ||||||
|  |  | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' |                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Renaming not possible') |                 wt = 'Renaming not possible' | ||||||
|                 msg_t = _('At least one character must be entered') |                 msg_t = 'At least one character must be entered.' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|             elif any(ch in special_characters for ch in self.lb_rename.get()): |             elif any(ch in special_characters for ch in self.lb_rename.get()): | ||||||
|  |  | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' |                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Renaming not possible') |                 wt = 'Renaming not possible' | ||||||
|                 msg_t = _('No valid sign. These must not be used.\nBlank, Slash, Backslash and { }\n') |                 msg_t = 'No valid sign. These must not be used.\nBlank, Slash, Backslash and { }\n' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|             else: |             else: | ||||||
| @@ -647,11 +622,11 @@ class FrameWidgets(ttk.Frame): | |||||||
|                     if self.a != '' and self.a == select_tl: |                     if self.a != '' and self.a == select_tl: | ||||||
|                         self.a = Tunnel.active() |                         self.a = Tunnel.active() | ||||||
|                         self.StrVar.set(value=self.a) |                         self.StrVar.set(value=self.a) | ||||||
|                         with open(wg_set, 'r') as set_file5: |                         with open(path_to_file2, 'r') as set_file5: | ||||||
|                             lines5 = set_file5.readlines() |                             lines5 = set_file5.readlines() | ||||||
|                         if select_tl == lines5[7].strip() and 'off' not in lines5[7].strip(): |                         if select_tl == lines5[7].strip() and 'off' not in lines5[7].strip(): | ||||||
|                             lines5[7] = new_a_connect |                             lines5[7] = new_a_connect | ||||||
|                             with open(wg_set, 'w') as theme_set5: |                             with open(path_to_file2, 'w') as theme_set5: | ||||||
|                                 theme_set5.writelines(lines5) |                                 theme_set5.writelines(lines5) | ||||||
|                             self.autoconnect_var.set(value=new_a_connect) |                             self.autoconnect_var.set(value=new_a_connect) | ||||||
|  |  | ||||||
| @@ -660,14 +635,14 @@ class FrameWidgets(ttk.Frame): | |||||||
|                 except IndexError: |                 except IndexError: | ||||||
|  |  | ||||||
|                     """img_w, img_i, w_title, w_txt hand over""" |                     """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                     iw = r'/usr/share/icons/lx-icons/64/info.png' |                     iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                     wt = _('Renaming not possible') |                     wt = 'Renaming not possible' | ||||||
|                     msg_t = _('Please select a tunnel from the list') |                     msg_t = 'Please select a tunnel from the list.' | ||||||
|                     msg_window(iw, ii, wt, msg_t) |                     msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|         ''' Button Rename ''' |         ''' Button Rename ''' | ||||||
|         self.btn_rename = ttk.Button(self.lb_frame4, text=_('Rename'), state='disable', command=tl_rename, padding=4, |         self.btn_rename = ttk.Button(self.lb_frame3, text='Rename', state='disable', command=tl_rename, padding=4, | ||||||
|                                      style='RnButton.TButton') |                                      style='RnButton.TButton') | ||||||
|         self.btn_rename.grid(column=3, row=0, padx=5, pady=10, sticky='ne') |         self.btn_rename.grid(column=3, row=0, padx=5, pady=10, sticky='ne') | ||||||
|  |  | ||||||
| @@ -679,15 +654,15 @@ class FrameWidgets(ttk.Frame): | |||||||
|         self.autoconnect = ttk.Label(self.lb_frame3, textvariable=self.autoconnect_var, width=15) |         self.autoconnect = ttk.Label(self.lb_frame3, textvariable=self.autoconnect_var, width=15) | ||||||
|         self.autoconnect.config(font=('Ubuntu', 11)) |         self.autoconnect.config(font=('Ubuntu', 11)) | ||||||
|         self.autoconnect.grid(column=1, row=0, sticky='e', pady=19) |         self.autoconnect.grid(column=1, row=0, sticky='e', pady=19) | ||||||
|         self.wg_autostart = ttk.Checkbutton(self.lb_frame3, text=_('Autoconnect on:'), variable=self.selected_option, |         self.wg_autostart = ttk.Checkbutton(self.lb_frame3, text='Autoconnect on:', variable=self.selected_option, | ||||||
|                                             command=self.box_set) |                                             command=self.box_set) | ||||||
|         self.wg_autostart.grid(column=0, row=0, pady=15, padx=15, sticky='nw') |         self.wg_autostart.grid(column=0, row=0, pady=15, padx=15, sticky='nw') | ||||||
|  |  | ||||||
|         def chk_enter(event): |         def chk_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                            _('You must have at least one\n' |                                            'You must have at least one\n' | ||||||
|                                              'tunnel in the list,to use the autostart')) |                                            'tunnel in the list,to use the autostart') | ||||||
|  |  | ||||||
|         def chk_leave(_): |         def chk_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -698,7 +673,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|             def chk_a_enter(event): |             def chk_a_enter(event): | ||||||
|                 """ The mouse moves into the entry widget """ |                 """ The mouse moves into the entry widget """ | ||||||
|                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                                _('To use the autostart, enable this Checkbox')) |                                                'To use the autostart, enable this Checkbox') | ||||||
|  |  | ||||||
|             def chk_a_leave(_): |             def chk_a_leave(_): | ||||||
|                 """ The mouse moves from the entry widget """ |                 """ The mouse moves from the entry widget """ | ||||||
| @@ -715,7 +690,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|             def chk_a_enter(event): |             def chk_a_enter(event): | ||||||
|                 """ The mouse moves into the entry widget """ |                 """ The mouse moves into the entry widget """ | ||||||
|                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |                 window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                                _('To use the autostart, a tunnel must be selected from the list')) |                                                'To use the autostart, a tunnel must be selected from the list') | ||||||
|  |  | ||||||
|             def chk_a_leave(_): |             def chk_a_leave(_): | ||||||
|                 """ The mouse moves from the entry widget """ |                 """ The mouse moves from the entry widget """ | ||||||
| @@ -739,8 +714,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|         If in each case false comes out, a corresponding window comes to inform the user that something is wrong. |         If in each case false comes out, a corresponding window comes to inform the user that something is wrong. | ||||||
|         """ |         """ | ||||||
|         try: |         try: | ||||||
|             filepath = filedialog.askopenfilename(initialdir=str(_u), 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')], ) | ||||||
|  |  | ||||||
|             with open(filepath, 'r') as file: |             with open(filepath, 'r') as file: | ||||||
|                 read = file.read() |                 read = file.read() | ||||||
| @@ -757,10 +732,10 @@ class FrameWidgets(ttk.Frame): | |||||||
|                             p_key = readfile.readlines() |                             p_key = readfile.readlines() | ||||||
|                             if pre_key in p_key or pre_key + '\n' in p_key: |                             if pre_key in p_key or pre_key + '\n' in p_key: | ||||||
|                                 """img_w, img_i, w_title, w_txt hand over""" |                                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                                 iw = r'/usr/share/icons/lx-icons/64/error.png' |                                 iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||||
|                                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                                 wt = _('Import Error') |                                 wt = 'Import Error' | ||||||
|                                 msg_t = _('Tunnel already available!\nPlease use another file for import') |                                 msg_t = 'Tunnel already available!\nPlease use another file for import' | ||||||
|                                 msg_window(iw, ii, wt, msg_t) |                                 msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|                             else: |                             else: | ||||||
| @@ -799,8 +774,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|                                     def chk_a_enter(event): |                                     def chk_a_enter(event): | ||||||
|                                         """ The mouse moves into the entry widget """ |                                         """ The mouse moves into the entry widget """ | ||||||
|                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                                                        _('To use the autostart, enable this ' |                                                                        'To use the autostart, enable this ' | ||||||
|                                                                          'Checkbox')) |                                                                        'Checkbox') | ||||||
|  |  | ||||||
|                                     def chk_a_leave(_): |                                     def chk_a_leave(_): | ||||||
|                                         """ The mouse moves from the entry widget """ |                                         """ The mouse moves from the entry widget """ | ||||||
| @@ -810,7 +785,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|                                     def list_info_enter(event): |                                     def list_info_enter(event): | ||||||
|                                         """ The mouse moves into the entry widget """ |                                         """ The mouse moves into the entry widget """ | ||||||
|                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                                                        _('List of available tunnels')) |                                                                        'List of available tunnels') | ||||||
|  |  | ||||||
|                                     def list_info_leave(_): |                                     def list_info_leave(_): | ||||||
|                                         """ The mouse moves from the entry widget """ |                                         """ The mouse moves from the entry widget """ | ||||||
| @@ -820,8 +795,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|                                     def del_enter(event): |                                     def del_enter(event): | ||||||
|                                         """ The mouse moves into the entry widget """ |                                         """ The mouse moves into the entry widget """ | ||||||
|                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                                                        _('Click to delete a Wireguard ' |                                                                        'Click to delete a Wireguard ' | ||||||
|                                                                          'Tunnel\nSelect from the list!')) |                                                                        'Tunnel\nSelect from the list!') | ||||||
|  |  | ||||||
|                                     def del_leave(_): |                                     def del_leave(_): | ||||||
|                                         """ The mouse moves from the entry widget """ |                                         """ The mouse moves from the entry widget """ | ||||||
| @@ -831,8 +806,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|                                     def exp_enter(event): |                                     def exp_enter(event): | ||||||
|                                         """ The mouse moves into the entry widget """ |                                         """ The mouse moves into the entry widget """ | ||||||
|                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                                                        _('         Click to export ' |                                                                        '         Click to export ' | ||||||
|                                                                          'all\nWireguard Tunnel to Zipfile')) |                                                                        'all\nWireguard Tunnel to Zipfile') | ||||||
|  |  | ||||||
|                                     def exp_leave(_): |                                     def exp_leave(_): | ||||||
|                                         """ The mouse moves from the entry widget """ |                                         """ The mouse moves from the entry widget """ | ||||||
| @@ -842,8 +817,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|                                     def rename_enter(event): |                                     def rename_enter(event): | ||||||
|                                         """ The mouse moves into the entry widget """ |                                         """ The mouse moves into the entry widget """ | ||||||
|                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, |                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|                                                                        _('To rename a tunnel, you need to\n' |                                                                        'To rename a tunnel, you need to\n' | ||||||
|                                                                          'select a tunnel from the list')) |                                                                        'select a tunnel from the list') | ||||||
|  |  | ||||||
|                                     def rename_leave(_): |                                     def rename_leave(_): | ||||||
|                                         """ The mouse moves from the entry widget """ |                                         """ The mouse moves from the entry widget """ | ||||||
| @@ -877,10 +852,10 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|             if 'PrivateKey = ' and 'Endpoint = ' not in read: |             if 'PrivateKey = ' and 'Endpoint = ' not in read: | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/error.png' |                 iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Import Error') |                 wt = 'Import Error' | ||||||
|                 msg_t = _('Oh... no valid Wireguard File!\nPlease select a valid Wireguard File') |                 msg_t = 'Oh... no valid Wireguard File!\nPlease select a valid Wireguard File' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|         except EOFError: |         except EOFError: | ||||||
| @@ -904,10 +879,10 @@ class FrameWidgets(ttk.Frame): | |||||||
|             select_tl = self.l_box.get(select_tunnel[0]) |             select_tl = self.l_box.get(select_tunnel[0]) | ||||||
|  |  | ||||||
|             if self.selected_option.get() == 0: |             if self.selected_option.get() == 0: | ||||||
|                 with open(wg_set, 'r') as set_file3: |                 with open(path_to_file2, 'r') as set_file3: | ||||||
|                     lines3 = set_file3.readlines() |                     lines3 = set_file3.readlines() | ||||||
|                     lines3[7] = 'off' |                     lines3[7] = 'off' | ||||||
|                 with open(wg_set, 'w') as set_file3: |                 with open(path_to_file2, 'w') as set_file3: | ||||||
|                     set_file3.writelines(lines3) |                     set_file3.writelines(lines3) | ||||||
|  |  | ||||||
|                 tl = Tunnel.list() |                 tl = Tunnel.list() | ||||||
| @@ -916,10 +891,10 @@ class FrameWidgets(ttk.Frame): | |||||||
|                     self.wg_autostart.configure(state='disabled') |                     self.wg_autostart.configure(state='disabled') | ||||||
|  |  | ||||||
|             if self.selected_option.get() >= 1: |             if self.selected_option.get() >= 1: | ||||||
|                 with open(wg_set, 'r') as set_file3: |                 with open(path_to_file2, 'r') as set_file3: | ||||||
|                     lines3 = set_file3.readlines() |                     lines3 = set_file3.readlines() | ||||||
|                     lines3[7] = select_tl |                     lines3[7] = select_tl | ||||||
|                 with open(wg_set, 'w') as set_file3: |                 with open(path_to_file2, 'w') as set_file3: | ||||||
|                     set_file3.writelines(lines3) |                     set_file3.writelines(lines3) | ||||||
|  |  | ||||||
|         except IndexError: |         except IndexError: | ||||||
| @@ -933,7 +908,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|         Set (on), the selected tunnel is displayed in the label. |         Set (on), the selected tunnel is displayed in the label. | ||||||
|         At (off) the label is first emptied then filled with No Autoconnect |         At (off) the label is first emptied then filled with No Autoconnect | ||||||
|         """ |         """ | ||||||
|         with open(wg_set, 'r') as set_file4: |         with open(path_to_file2, 'r') as set_file4: | ||||||
|             lines4 = set_file4.readlines() |             lines4 = set_file4.readlines() | ||||||
|  |  | ||||||
|         if lines4[7] != 'off': |         if lines4[7] != 'off': | ||||||
| @@ -944,7 +919,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|         else: |         else: | ||||||
|  |  | ||||||
|             self.wg_autostart.configure(state='disabled') |             self.wg_autostart.configure(state='disabled') | ||||||
|             self.auto_con = _('no Autoconnect') |             self.auto_con = 'no Autoconnect' | ||||||
|         self.autoconnect_var.set('') |         self.autoconnect_var.set('') | ||||||
|         self.autoconnect_var = tk.StringVar() |         self.autoconnect_var = tk.StringVar() | ||||||
|         self.autoconnect_var.set(self.auto_con) |         self.autoconnect_var.set(self.auto_con) | ||||||
| @@ -961,11 +936,11 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         """ Address Label """ |         """ Address Label """ | ||||||
|         self.add = tk.StringVar() |         self.add = tk.StringVar() | ||||||
|         self.add.set(_('Address:    ') + data[0]) |         self.add.set('Address:    ' + data[0]) | ||||||
|         self.DNS = tk.StringVar() |         self.DNS = tk.StringVar() | ||||||
|         self.DNS.set('       DNS:    ' + data[1]) |         self.DNS.set('       DNS:    ' + data[1]) | ||||||
|         self.enp = tk.StringVar() |         self.enp = tk.StringVar() | ||||||
|         self.enp.set(_('Endpoint:    ') + data[2]) |         self.enp.set('Endpoint:    ' + data[2]) | ||||||
|  |  | ||||||
|     def label_empty(self): |     def label_empty(self): | ||||||
|         self.add.set('') |         self.add.set('') | ||||||
| @@ -995,7 +970,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def stop_enter(event): |         def stop_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Click to stop selected Wireguard Tunnel')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|  |                                            'Click to stop selected Wireguard Tunnel') | ||||||
|  |  | ||||||
|         def stop_leave(_): |         def stop_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -1012,7 +988,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def empty_list_start_enter(event): |         def empty_list_start_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('No tunnels to start in the list')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, 'No tunnels to start in the list') | ||||||
|  |  | ||||||
|         def empty_list_start_leave(_): |         def empty_list_start_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -1021,7 +997,8 @@ class FrameWidgets(ttk.Frame): | |||||||
|  |  | ||||||
|         def start_enter(event): |         def start_enter(event): | ||||||
|             """ The mouse moves into the entry widget """ |             """ The mouse moves into the entry widget """ | ||||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, _('Click to start selected Wireguard Tunnel')) |             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||||
|  |                                            'Click to start selected Wireguard Tunnel') | ||||||
|  |  | ||||||
|         def start_leave(_): |         def start_leave(_): | ||||||
|             """ The mouse moves from the entry widget """ |             """ The mouse moves from the entry widget """ | ||||||
| @@ -1039,7 +1016,7 @@ class FrameWidgets(ttk.Frame): | |||||||
|     def color_label(self): |     def color_label(self): | ||||||
|         """ View activ Tunnel in color green or yellow """ |         """ View activ Tunnel in color green or yellow """ | ||||||
|  |  | ||||||
|         with open(wg_set, 'r') as read_file: |         with open(path_to_file2, 'r') as read_file: | ||||||
|             lines = read_file.readlines() |             lines = read_file.readlines() | ||||||
|             if 'light\n' in lines: |             if 'light\n' in lines: | ||||||
|                 self.lb_tunnel = ttk.Label(self, textvariable=self.StrVar, foreground='green') |                 self.lb_tunnel = ttk.Label(self, textvariable=self.StrVar, foreground='green') | ||||||
| @@ -1098,29 +1075,29 @@ class FrameWidgets(ttk.Frame): | |||||||
|             if self.l_box.size() != 0: |             if self.l_box.size() != 0: | ||||||
|  |  | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' |                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Select tunnel') |                 wt = 'Select tunnel' | ||||||
|                 msg_t = _('Please select a tunnel from the list') |                 msg_t = 'Please select a tunnel from the list.' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|             else: |             else: | ||||||
|  |  | ||||||
|                 """img_w, img_i, w_title, w_txt hand over""" |                 """img_w, img_i, w_title, w_txt hand over""" | ||||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' |                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' |                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||||
|                 wt = _('Select tunnel') |                 wt = 'Select tunnel' | ||||||
|                 msg_t = _('Please first import tunnel') |                 msg_t = 'Please first import tunnel.' | ||||||
|                 msg_window(iw, ii, wt, msg_t) |                 msg_window(iw, ii, wt, msg_t) | ||||||
|  |  | ||||||
|  |  | ||||||
| class MyToolTip(tk.Toplevel): | class MyToolTip(tk.Toplevel): | ||||||
|     TIP_X_OFFSET = 20 |     TIP_X_OFFSET = 20 | ||||||
|     TIP_Y_OFFSET = 20 |     TIP_Y_OFFSET = 20 | ||||||
|     if not wg_tips: |     if not tips: | ||||||
|         AUTO_CLEAR_TIME = 0 |         AUTO_CLEAR_TIME = 0 | ||||||
|     else: |     else: | ||||||
|         AUTO_CLEAR_TIME = 2000  # Millisecond. (1/200 sec.) |         AUTO_CLEAR_TIME = 900  # Millisecond. (1/90 sec.) | ||||||
|  |  | ||||||
|     def __init__(self, x_pos, y_pos, message=None, auto_clear=True): |     def __init__(self, x_pos, y_pos, message=None, auto_clear=True): | ||||||
|         self.x_pos = x_pos |         self.x_pos = x_pos | ||||||
|   | |||||||