Compare commits
	
		
			62 Commits
		
	
	
		
			1.11.0824
			...
			8771be760d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8771be760d | |||
| 97bf9df041 | |||
| 1bba45a6c1 | |||
| a5eb6293c6 | |||
| 6e54529c0f | |||
| e28235af4b | |||
| 862cc91fa1 | |||
| 5fe6fd3f29 | |||
| 48a48ffd4c | |||
| 1278b02a95 | |||
| 22abe9f8b9 | |||
| 52f22beec6 | |||
| 8754e7ecda | |||
| a6742a0c0e | |||
| 6b75713121 | |||
| 762694aa94 | |||
| cc54f329fe | |||
| 8c01c1b984 | |||
| ebafdbdcb3 | |||
| ce4f6c84dc | |||
| b68908eaef | |||
| c4565ed169 | |||
| 485cfff457 | |||
| 1a0fc74a80 | |||
| 971c86c97f | |||
| 66dd27cc64 | |||
| cf71eae7d3 | |||
| 1f80d5342c | |||
| e719a1f23f | |||
| a0da356cec | |||
| ac87e0a4a7 | |||
| 6a3a982057 | |||
| aab90eec70 | |||
| 511d5f72df | |||
| ed93e99026 | |||
| 10c3b07053 | |||
| e9814f2b60 | |||
| c470783ff2 | |||
| 2fac03a927 | |||
| 03a7e48018 | |||
| 090842ab28 | |||
| 9eb99f0859 | |||
| feb6217637 | |||
| 5f6aaa6cf1 | |||
| 63ed0abc98 | |||
| 3102c685fd | |||
| ec10f912ea | |||
| 96164eb132 | |||
| a19f889950 | |||
| de2929896d | |||
| f9d4256679 | |||
| a0b895438c | |||
| 4c89488950 | |||
| c0ae2d2b75 | |||
| e4774abf19 | |||
| 7b1e543428 | |||
| 6f83fc7162 | |||
| b70400b456 | |||
| e25bc154ea | |||
| 7aa3cd75fe | |||
| 0b9eec8d1d | |||
| b9083d4698 | 
							
								
								
									
										238
									
								
								.idea/workspace.xml
									
									
									
										generated
									
									
									
								
							
							
						
						| @@ -4,16 +4,9 @@ | ||||
|     <option name="autoReloadType" value="SELECTIVE" /> | ||||
|   </component> | ||||
|   <component name="ChangeListManager"> | ||||
|     <list default="true" id="940e1630-c825-4d4c-be80-bc11f543c122" name="Changes" comment="- Optimize Class and Tooltip"> | ||||
|       <change afterPath="$PROJECT_DIR$/run_as" afterDir="false" /> | ||||
|     <list default="true" id="940e1630-c825-4d4c-be80-bc11f543c122" name="Changes" comment=" - Update Translate Files"> | ||||
|       <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$/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$/cls_mth_fc.py" beforeDir="false" afterPath="$PROJECT_DIR$/cls_mth_fc.py" afterDir="false" /> | ||||
|     </list> | ||||
|     <option name="SHOW_DIALOG" value="false" /> | ||||
|     <option name="HIGHLIGHT_CONFLICTS" value="true" /> | ||||
| @@ -30,7 +23,7 @@ | ||||
|   <component name="Git.Settings"> | ||||
|     <option name="RECENT_BRANCH_BY_REPOSITORY"> | ||||
|       <map> | ||||
|         <entry key="$PROJECT_DIR$" value="main" /> | ||||
|         <entry key="$PROJECT_DIR$" value="1.11.0824" /> | ||||
|       </map> | ||||
|     </option> | ||||
|     <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" /> | ||||
| @@ -65,13 +58,14 @@ | ||||
|     "RunOnceActivity.ShowReadmeOnStart": "true", | ||||
|     "Shell Script.install.executor": "Run", | ||||
|     "Shell Script.run_as.executor": "Run", | ||||
|     "git-widget-placeholder": "main", | ||||
|     "git-widget-placeholder": "1.11.1024", | ||||
|     "last_opened_file_path": "/home/punix/Pyapps/wire-py", | ||||
|     "settings.editor.selected.configurable": "reference.settingsdialog.IDE.editor.colors" | ||||
|   } | ||||
| }</component> | ||||
|   <component name="RecentsManager"> | ||||
|     <key name="CopyFile.RECENT_KEYS"> | ||||
|       <recent name="$PROJECT_DIR$/lx-icons" /> | ||||
|       <recent name="$PROJECT_DIR$" /> | ||||
|     </key> | ||||
|     <key name="MoveFile.RECENT_KEYS"> | ||||
| @@ -135,7 +129,7 @@ | ||||
|   <component name="SharedIndexes"> | ||||
|     <attachedChunks> | ||||
|       <set> | ||||
|         <option value="bundled-python-sdk-0e3be3396995-c546a90a8094-com.jetbrains.pycharm.community.sharedIndexes.bundled-PC-242.23339.19" /> | ||||
|         <option value="bundled-python-sdk-8336bb23522e-31b6be0877a2-com.jetbrains.pycharm.community.sharedIndexes.bundled-PC-241.19072.16" /> | ||||
|       </set> | ||||
|     </attachedChunks> | ||||
|   </component> | ||||
| @@ -148,102 +142,6 @@ | ||||
|       <option name="presentableId" value="Default" /> | ||||
|       <updated>1723279982210</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00017" summary="remove a ',' in DNS Name"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1724576599289</created> | ||||
|       <option name="number" value="00017" /> | ||||
|       <option name="presentableId" value="LOCAL-00017" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1724576599289</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00018" summary="fix when Filname > 17 first copy file after rename"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1724593165879</created> | ||||
|       <option name="number" value="00018" /> | ||||
|       <option name="presentableId" value="LOCAL-00018" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1724593165879</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00019" summary="add export Tunnel as zip"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1724610514657</created> | ||||
|       <option name="number" value="00019" /> | ||||
|       <option name="presentableId" value="LOCAL-00019" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1724610514658</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00020" summary="columnconfigure on all widgets set"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1724778892233</created> | ||||
|       <option name="number" value="00020" /> | ||||
|       <option name="presentableId" value="LOCAL-00020" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1724778892233</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00021" summary="little fixes a " " to ' '"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725119445803</created> | ||||
|       <option name="number" value="00021" /> | ||||
|       <option name="presentableId" value="LOCAL-00021" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725119445803</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00022" summary="add class FileHandle,
add Label to show autoconnect Tunnel
disable checkbox when Listbox is empty or no select Tunnel"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725391658456</created> | ||||
|       <option name="number" value="00022" /> | ||||
|       <option name="presentableId" value="LOCAL-00022" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725391658456</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00023" summary="add if question and add autoconnect, autoconnect_var to class Filehandle in box_set no finish!"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725434328731</created> | ||||
|       <option name="number" value="00023" /> | ||||
|       <option name="presentableId" value="LOCAL-00023" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725434328731</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00024" summary="fixes on empty Listbox now is disable and now works autoconnect label with read and write, delete works now with read and write"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725475967338</created> | ||||
|       <option name="number" value="00024" /> | ||||
|       <option name="presentableId" value="LOCAL-00024" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725475967338</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00025" summary="add Frame widget 3
for Buttons and Listbox with Scrollbar.
all Widgets new format
delete works now of disable checkbox when Listbox empty (part two)"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725567453540</created> | ||||
|       <option name="number" value="00025" /> | ||||
|       <option name="presentableId" value="LOCAL-00025" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725567453540</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00026" summary="little fixes"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725639633873</created> | ||||
|       <option name="number" value="00026" /> | ||||
|       <option name="presentableId" value="LOCAL-00026" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725639633873</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00027" summary="little fixes"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725746027132</created> | ||||
|       <option name="number" value="00027" /> | ||||
|       <option name="presentableId" value="LOCAL-00027" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725746027132</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00028" summary="little fixes replace os.system with check_call
first steps in install Script add wg_start.service file"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725820337669</created> | ||||
|       <option name="number" value="00028" /> | ||||
|       <option name="presentableId" value="LOCAL-00028" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1725820337669</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00029" summary="little fixes a labels when stop and start, installer first functions works"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1725991610908</created> | ||||
| @@ -540,18 +438,109 @@ | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1729938941027</updated> | ||||
|     </task> | ||||
|     <option name="localTasksCounter" value="66" /> | ||||
|     <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="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> | ||||
|     <task id="LOCAL-00069" summary=" - - Fix Checkbutton Autostart when first install Wire-Py"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731690583059</created> | ||||
|       <option name="number" value="00069" /> | ||||
|       <option name="presentableId" value="LOCAL-00069" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731690583060</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00070" summary=" - - Fix Checkbutton Autostart when first install Wire-Py"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731836942211</created> | ||||
|       <option name="number" value="00070" /> | ||||
|       <option name="presentableId" value="LOCAL-00070" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731836942212</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00071" summary=" - Update Translate Files"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731840048762</created> | ||||
|       <option name="number" value="00071" /> | ||||
|       <option name="presentableId" value="LOCAL-00071" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731840048763</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00072" summary=" - Update Translate Files"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731840089956</created> | ||||
|       <option name="number" value="00072" /> | ||||
|       <option name="presentableId" value="LOCAL-00072" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731840089956</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00073" summary=" - Update Translate Files"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731840188277</created> | ||||
|       <option name="number" value="00073" /> | ||||
|       <option name="presentableId" value="LOCAL-00073" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731840188278</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00074" summary=" - Update Translate Files"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731840383592</created> | ||||
|       <option name="number" value="00074" /> | ||||
|       <option name="presentableId" value="LOCAL-00074" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731840383592</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00075" summary=" - Update Translate Files"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731841930614</created> | ||||
|       <option name="number" value="00075" /> | ||||
|       <option name="presentableId" value="LOCAL-00075" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731841930615</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00076" summary=" - Update Translate Files"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731844213239</created> | ||||
|       <option name="number" value="00076" /> | ||||
|       <option name="presentableId" value="LOCAL-00076" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731844213239</updated> | ||||
|     </task> | ||||
|     <task id="LOCAL-00077" summary=" - Update Translate Files"> | ||||
|       <option name="closed" value="true" /> | ||||
|       <created>1731844339039</created> | ||||
|       <option name="number" value="00077" /> | ||||
|       <option name="presentableId" value="LOCAL-00077" /> | ||||
|       <option name="project" value="LOCAL" /> | ||||
|       <updated>1731844339039</updated> | ||||
|     </task> | ||||
|     <option name="localTasksCounter" value="78" /> | ||||
|     <servers /> | ||||
|   </component> | ||||
|   <component name="UnknownFeatures"> | ||||
|     <option featureType="com.intellij.fileTypeFactory" implementationName="*.policy" /> | ||||
|   </component> | ||||
|   <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"> | ||||
|       <map> | ||||
|         <entry key="MAIN"> | ||||
| @@ -562,7 +551,7 @@ | ||||
|                   <entry key="branch"> | ||||
|                     <value> | ||||
|                       <list> | ||||
|                         <option value="origin/wire-py-reformat-14-08-2024" /> | ||||
|                         <option value="1.11.0824" /> | ||||
|                       </list> | ||||
|                     </value> | ||||
|                   </entry> | ||||
| @@ -571,19 +560,11 @@ | ||||
|             </State> | ||||
|           </value> | ||||
|         </entry> | ||||
|         <entry key="f9756e7d-0c5c-4b84-84e4-660314c46ea4"> | ||||
|           <value> | ||||
|             <State /> | ||||
|           </value> | ||||
|         </entry> | ||||
|       </map> | ||||
|     </option> | ||||
|   </component> | ||||
|   <component name="VcsManagerConfiguration"> | ||||
|     <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="fix install and .desktop File Tar works now for user home and filebrowser.askfilebrowser start now in user home" /> | ||||
|     <MESSAGE value="replace tar with zip and Check if Zip file is empty" /> | ||||
|     <MESSAGE value="Create your own message boxes for export" /> | ||||
|     <MESSAGE value="chown Export File to 1000:1000" /> | ||||
| @@ -606,15 +587,18 @@ | ||||
|     <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 and Tooltip" /> | ||||
|     <option name="LAST_COMMIT_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" /> | ||||
|     <MESSAGE value=" - - Fix Checkbutton Autostart when first install Wire-Py" /> | ||||
|     <MESSAGE value=" - Update Translate Files" /> | ||||
|     <option name="LAST_COMMIT_MESSAGE" value=" - Update Translate Files" /> | ||||
|   </component> | ||||
|   <component name="XDebuggerManager"> | ||||
|     <breakpoint-manager> | ||||
|       <breakpoints> | ||||
|         <line-breakpoint enabled="true" suspend="THREAD" type="python-line"> | ||||
|           <url>file://$PROJECT_DIR$/start_wg.py</url> | ||||
|           <line>1</line> | ||||
|           <option name="timeStamp" value="2" /> | ||||
|           <url>file://$PROJECT_DIR$/wg_main.py</url> | ||||
|           <line>1128</line> | ||||
|           <option name="timeStamp" value="3" /> | ||||
|         </line-breakpoint> | ||||
|       </breakpoints> | ||||
|     </breakpoint-manager> | ||||
|   | ||||
							
								
								
									
										72
									
								
								Changelog
									
									
									
									
									
								
							
							
						
						| @@ -3,50 +3,96 @@ My standard System: Linux Mint 22 Cinnamon | ||||
|  | ||||
| ## [Unreleased] | ||||
|  | ||||
|  - os import in wg_func replaced by other methods | ||||
|  - os import in cls_mth_fc.py replaced by other methods | ||||
|  - If Wire-Py already runs, prevent further start | ||||
|  - for loops with lists replaced by List Comprehensions | ||||
|  - Update search after start of Wire-Py | ||||
|  - Crypt and Decrypt Config Files in ~/.config/wire_py | ||||
|  | ||||
|    ### Added | ||||
| 03-03-2025 | ||||
|  | ||||
|  - Fixes a new user files create | ||||
|  | ||||
|  | ||||
|   ### Added | ||||
| 02-03-2025 | ||||
|  | ||||
|  - Fix ipv6 in Config File on import | ||||
|  - Wirepy run now as user | ||||
|  - settings, keys and Config Files now in ~/.config/wire_py | ||||
|  - For new users, the required files are created and autostart service is started.  | ||||
|  - Tunnels are now read from the directory to view them in the list.  | ||||
|    To display only own tunnels, and read errors are minimized. | ||||
|  | ||||
|   ### Added | ||||
| 10-11-2024 | ||||
|  | ||||
|  - Fix Checkbutton Autostart when first install Wire-Py | ||||
|  - Update Translate Files | ||||
|  | ||||
|   ### Added | ||||
| 10-11-2024 | ||||
|  | ||||
|  - Translate file de_De complete | ||||
|  - 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 | ||||
| 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 | ||||
|  - Preparation for language translation part 1 | ||||
|  - separate folder for general icons | ||||
|  - install edit for new dir lx-icons | ||||
|  | ||||
|  | ||||
|   ### 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 | ||||
| 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 | ||||
| 27-10-2024 | ||||
|  | ||||
| - Add Autoconnect settings to settings.conf | ||||
|  - Add Autoconnect settings to settings | ||||
|  | ||||
|  | ||||
|   ### Added | ||||
| 26-10-2024 | ||||
|  | ||||
| - Add run_as Bash script and open_gitea.py python script | ||||
| - Add Tooltip disable/enable | ||||
| - Rename settings to settings.conf for theme, updates and tooltip enable in one file | ||||
|  - Add run_as Bash script and open_gitea.py python script | ||||
|  - Add Tooltip disable/enable | ||||
|  - Rename settings to settings for theme, updates and tooltip enable in one file | ||||
|  | ||||
|  | ||||
|   ### Added | ||||
| 25-10-2024 | ||||
|  | ||||
| - Optimize Class and Tooltip | ||||
|  - Optimize Class and Tooltip | ||||
|  | ||||
|  | ||||
|   ### Added | ||||
| 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 | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| [Desktop Entry] | ||||
| Type=Application | ||||
| Name=Wire-Py | ||||
| Exec=/usr/bin/wirepy.py | ||||
| Exec=/usr/local/bin/wg_main.py | ||||
| Terminal=false | ||||
| Categories=Network; | ||||
| Icon=/usr/share/icons/wp-icons/128/wg_vpn.png | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								__pycache__/cls_mth_fc.cpython-312.pyc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								__pycache__/message.cpython-312.pyc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								__pycache__/start_wg.cpython-312.pyc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								__pycache__/wg_main.cpython-312.pyc
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -1,35 +1,78 @@ | ||||
| """ Wireguard Classes and Method for Wire-Py """ | ||||
| """ Classes Method and functions for lx apps """ | ||||
| 
 | ||||
| import gettext | ||||
| import locale | ||||
| import os | ||||
| import shutil | ||||
| import subprocess | ||||
| import time | ||||
| from subprocess import check_call | ||||
| import tkinter as tk | ||||
| import zipfile | ||||
| from datetime import datetime | ||||
| from pathlib import Path | ||||
| from subprocess import check_call | ||||
| from tkinter import ttk | ||||
| import requests | ||||
| 
 | ||||
| APP = 'wirepy' | ||||
| LOCALE_DIR = "/usr/share/locale/" | ||||
| locale.bindtextdomain(APP, LOCALE_DIR) | ||||
| gettext.bindtextdomain(APP, LOCALE_DIR) | ||||
| gettext.textdomain(APP) | ||||
| _ = gettext.gettext | ||||
| 
 | ||||
| ''' 1 = 1. Year, 09 = Month of the Year, 2924 = Day and Year of the Year ''' | ||||
| version = 'v. 1.11.0824' | ||||
| wg_set = Path(Path.home() / '.config/wire_py/settings') | ||||
| 
 | ||||
| path_to_file2 = Path('/etc/wire_py/settings.conf') | ||||
| _u = Path.read_text(Path('/tmp/_u')) | ||||
| def dirs_and_files(): | ||||
| 
 | ||||
| UPDATE_API_URL = 'https://git.ilunix.de/api/v1/repos/punix/Wire-Py/releases' | ||||
|     pth = Path.home() / '.config/wire_py' | ||||
|     pth.mkdir(parents=True, exist_ok=True) | ||||
|     sett = Path.home() / '.config/wire_py/settings' | ||||
|     ks = Path.home() / '.config/wire_py/keys' | ||||
| 
 | ||||
|     if sett.exists(): | ||||
|         pass | ||||
| 
 | ||||
|     else: | ||||
|         sett.touch() | ||||
|         sett.write_text('[UPDATES]\non\n[THEME]\nlight\n[TOOLTIP]\nTrue\n[AUTOSTART ON]\noff\n') | ||||
| 
 | ||||
|     if ks.exists(): | ||||
|         pass | ||||
| 
 | ||||
|     else: | ||||
|         ks.touch() | ||||
| 
 | ||||
| def files_for_autostart(): | ||||
| 
 | ||||
|     pth2 = Path.home() / '.config/systemd/user' | ||||
|     pth2.mkdir(parents=True, exist_ok=True) | ||||
|     wg_ser = Path.home() / '.config/systemd/user/wg_start.service' | ||||
| 
 | ||||
|     if wg_ser.exists(): | ||||
|         pass | ||||
| 
 | ||||
|     else: | ||||
|         wg_ser.touch() | ||||
|         wg_ser.write_text('[Unit]\nDescription=Automatic Tunnel Start\nAfter=network-online.target\n\n[Service]\nType=oneshot\nExecStartPre=/bin/sleep 5\nExecStart=/usr/local/bin/start_wg.py\n[Install]\nWantedBy=default.target') | ||||
|         check_call(['systemctl', '--user', 'enable', 'wg_start.service']) | ||||
| 
 | ||||
| 
 | ||||
| class WirePyUpdate: | ||||
| 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, | ||||
|     the taskbar image for the “Download OK” window, the taskbar image for the | ||||
|     “Download error” window and the variable res | ||||
|     """ | ||||
|     @staticmethod | ||||
|     def api_down(): | ||||
|     def api_down(update_api_url, version): | ||||
|         try: | ||||
|             response = requests.get(UPDATE_API_URL) | ||||
|             response = requests.get(update_api_url) | ||||
|             response_dict = response.json() | ||||
|             response_dict = response_dict[0] | ||||
|             with open(path_to_file2, 'r') as set_file: | ||||
|             with open(wg_set, 'r') as set_file: | ||||
|                 set_file = set_file.read() | ||||
|                 if 'on\n' in set_file: | ||||
|                     if version[3:] != response_dict['tag_name']: | ||||
| @@ -42,51 +85,47 @@ class WirePyUpdate: | ||||
|             return 'No Internet Connection!' | ||||
| 
 | ||||
|     @staticmethod | ||||
|     def download(): | ||||
|     def download(urld, down_ok_image, down_not_ok_image, res): | ||||
|         try: | ||||
|             url = f'https://git.ilunix.de/punix/Wire-Py/archive/{res}.zip' | ||||
|             to_down = 'wget -qP ' + str(_u) + ' ' + url | ||||
|             to_down = 'wget -qP ' + str(Path.home()) + ' ' + urld | ||||
|             result = subprocess.call(to_down, shell=True) | ||||
|             if result == 0: | ||||
|                 shutil.chown(str(_u) + f'/{res}.zip', 1000, 1000) | ||||
|                 shutil.chown(str(Path.home()) + f'/{res}.zip', 1000, 1000) | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_vpn.png' | ||||
|                 wt = 'Download Successful' | ||||
|                 msg_t = 'Your zip file is in home directory' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                 ii = down_ok_image | ||||
|                 wt = _('Download Successful') | ||||
|                 msg_t = _('Your zip file is in home directory') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
| 
 | ||||
|             else: | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Download error' | ||||
|                 msg_t = 'Download failed! Please try again' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/error.png' | ||||
|                 ii = down_not_ok_image | ||||
|                 wt = _('Download error') | ||||
|                 msg_t = _('Download failed! Please try again') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
|         except subprocess.CalledProcessError: | ||||
|             """img_w, img_i, w_title, w_txt hand over""" | ||||
|             iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||
|             ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|             wt = 'Download error' | ||||
|             msg_t = 'Download failed! No internet connection!' | ||||
|             iw = r'/usr/share/icons/lx-icons/64/error.png' | ||||
|             ii = down_not_ok_image | ||||
|             wt = _('Download error') | ||||
|             msg_t = _('Download failed! No internet connection!') | ||||
|             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): | ||||
|     """ | ||||
|     Function for different message windows for the user. with 4 arguments to be passed. | ||||
|     To create messages with your own images, icons, and titles. As an alternative to Python Messagebox. | ||||
|     Paths to images must be specified: r'/usr/share/icons/wp-icons/64/info.png' | ||||
|     Paths to images must be specified: r'/usr/share/icons/lx-icons/64/info.png' | ||||
|     img_w = Image for Tk Window | ||||
|     img_i = Image for Icon | ||||
|     w_title = Windows Title | ||||
|     w_txt = Text for Tk Window | ||||
|     txt2 = Text for Button two | ||||
|     com = function for Button command | ||||
|     """ | ||||
| 
 | ||||
|     msg = tk.Toplevel() | ||||
|     msg.resizable(width=False, height=False) | ||||
|     msg.title(w_title) | ||||
| @@ -98,7 +137,7 @@ def msg_window(img_w, img_i, w_title, w_txt, txt2=None, com=None): | ||||
| 
 | ||||
|     label.grid(column=1, row=0) | ||||
| 
 | ||||
|     if txt2 != None and com != None: | ||||
|     if txt2 is not None and com is not None: | ||||
|         label.config(font=('Ubuntu', 11), padx=15, justify='left') | ||||
|         msg.i_window.grid(column=0, row=0, sticky='nw') | ||||
|         button2 = ttk.Button(msg, text=f'{txt2}', command=com, padding=4) | ||||
| @@ -120,7 +159,6 @@ def msg_window(img_w, img_i, w_title, w_txt, txt2=None, com=None): | ||||
| 
 | ||||
| 
 | ||||
| class Tunnel: | ||||
| 
 | ||||
|     """ | ||||
|     Class of Methods for Wire-Py | ||||
|     """ | ||||
| @@ -129,7 +167,6 @@ class Tunnel: | ||||
|     The config file is packed into a dictionary, | ||||
|     to display the values Address , DNS and Peer in the labels | ||||
|     """ | ||||
| 
 | ||||
|     @classmethod | ||||
|     def con_to_dict(cls, file): | ||||
| 
 | ||||
| @@ -142,6 +179,8 @@ class Tunnel: | ||||
|         for items in dictlist: | ||||
|             if items == '=': | ||||
|                 dictlist.remove(items) | ||||
|             if items == '::/0': | ||||
|                 dictlist.remove(items)     | ||||
| 
 | ||||
|         ''' Here is the beginning (Loop) of convert List to Dictionary ''' | ||||
|         for _ in dictlist: | ||||
| @@ -171,11 +210,9 @@ class Tunnel: | ||||
|             pre_key = final_dict['PreSharedKey'] | ||||
|         return address, dns, endpoint, pre_key | ||||
| 
 | ||||
| 
 | ||||
|     """ | ||||
|     Shows the Active Tunnel | ||||
|     """ | ||||
| 
 | ||||
|     @staticmethod | ||||
|     def active(): | ||||
| 
 | ||||
| @@ -188,80 +225,81 @@ class Tunnel: | ||||
|         return active | ||||
| 
 | ||||
|     """ | ||||
|     Shows all existing Wireguard tunnels | ||||
|     Shows all existing Wireguard tunnels a login user | ||||
|     """ | ||||
| 
 | ||||
|     @staticmethod | ||||
|     def list(): | ||||
|         wg_s = os.popen('nmcli con show | grep -iPo "(.*)(wireguard)"').read().split() | ||||
| 
 | ||||
|         ''' tl = Tunnel list # Show of 4.Element in list ''' | ||||
|         tl = wg_s[::3] | ||||
|         return tl | ||||
|         dirname = Path.home() / '.config/wire_py/' | ||||
|         wg_s = os.listdir(dirname) | ||||
|         wg_s.remove('keys') | ||||
|         wg_s.remove('settings') | ||||
|          | ||||
|         return wg_s | ||||
| 
 | ||||
|     """ | ||||
|     This will export the tunnels. | ||||
|     A zipfile with current date and time is created | ||||
|     in the user's home directory with correct right | ||||
|     """ | ||||
| 
 | ||||
|     @staticmethod | ||||
|     def export(): | ||||
|         _u1 = str(_u[6:]) | ||||
|         now_time = datetime.now() | ||||
|         now_datetime = now_time.strftime('wg-exp-' + '%m-%d-%Y' + '-' + '%H:%M') | ||||
|         tl = Tunnel.list() | ||||
| 
 | ||||
|         try: | ||||
|             if len(tl) != 0: | ||||
|                 wg_tar = str(_u) + '/' + now_datetime | ||||
|                 shutil.copytree('/etc/wire_py', '/tmp/wire_py', dirs_exist_ok=True) | ||||
|                 wg_tar = str(Path.home()) + '/' + now_datetime | ||||
|                 shutil.copytree(Path.home() / '.config/wire_py/', '/tmp/wire_py', dirs_exist_ok=True) | ||||
|                 source = Path('/tmp/wire_py') | ||||
|                 Path.unlink(Path(source) / 'wg_py', missing_ok=True) | ||||
|                 Path.unlink(Path(source) / '.keys', missing_ok=True) | ||||
|                 Path.unlink(Path(source) / 'settings.conf', missing_ok=True) | ||||
|                 Path.unlink(Path(source) / 'keys', missing_ok=True) | ||||
|                 Path.unlink(Path(source) / 'settings', missing_ok=True) | ||||
|                 shutil.make_archive(wg_tar, 'zip', source) | ||||
|                 shutil.chown(wg_tar + '.zip', 1000, 1000) | ||||
|                 #shutil.chown(wg_tar + '.zip', 1000, 1000) | ||||
|                 shutil.rmtree(source) | ||||
|                 with zipfile.ZipFile((wg_tar + '.zip'), 'r') as zf: | ||||
|                     if len(zf.namelist()) != 0: | ||||
| 
 | ||||
|                         """img_w, img_i, w_title, w_txt hand over""" | ||||
|                         iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                         iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                         ii = r'/usr/share/icons/wp-icons/48/wg_vpn.png' | ||||
|                         wt = 'Export Successful' | ||||
|                         msg_t = 'Your zip file is in home directory' | ||||
|                         wt = _('Export Successful') | ||||
|                         msg_t = _('Your zip file is in home directory') | ||||
|                         msg_window(iw, ii, wt, msg_t) | ||||
| 
 | ||||
|                     else: | ||||
| 
 | ||||
|                         """img_w, img_i, w_title, w_txt hand over""" | ||||
|                         iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||
|                         iw = r'/usr/share/icons/lx-icons/64/error.png' | ||||
|                         ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                         wt = 'Export error' | ||||
|                         msg_t = 'Export failed! Please try again' | ||||
|                         wt = _('Export error') | ||||
|                         msg_t = _('Export failed! Please try again') | ||||
|                         msg_window(iw, ii, wt, msg_t) | ||||
| 
 | ||||
|             else: | ||||
| 
 | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Select tunnel' | ||||
|                 msg_t = 'Please first import tunnel.' | ||||
|                 wt = _('Select tunnel') | ||||
|                 msg_t = _('Please first import tunnel') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
| 
 | ||||
|         except TypeError: | ||||
|             pass | ||||
| 
 | ||||
|     @staticmethod | ||||
|     def if_tip(): | ||||
|         with open(path_to_file2, 'r') as set_file2: | ||||
|                 lines2 = set_file2.readlines() | ||||
|                 if 'False\n' in lines2: | ||||
|                     return False | ||||
|                 else: | ||||
|                     return True | ||||
| 
 | ||||
| tips = Tunnel.if_tip() | ||||
| class Tipi: | ||||
|     """ | ||||
|     Class for Tooltip setting write in File | ||||
|     Calling request path to file | ||||
|     """ | ||||
|     @staticmethod | ||||
|     def if_tip(path): | ||||
|         with open(path, 'r') as set_file2: | ||||
|             lines2 = set_file2.readlines() | ||||
|             if 'False\n' in lines2: | ||||
|                 return False | ||||
|             else: | ||||
|                 return True | ||||
							
								
								
									
										42
									
								
								install
									
									
									
									
									
								
							
							
						
						| @@ -6,25 +6,25 @@ BLUE='\033[30;1;34m' | ||||
|  | ||||
| install_file_with(){ | ||||
|   clear | ||||
|   mkdir -p ~/.config/wire_py && touch ~/.config/wire_py/keys && cp -u settings ~/.config/wire_py/ && \ | ||||
|   mkdir -p ~/.config/systemd/user && cp -u wg_start.service ~/.config/systemd/user/ && \ | ||||
|   systemctl --user enable wg_start.service | ||||
|   sudo apt install python3-tk && \ | ||||
|   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 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 ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ | ||||
|   sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||
|   sudo cp -u Wire-Py.desktop /usr/share/applications/ && \ | ||||
|   sudo cp -u wg_start.service /lib/systemd/system/ && \ | ||||
|   sudo systemctl enable wg_start.service | ||||
|   sudo cp -u wg_main.py start_wg.py cls_mth_fc.py /usr/local/bin/ && \ | ||||
|   sudo cp -uR wp-icons lx-icons /usr/share/icons/ &&  sudo cp -uR TK-Themes /usr/share/ && \ | ||||
|   sudo cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ | ||||
|   sudo ln -sf /usr/local/bin/wg_main.py /usr/local/bin/wirepy && \ | ||||
|   sudo cp -u Wire-Py.desktop /usr/share/applications/  | ||||
|   } | ||||
|  | ||||
| install_arch_d(){ | ||||
|   clear | ||||
|   sudo pacman -S --noconfirm tk python3 python-requests && \ | ||||
|   sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py 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 cp -uR wp-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ | ||||
|   sudo cp -u wg_main.py start_wg.py cls_mth_fc.py && \ | ||||
|   sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/keys && sudo cp -u settings  /etc/wire_py/ && \ | ||||
|   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 cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ | ||||
|   sudo ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ | ||||
|   sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||
|   sudo cp -u Wire-Py.desktop /usr/share/applications/ && \ | ||||
| @@ -89,10 +89,11 @@ elif grep -i 'fedora' /etc/os-release > /dev/null 2>&1 | ||||
|         if ! which python3-tkinter &> /dev/null | ||||
|             then sudo dnf install python3-tkinter -y | ||||
|  | ||||
|                 sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py 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 cp -uR wp-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ | ||||
|                 sudo cp -u wg_main.py start_wg.py cls_mth_fc.py && \ | ||||
|                 sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/keys && \ | ||||
|                 sudo cp -u settings /etc/wire_py/ && \ | ||||
|                 sudo cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ | ||||
|                 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 ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ | ||||
|                 sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||
| @@ -105,10 +106,11 @@ elif grep -i 'suse' /etc/os-release > /dev/null 2>&1 | ||||
|     then | ||||
|         if ! which python311-tk &> /dev/null | ||||
|             then sudo zypper install python311-tk | ||||
|                  sudo cp -u wg_main.py start_wg.py wg_func.py wirepy.py 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 cp -uR wp-icons /usr/share/icons/ && sudo cp -uR TK-Themes /usr/share/ && \ | ||||
|                  sudo cp -u wg_main.py start_wg.py cls_mth_fc.py && \ | ||||
|                  sudo mkdir -p /etc/wire_py && sudo touch /etc/wire_py/keys && \ | ||||
|                  sudo cp -u settings /etc/wire_py/ && \ | ||||
|                  sudo cp -u languages/de/*.mo /usr/share/locale/de/LC_MESSAGES/ && \ | ||||
|                  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 ln -sf /usr/bin/wirepy.py /usr/local/bin/wirepy && \ | ||||
|                  sudo cp -u org.wirepy.policy /usr/share/polkit-1/actions/ && \ | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								languages/de/wirepy.mo
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								lx-icons/128/error.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/128/info.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/256/error.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 12 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/256/info.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 10 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/32/error.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.1 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/32/info.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.6 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/48/error.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/48/info.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.2 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/64/error.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								lx-icons/64/info.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.7 KiB | 
| @@ -1,5 +0,0 @@ | ||||
| #!/usr/bin/python3 | ||||
|  | ||||
| import webbrowser | ||||
|  | ||||
| webbrowser.open('https://git.ilunix.de/punix/Wire-Py') | ||||
| @@ -1,16 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <!DOCTYPE policyconfig PUBLIC "-//freedesktop//DTD PolicyKit Policy Configuration 1.0//EN" "http://www.freedesktop.org/standards/PolicyKit/1/policyconfig.dtd"> | ||||
| <policyconfig> | ||||
|   <vendor>Project Wire-Py</vendor> | ||||
|   <vendor_url>https://git.ilunix.de/punix/Wire-Py</vendor_url> | ||||
|   <icon_name>wg-vpn</icon_name> | ||||
|   <action id="org.wirepy"> | ||||
|     <defaults> | ||||
|       <allow_any>auth_admin_keep</allow_any> | ||||
|       <allow_inactive>auth_admin_keep</allow_inactive> | ||||
|       <allow_active>yes</allow_active> | ||||
|     </defaults> | ||||
|     <annotate key="org.freedesktop.policykit.exec.path">/usr/bin/wg_main.py</annotate> | ||||
|     <annotate key="org.freedesktop.policykit.exec.allow_gui">true</annotate> | ||||
|   </action> | ||||
| </policyconfig> | ||||
| @@ -2,7 +2,7 @@ | ||||
| from subprocess import check_call | ||||
| from pathlib import Path | ||||
|  | ||||
| path_to_file = Path('/etc/wire_py/settings.conf') | ||||
| path_to_file = Path(Path.home() / '.config/wire_py/settings') | ||||
|  | ||||
| with open(path_to_file, 'r') as a_con: | ||||
|     lines = a_con.readlines() | ||||
|   | ||||
							
								
								
									
										341
									
								
								wg_main.py
									
									
									
									
									
								
							
							
						
						| @@ -1,4 +1,8 @@ | ||||
| #!/usr/bin/python3 | ||||
|  | ||||
| import gettext | ||||
| import locale | ||||
| import webbrowser | ||||
| import os | ||||
| import shutil | ||||
| import subprocess | ||||
| @@ -6,11 +10,24 @@ import tkinter as tk | ||||
| from pathlib import Path | ||||
| from subprocess import check_call | ||||
| from tkinter import filedialog, ttk, TclError | ||||
|  | ||||
| from wg_func import (Tunnel, msg_window, WirePyUpdate, res, _u, version, path_to_file2, tips) | ||||
| from cls_mth_fc import (Tunnel, dirs_and_files, msg_window, Tipi, GiteaUpdate ,files_for_autostart) | ||||
|  | ||||
| tcl_path = Path('/usr/share/TK-Themes') | ||||
| wg_set = Path(Path.home() / '.config/wire_py/settings') | ||||
| wg_tips = Tipi.if_tip(wg_set) | ||||
|  | ||||
| ''' 1 = 1. Year, 09 = Month of the Year, 2924 = Day and Year of the Year ''' | ||||
| version = 'v. 2.03.0325' | ||||
|  | ||||
| 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): | ||||
|  | ||||
| @@ -22,7 +39,7 @@ class MainWindow(tk.Tk): | ||||
|         self.y_height = 383 | ||||
|         self.monitor_center_x = self.winfo_screenwidth() / 2 - (self.x_width / 2) | ||||
|         self.monitor_center_y = self.winfo_screenheight() / 2 - (self.y_height / 2) | ||||
|         self.resizable(width=True, height=True) | ||||
|         self.resizable(width=False, height=False) | ||||
|         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.columnconfigure(0, weight=1) | ||||
| @@ -31,7 +48,7 @@ class MainWindow(tk.Tk): | ||||
|         self.style = ttk.Style(self) | ||||
|         self.tk.call('source', str(tcl_path) + '/water.tcl') | ||||
|         ''' self.tk.call('source', 'TK-Themes/water.tcl') ''' | ||||
|         with open(path_to_file2, 'r') as read_file: | ||||
|         with open(wg_set, 'r') as read_file: | ||||
|             lines = read_file.readlines() | ||||
|             if 'light\n' in lines: | ||||
|                 self.tk.call('set_theme', 'light') | ||||
| @@ -62,7 +79,7 @@ class FrameWidgets(ttk.Frame): | ||||
|         self.imp_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_import.png') | ||||
|         self.tr_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_trash.png') | ||||
|         self.exp_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_export.png') | ||||
|         self.warning_pic = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/64/error.png') | ||||
|         self.warning_pic = tk.PhotoImage(file=r'/usr/share/icons/lx-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_stop = tk.PhotoImage(file=r'/usr/share/icons/wp-icons/48/wg_vpn-stop.png') | ||||
|  | ||||
| @@ -70,34 +87,34 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def update(): | ||||
|             if set_update.get() == 1: | ||||
|                 with open(path_to_file2, 'r') as set_file2: | ||||
|                 with open(wg_set, 'r') as set_file2: | ||||
|                     lines2 = set_file2.readlines() | ||||
|                     lines2[1] = 'off\n' | ||||
|                 with open(path_to_file2, 'w') as set_file2: | ||||
|                 with open(wg_set, 'w') as set_file2: | ||||
|                     set_file2.writelines(lines2) | ||||
|  | ||||
|             if set_update.get() == 0: | ||||
|                 with open(path_to_file2, 'r') as set_file2: | ||||
|                 with open(wg_set, 'r') as set_file2: | ||||
|                     lines2 = set_file2.readlines() | ||||
|                     lines2[1] = 'on\n' | ||||
|                 with open(path_to_file2, 'w') as set_file2: | ||||
|                 with open(wg_set, 'w') as set_file2: | ||||
|                     set_file2.writelines(lines2) | ||||
|  | ||||
|         ''' Set True or False in file ''' | ||||
|  | ||||
|         def tooltip(): | ||||
|             if set_tip.get(): | ||||
|                 with open(path_to_file2, 'r') as set_file2: | ||||
|                 with open(wg_set, 'r') as set_file2: | ||||
|                     lines2 = set_file2.readlines() | ||||
|                     lines2[5] = 'False\n' | ||||
|                 with open(path_to_file2, 'w') as set_file2: | ||||
|                 with open(wg_set, 'w') as set_file2: | ||||
|                     set_file2.writelines(lines2) | ||||
|  | ||||
|             else: | ||||
|                 with open(path_to_file2, 'r') as set_file2: | ||||
|                 with open(wg_set, 'r') as set_file2: | ||||
|                     lines2 = set_file2.readlines() | ||||
|                     lines2[5] = 'True\n' | ||||
|                 with open(path_to_file2, 'w') as set_file2: | ||||
|                 with open(wg_set, 'w') as set_file2: | ||||
|                     set_file2.writelines(lines2) | ||||
|  | ||||
|         ''' Set dark or light ''' | ||||
| @@ -106,10 +123,10 @@ class FrameWidgets(ttk.Frame): | ||||
|             if self.tk.call("ttk::style", "theme", "use") == "water-dark": | ||||
|                 ''' Set light theme ''' | ||||
|                 self.tk.call('set_theme', 'light') | ||||
|                 with open(path_to_file2, 'r') as theme_set2: | ||||
|                 with open(wg_set, 'r') as theme_set2: | ||||
|                     lines3 = theme_set2.readlines() | ||||
|                     lines3[3] = 'light\n' | ||||
|                 with open(path_to_file2, 'w') as theme_set2: | ||||
|                 with open(wg_set, 'w') as theme_set2: | ||||
|                     theme_set2.writelines(lines3) | ||||
|                 self.color_label() | ||||
|  | ||||
| @@ -117,28 +134,26 @@ class FrameWidgets(ttk.Frame): | ||||
|             if not self.tk.call("ttk::style", "theme", "use") == "water-dark": | ||||
|                 ''' Set dark theme ''' | ||||
|                 self.tk.call('set_theme', 'dark') | ||||
|                 with open(path_to_file2, 'r') as theme_set2: | ||||
|                 with open(wg_set, 'r') as theme_set2: | ||||
|                     lines4 = theme_set2.readlines() | ||||
|                     lines4[3] = 'dark\n' | ||||
|                 with open(path_to_file2, 'w') as theme_set2: | ||||
|                 with open(wg_set, 'w') as theme_set2: | ||||
|                     theme_set2.writelines(lines4) | ||||
|                 self.color_label() | ||||
|  | ||||
|         def info(): | ||||
|             def link_btn(): | ||||
|                 _u1 = str(_u[6:]) | ||||
|                 path_to_file = Path('/usr/bin/./run_as') | ||||
|                 check_call(['su', _u1, path_to_file]) | ||||
|                 webbrowser.open('https://git.ilunix.de/punix/Wire-Py') | ||||
|  | ||||
|             """img_w, img_i, w_title, w_txt , txt2, com hand over""" | ||||
|             iw = r'/usr/share/icons/wp-icons/48/wg_vpn.png' | ||||
|             ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|             wt = 'Info' | ||||
|             msg_t = ('Wire-Py a simple Wireguard Gui for Linux systems.\n\n' | ||||
|                      'Wire-Py is open source software written in Python.\n\n' | ||||
|                      'Email: polunga40@unity-mail.de also likes for donation.\n\n' | ||||
|                      'Use without warranty!\n') | ||||
|             txt2 = 'Go to Wire-Py git' | ||||
|             wt = _('Info') | ||||
|             msg_t = (_('Wire-Py a simple Wireguard Gui for Linux systems.\n\n' | ||||
|                        'Wire-Py is open source software written in Python.\n\n' | ||||
|                        'Email: polunga40@unity-mail.de also likes for donation.\n\n' | ||||
|                        'Use without warranty!\n')) | ||||
|             txt2 = _('Go to Wire-Py git') | ||||
|             com = link_btn | ||||
|  | ||||
|             msg_window(iw, ii, wt, msg_t, txt2, com) | ||||
| @@ -162,12 +177,12 @@ class FrameWidgets(ttk.Frame): | ||||
|             ''' Remove Tool-Tip ''' | ||||
|             window.my_tool_tip.destroy() | ||||
|  | ||||
|         self.options_btn = ttk.Menubutton(self.menu_frame, text='Options') | ||||
|         self.options_btn.grid(column=1, row=0) | ||||
|         self.options_btn = ttk.Menubutton(self.menu_frame, text=_('Options')) | ||||
|         self.options_btn.grid(column=1, columnspan=1, row=0) | ||||
|  | ||||
|         def sets_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -183,21 +198,21 @@ class FrameWidgets(ttk.Frame): | ||||
|         set_tip = tk.BooleanVar() | ||||
|         self.settings = tk.Menu(self, relief='flat') | ||||
|         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 Tooltips', command=tooltip, variable=set_tip) | ||||
|         self.settings.add_command(label='Light', command=theme_change_light) | ||||
|         self.settings.add_command(label='Dark', command=theme_change_dark) | ||||
|         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_command(label=_('Light'), command=theme_change_light) | ||||
|         self.settings.add_command(label=_('Dark'), command=theme_change_dark) | ||||
|  | ||||
|         ''' About BTN Menu / Label ''' | ||||
|         self.about_btn = ttk.Button(self.menu_frame, text='About', style='Toolbutton', command=info) | ||||
|         self.about_btn.grid(column=2, row=0) | ||||
|         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.readme = tk.Menu(self) | ||||
|  | ||||
|         ''' Update and Tooltip Label ''' | ||||
|         self.updates_lb = ttk.Label(self.menu_frame) | ||||
|         self.updates_lb.grid(column=3, row=0, padx=10) | ||||
|         self.updates_lb.grid(column=4, columnspan=3, row=0, padx=10) | ||||
|         '''View Checkbox for enable or disable Tooltip ''' | ||||
|         if tips: | ||||
|         if wg_tips: | ||||
|             set_tip.set(value=False) | ||||
|         else: | ||||
|             set_tip.set(value=True) | ||||
| @@ -205,11 +220,11 @@ class FrameWidgets(ttk.Frame): | ||||
|         '''View Checkbox for enable or disable Updates ''' | ||||
|         if res == 'False': | ||||
|             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): | ||||
|                 """ 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(_): | ||||
|                 """ The mouse moves from the entry widget """ | ||||
| @@ -219,14 +234,13 @@ class FrameWidgets(ttk.Frame): | ||||
|             self.updates_lb.bind('<Enter>', disable_enter) | ||||
|             self.updates_lb.bind('<Leave>', disable_leave) | ||||
|         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': | ||||
|             self.updates_lb.configure(text='No Updates') | ||||
|             self.updates_lb.configure(text=_('No Updates')) | ||||
|  | ||||
|             def congratulations_enter(event): | ||||
|                 """ 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(_): | ||||
|                 """ The mouse moves from the entry widget """ | ||||
| @@ -237,15 +251,15 @@ class FrameWidgets(ttk.Frame): | ||||
|             self.updates_lb.bind('<Leave>', congratulations_leave) | ||||
|         else: | ||||
|             set_update.set(value=0) | ||||
|             text = f'Update {res} available!' | ||||
|             text = f'Update {res} ' + _('available!') | ||||
|  | ||||
|             ''' Update BTN Menu''' | ||||
|             self.update_btn = ttk.Menubutton(self.menu_frame, text=text) | ||||
|             self.update_btn.grid(column=4, row=0, padx=0) | ||||
|             self.update_btn.grid(column=4, columnspan=3, row=0, padx=0) | ||||
|  | ||||
|             def download_enter(event): | ||||
|                 """ 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(_): | ||||
|                 """ The mouse moves from the entry widget """ | ||||
| @@ -258,7 +272,15 @@ class FrameWidgets(ttk.Frame): | ||||
|             self.download = tk.Menu(self, relief='flat') | ||||
|  | ||||
|             self.update_btn.configure(menu=self.download, style='Toolbutton') | ||||
|             self.download.add_command(label='Download', command=WirePyUpdate.download) | ||||
|             self.download.add_command(label=_('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 ''' | ||||
|         self.a = Tunnel.active() | ||||
|  | ||||
| @@ -282,9 +304,14 @@ class FrameWidgets(ttk.Frame): | ||||
|         self.lb_frame3.configure(relief='flat') | ||||
|         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 ''' | ||||
|         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.grid(column=2, row=1, padx=15, pady=4, sticky='w') | ||||
|  | ||||
| @@ -293,19 +320,19 @@ class FrameWidgets(ttk.Frame): | ||||
|         self.color_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.config(font=('Ubuntu', 9)) | ||||
|  | ||||
|         ''' 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.grid(column=0, row=4, sticky='we', padx=130) | ||||
|  | ||||
|         ''' Listbox with Scrollbar ''' | ||||
|  | ||||
|         def enable_check_box(_): | ||||
|  | ||||
|             files_for_autostart()     | ||||
|             if self.l_box.size() != 0: | ||||
|                 self.wg_autostart.configure(state='normal') | ||||
|                 self.lb_rename.config(state='normal') | ||||
| @@ -324,13 +351,12 @@ class FrameWidgets(ttk.Frame): | ||||
|         ''' Tunnel List ''' | ||||
|         self.tl = Tunnel.list() | ||||
|         for tunnels in self.tl: | ||||
|             self.l_box.insert("end", tunnels) | ||||
|             self.l_box.insert("end", tunnels[:-5]) | ||||
|             self.l_box.update() | ||||
|  | ||||
|         def list_empty_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -339,7 +365,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def list_not_empty_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -356,7 +382,7 @@ class FrameWidgets(ttk.Frame): | ||||
|         ''' Button Vpn ''' | ||||
|         if self.a != '': | ||||
|             self.stop() | ||||
|             wg_read = Path('/etc/wire_py') / str(self.a + '.conf') | ||||
|             wg_read = str(Path.home()) + '/.config/wire_py/' + str(self.a + '.conf') | ||||
|             with open(wg_read, 'r') as file: | ||||
|                 data = Tunnel.con_to_dict(file) | ||||
|  | ||||
| @@ -379,7 +405,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def imp_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -394,28 +420,28 @@ class FrameWidgets(ttk.Frame): | ||||
|             try: | ||||
|                 self.select_tunnel = self.l_box.curselection() | ||||
|                 select_tl = self.l_box.get(self.select_tunnel[0]) | ||||
|                 with open('/etc/wire_py/' + select_tl + '.conf', 'r+') as file2: | ||||
|                 with open(str(Path.home()) + '/.config/wire_py/' + select_tl + '.conf', 'r+') as file2: | ||||
|                     key = Tunnel.con_to_dict(file2) | ||||
|                     pre_key = key[3] | ||||
|                 check_call(['nmcli', 'connection', 'delete', select_tl]) | ||||
|                 self.l_box.delete(self.select_tunnel[0]) | ||||
|                 with open(path_to_file2, 'r') as set_file6: | ||||
|                 with open(wg_set, 'r') as set_file6: | ||||
|                     lines6 = set_file6.readlines() | ||||
|                     if select_tl == lines6[7].strip() and 'off' not in lines6[7].strip(): | ||||
|                         lines6[7] = 'off' | ||||
|                         with open(path_to_file2, 'w') as set_file7: | ||||
|                     if select_tl == lines6[7].strip() and 'off\n' not in lines6[7].strip(): | ||||
|                         lines6[7] = 'off\n' | ||||
|                         with open(wg_set, 'w') as set_file7: | ||||
|                             set_file7.writelines(lines6) | ||||
|                         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')) | ||||
|                 with open('/etc/wire_py/.keys', 'r') as readfile: | ||||
|                     with open('/etc/wire_py/.keys2', 'w') as writefile: | ||||
|                 Path.unlink(str(Path.home()) + '/.config/wire_py/' + str(select_tl + '.conf')) | ||||
|                 with open(str(Path.home()) + '/.config/wire_py/keys', 'r') as readfile: | ||||
|                     with open(str(Path.home()) +  '/.config/wire_py/keys2', 'w') as writefile: | ||||
|                         for line in readfile: | ||||
|                             if pre_key not in line.strip("\n"): | ||||
|                                 writefile.write(line) | ||||
|                 file_one = Path('/etc/wire_py/.keys2') | ||||
|                 file_two = file_one.with_name('.keys') | ||||
|                 file_one = Path(str(Path.home()) +  '/.config/wire_py/keys2') | ||||
|                 file_two = file_one.with_name('keys') | ||||
|                 file_one.replace(file_two) | ||||
|                 self.wg_autostart.configure(state='disabled') | ||||
|  | ||||
| @@ -423,8 +449,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|                 def empty_list_start_enter(event): | ||||
|                     """ 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(_): | ||||
|                     """ The mouse moves from the entry widget """ | ||||
| @@ -446,7 +471,7 @@ class FrameWidgets(ttk.Frame): | ||||
|                     self.btn_stst.bind('<Leave>', empty_list_start_leave) | ||||
|                     self.lb_rename.bind('<Enter>', rename_no_active_enter) | ||||
|                     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: | ||||
|                     self.StrVar.set(value='') | ||||
| @@ -464,19 +489,19 @@ class FrameWidgets(ttk.Frame): | ||||
|                 if self.l_box.size() != 0: | ||||
|  | ||||
|                     """img_w, img_i, w_title, w_txt hand over""" | ||||
|                     iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                     iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                     wt = 'Select tunnel' | ||||
|                     msg_t = 'Please select a tunnel from the list.' | ||||
|                     wt = _('Select tunnel') | ||||
|                     msg_t = _('Please select a tunnel from the list') | ||||
|                     msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|                 else: | ||||
|  | ||||
|                     """img_w, img_i, w_title, w_txt hand over""" | ||||
|                     iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                     iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                     wt = 'Select tunnel' | ||||
|                     msg_t = 'Please first import tunnel.' | ||||
|                     wt = _('Select tunnel') | ||||
|                     msg_t = _('Please first import tunnel') | ||||
|                     msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|         ''' Button Trash ''' | ||||
| @@ -486,7 +511,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def empty_list_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -496,7 +521,7 @@ class FrameWidgets(ttk.Frame): | ||||
|         def del_enter(event): | ||||
|             """ The mouse moves into the entry widget """ | ||||
|             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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -516,7 +541,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def empty_list_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -526,7 +551,7 @@ class FrameWidgets(ttk.Frame): | ||||
|         def exp_enter(event): | ||||
|             """ The mouse moves into the entry widget """ | ||||
|             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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -541,9 +566,9 @@ class FrameWidgets(ttk.Frame): | ||||
|             self.btn_exp.bind('<Leave>', exp_leave) | ||||
|  | ||||
|         ''' Label Entry ''' | ||||
|         self.lb_rename = ttk.Entry(self.lb_frame3, width=20) | ||||
|         self.lb_rename = ttk.Entry(self.lb_frame4, width=20) | ||||
|         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') | ||||
|  | ||||
|         def rename_no_active_leave(_): | ||||
| @@ -554,12 +579,12 @@ class FrameWidgets(ttk.Frame): | ||||
|         def rename_no_active_enter(event): | ||||
|             """ The mouse moves into the entry widget """ | ||||
|             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): | ||||
|             """ The mouse moves into the entry widget """ | ||||
|             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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -579,28 +604,28 @@ class FrameWidgets(ttk.Frame): | ||||
|             if len(self.lb_rename.get()) > 12: | ||||
|  | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Renaming not possible' | ||||
|                 msg_t = 'The new name may contain only 12 characters.' | ||||
|                 wt = _('Renaming not possible') | ||||
|                 msg_t = _('The new name may contain only 12 characters') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|             elif len(self.lb_rename.get()) == 0: | ||||
|  | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Renaming not possible' | ||||
|                 msg_t = 'At least one character must be entered.' | ||||
|                 wt = _('Renaming not possible') | ||||
|                 msg_t = _('At least one character must be entered') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|             elif any(ch in special_characters for ch in self.lb_rename.get()): | ||||
|  | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Renaming not possible' | ||||
|                 msg_t = 'No valid sign. These must not be used.\nBlank, Slash, Backslash and { }\n' | ||||
|                 wt = _('Renaming not possible') | ||||
|                 msg_t = _('No valid sign. These must not be used.\nBlank, Slash, Backslash and { }\n') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|             else: | ||||
| @@ -611,7 +636,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|                     ''' nmcli connection modify old connection.id iphone ''' | ||||
|                     check_call(['nmcli', 'connection', 'modify', select_tl, 'connection.id', self.lb_rename.get()]) | ||||
|                     source = Path('/etc/wire_py') / str(select_tl + '.conf') | ||||
|                     source = Path.home() / '.config/wire_py' / str(select_tl + '.conf') | ||||
|                     destination = source.with_name(str(self.lb_rename.get() + '.conf')) | ||||
|                     source.replace(destination) | ||||
|                     self.l_box.delete(self.select_tunnel[0]) | ||||
| @@ -622,11 +647,11 @@ class FrameWidgets(ttk.Frame): | ||||
|                     if self.a != '' and self.a == select_tl: | ||||
|                         self.a = Tunnel.active() | ||||
|                         self.StrVar.set(value=self.a) | ||||
|                         with open(path_to_file2, 'r') as set_file5: | ||||
|                         with open(wg_set, 'r') as set_file5: | ||||
|                             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\n' not in lines5[7].strip(): | ||||
|                             lines5[7] = new_a_connect | ||||
|                             with open(path_to_file2, 'w') as theme_set5: | ||||
|                             with open(wg_set, 'w') as theme_set5: | ||||
|                                 theme_set5.writelines(lines5) | ||||
|                             self.autoconnect_var.set(value=new_a_connect) | ||||
|  | ||||
| @@ -635,14 +660,14 @@ class FrameWidgets(ttk.Frame): | ||||
|                 except IndexError: | ||||
|  | ||||
|                     """img_w, img_i, w_title, w_txt hand over""" | ||||
|                     iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                     iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                     ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                     wt = 'Renaming not possible' | ||||
|                     msg_t = 'Please select a tunnel from the list.' | ||||
|                     wt = _('Renaming not possible') | ||||
|                     msg_t = _('Please select a tunnel from the list') | ||||
|                     msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|         ''' Button Rename ''' | ||||
|         self.btn_rename = ttk.Button(self.lb_frame3, text='Rename', state='disable', command=tl_rename, padding=4, | ||||
|         self.btn_rename = ttk.Button(self.lb_frame4, text=_('Rename'), state='disable', command=tl_rename, padding=4, | ||||
|                                      style='RnButton.TButton') | ||||
|         self.btn_rename.grid(column=3, row=0, padx=5, pady=10, sticky='ne') | ||||
|  | ||||
| @@ -654,15 +679,15 @@ class FrameWidgets(ttk.Frame): | ||||
|         self.autoconnect = ttk.Label(self.lb_frame3, textvariable=self.autoconnect_var, width=15) | ||||
|         self.autoconnect.config(font=('Ubuntu', 11)) | ||||
|         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) | ||||
|         self.wg_autostart.grid(column=0, row=0, pady=15, padx=15, sticky='nw') | ||||
|  | ||||
|         def chk_enter(event): | ||||
|             """ The mouse moves into the entry widget """ | ||||
|             window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||
|                                            'You must have at least one\n' | ||||
|                                            'tunnel in the list,to use the autostart') | ||||
|                                            _('You must have at least one\n' | ||||
|                                              'tunnel in the list,to use the autostart')) | ||||
|  | ||||
|         def chk_leave(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -673,7 +698,7 @@ class FrameWidgets(ttk.Frame): | ||||
|             def chk_a_enter(event): | ||||
|                 """ The mouse moves into the entry widget """ | ||||
|                 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(_): | ||||
|                 """ The mouse moves from the entry widget """ | ||||
| @@ -690,7 +715,7 @@ class FrameWidgets(ttk.Frame): | ||||
|             def chk_a_enter(event): | ||||
|                 """ The mouse moves into the entry widget """ | ||||
|                 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(_): | ||||
|                 """ The mouse moves from the entry widget """ | ||||
| @@ -713,9 +738,12 @@ class FrameWidgets(ttk.Frame): | ||||
|         If True then the name is automatically shortened to 12 characters and then imported. | ||||
|         If in each case false comes out, a corresponding window comes to inform the user that something is wrong. | ||||
|         """ | ||||
|  | ||||
|         dirs_and_files() | ||||
|  | ||||
|         try: | ||||
|             filepath = filedialog.askopenfilename(initialdir=str(_u), title='Select Wireguard config File', | ||||
|                                                   filetypes=[('WG config files', '*.conf')], ) | ||||
|             filepath = filedialog.askopenfilename(initialdir=str(Path.home()), title=_('Select Wireguard config File'), | ||||
|                                                   filetypes=[(_('WG config files'), '*.conf')], ) | ||||
|  | ||||
|             with open(filepath, 'r') as file: | ||||
|                 read = file.read() | ||||
| @@ -728,25 +756,25 @@ class FrameWidgets(ttk.Frame): | ||||
|                     key = Tunnel.con_to_dict(file) | ||||
|                     pre_key = key[3] | ||||
|                     if len(pre_key) != 0: | ||||
|                         with open('/etc/wire_py/.keys', 'r') as readfile: | ||||
|                         with open(str(Path.home()) + '/.config/wire_py/keys', 'r') as readfile: | ||||
|                             p_key = readfile.readlines() | ||||
|                             if pre_key in p_key or pre_key + '\n' in p_key: | ||||
|                                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                                 iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||
|                                 iw = r'/usr/share/icons/lx-icons/64/error.png' | ||||
|                                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                                 wt = 'Import Error' | ||||
|                                 msg_t = 'Tunnel already available!\nPlease use another file for import' | ||||
|                                 wt = _('Import Error') | ||||
|                                 msg_t = _('Tunnel already available!\nPlease use another file for import') | ||||
|                                 msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|                             else: | ||||
|  | ||||
|                                 with open('/etc/wire_py/.keys', 'a') as keyfile: | ||||
|                                 with open(str(Path.home()) +  '/.config/wire_py/keys', 'a') as keyfile: | ||||
|                                     keyfile.write(pre_key + '\r') | ||||
|                                     if len(path_split1) > 17: | ||||
|                                         p1 = shutil.copy(filepath, Path('/etc/wire_py/')) | ||||
|                                         p1 = shutil.copy(filepath, str(Path.home()) + '/.config/wire_py/') | ||||
|                                         path_split = path_split1[len(path_split1) - 17:] | ||||
|                                         os.rename(p1, Path('/etc/wire_py') / str(path_split)) | ||||
|                                         new_conf = '/etc/wire_py/' + path_split | ||||
|                                         os.rename(p1, str(Path.home()) + '/.config/wire_py/' + str(path_split)) | ||||
|                                         new_conf = str(Path.home()) + '/.config/wire_py/' + path_split | ||||
|                                         if self.a != '': | ||||
|                                             check_call(['nmcli', 'connection', 'down', Tunnel.active()]) | ||||
|                                             self.label_empty() | ||||
| @@ -755,7 +783,7 @@ class FrameWidgets(ttk.Frame): | ||||
|                                                                  'wireguard', 'file', new_conf], text=True) | ||||
|  | ||||
|                                     else: | ||||
|                                         shutil.copy(filepath, Path('/etc/wire_py/')) | ||||
|                                         shutil.copy(filepath, str(Path.home()) + '/.config/wire_py/') | ||||
|                                         if self.a != '': | ||||
|                                             check_call(['nmcli', 'connection', 'down', Tunnel.active()]) | ||||
|                                             self.label_empty() | ||||
| @@ -774,8 +802,8 @@ class FrameWidgets(ttk.Frame): | ||||
|                                     def chk_a_enter(event): | ||||
|                                         """ The mouse moves into the entry widget """ | ||||
|                                         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(_): | ||||
|                                         """ The mouse moves from the entry widget """ | ||||
| @@ -785,7 +813,7 @@ class FrameWidgets(ttk.Frame): | ||||
|                                     def list_info_enter(event): | ||||
|                                         """ The mouse moves into the entry widget """ | ||||
|                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||
|                                                                        'List of available tunnels') | ||||
|                                                                        _('List of available tunnels')) | ||||
|  | ||||
|                                     def list_info_leave(_): | ||||
|                                         """ The mouse moves from the entry widget """ | ||||
| @@ -795,8 +823,8 @@ class FrameWidgets(ttk.Frame): | ||||
|                                     def del_enter(event): | ||||
|                                         """ The mouse moves into the entry widget """ | ||||
|                                         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(_): | ||||
|                                         """ The mouse moves from the entry widget """ | ||||
| @@ -806,8 +834,8 @@ class FrameWidgets(ttk.Frame): | ||||
|                                     def exp_enter(event): | ||||
|                                         """ The mouse moves into the entry widget """ | ||||
|                                         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(_): | ||||
|                                         """ The mouse moves from the entry widget """ | ||||
| @@ -817,8 +845,8 @@ class FrameWidgets(ttk.Frame): | ||||
|                                     def rename_enter(event): | ||||
|                                         """ The mouse moves into the entry widget """ | ||||
|                                         window.my_tool_tip = MyToolTip(event.x_root, event.y_root, | ||||
|                                                                        'To rename a tunnel, you need to\n' | ||||
|                                                                        'select a tunnel from the list') | ||||
|                                                                        _('To rename a tunnel, you need to\n' | ||||
|                                                                          'select a tunnel from the list')) | ||||
|  | ||||
|                                     def rename_leave(_): | ||||
|                                         """ The mouse moves from the entry widget """ | ||||
| @@ -840,7 +868,7 @@ class FrameWidgets(ttk.Frame): | ||||
|                                     self.StrVar.set(self.a) | ||||
|                                     self.color_label() | ||||
|                                     self.stop() | ||||
|                                     wg_read = Path('/etc/wire_py') / str(self.a + '.conf') | ||||
|                                     wg_read = str(Path.home()) + '/.config/wire_py/' + str(self.a + '.conf') | ||||
|                                     with open(wg_read, 'r') as file_for_key: | ||||
|                                         data = Tunnel.con_to_dict(file_for_key) | ||||
|  | ||||
| @@ -852,10 +880,10 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|             if 'PrivateKey = ' and 'Endpoint = ' not in read: | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/error.png' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/error.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Import Error' | ||||
|                 msg_t = 'Oh... no valid Wireguard File!\nPlease select a valid Wireguard File' | ||||
|                 wt = _('Import Error') | ||||
|                 msg_t = _('Oh... no valid Wireguard File!\nPlease select a valid Wireguard File') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|         except EOFError: | ||||
| @@ -879,10 +907,10 @@ class FrameWidgets(ttk.Frame): | ||||
|             select_tl = self.l_box.get(select_tunnel[0]) | ||||
|  | ||||
|             if self.selected_option.get() == 0: | ||||
|                 with open(path_to_file2, 'r') as set_file3: | ||||
|                 with open(wg_set, 'r') as set_file3: | ||||
|                     lines3 = set_file3.readlines() | ||||
|                     lines3[7] = 'off' | ||||
|                 with open(path_to_file2, 'w') as set_file3: | ||||
|                     lines3[7] = 'off\n' | ||||
|                 with open(wg_set, 'w') as set_file3: | ||||
|                     set_file3.writelines(lines3) | ||||
|  | ||||
|                 tl = Tunnel.list() | ||||
| @@ -891,10 +919,10 @@ class FrameWidgets(ttk.Frame): | ||||
|                     self.wg_autostart.configure(state='disabled') | ||||
|  | ||||
|             if self.selected_option.get() >= 1: | ||||
|                 with open(path_to_file2, 'r') as set_file3: | ||||
|                 with open(wg_set, 'r') as set_file3: | ||||
|                     lines3 = set_file3.readlines() | ||||
|                     lines3[7] = select_tl | ||||
|                 with open(path_to_file2, 'w') as set_file3: | ||||
|                 with open(wg_set, 'w') as set_file3: | ||||
|                     set_file3.writelines(lines3) | ||||
|  | ||||
|         except IndexError: | ||||
| @@ -908,18 +936,19 @@ class FrameWidgets(ttk.Frame): | ||||
|         Set (on), the selected tunnel is displayed in the label. | ||||
|         At (off) the label is first emptied then filled with No Autoconnect | ||||
|         """ | ||||
|         with open(path_to_file2, 'r') as set_file4: | ||||
|         with open(wg_set, 'r') as set_file4: | ||||
|             lines4 = set_file4.readlines() | ||||
|  | ||||
|         if lines4[7] != 'off': | ||||
|         if lines4[7] != 'off\n': | ||||
|             print(lines4[7]) | ||||
|             self.selected_option.set(1) | ||||
|             self.autoconnect_var.set('') | ||||
|             self.auto_con = lines4[7] | ||||
|  | ||||
|         else: | ||||
|             self.selected_option.set(0) | ||||
|             self.auto_con = _('no Autoconnect') | ||||
|  | ||||
|             self.wg_autostart.configure(state='disabled') | ||||
|             self.auto_con = 'no Autoconnect' | ||||
|         self.autoconnect_var.set('') | ||||
|         self.autoconnect_var = tk.StringVar() | ||||
|         self.autoconnect_var.set(self.auto_con) | ||||
| @@ -936,11 +965,11 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         """ Address Label """ | ||||
|         self.add = tk.StringVar() | ||||
|         self.add.set('Address:    ' + data[0]) | ||||
|         self.add.set(_('Address:    ') + data[0]) | ||||
|         self.DNS = tk.StringVar() | ||||
|         self.DNS.set('       DNS:    ' + data[1]) | ||||
|         self.enp = tk.StringVar() | ||||
|         self.enp.set('Endpoint:    ' + data[2]) | ||||
|         self.enp.set(_('Endpoint:    ') + data[2]) | ||||
|  | ||||
|     def label_empty(self): | ||||
|         self.add.set('') | ||||
| @@ -970,8 +999,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def stop_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -988,7 +1016,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def empty_list_start_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -997,8 +1025,7 @@ class FrameWidgets(ttk.Frame): | ||||
|  | ||||
|         def start_enter(event): | ||||
|             """ 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(_): | ||||
|             """ The mouse moves from the entry widget """ | ||||
| @@ -1016,7 +1043,7 @@ class FrameWidgets(ttk.Frame): | ||||
|     def color_label(self): | ||||
|         """ View activ Tunnel in color green or yellow """ | ||||
|  | ||||
|         with open(path_to_file2, 'r') as read_file: | ||||
|         with open(wg_set, 'r') as read_file: | ||||
|             lines = read_file.readlines() | ||||
|             if 'light\n' in lines: | ||||
|                 self.lb_tunnel = ttk.Label(self, textvariable=self.StrVar, foreground='green') | ||||
| @@ -1037,7 +1064,7 @@ class FrameWidgets(ttk.Frame): | ||||
|                 self.select_tunnel = self.l_box.curselection() | ||||
|                 select_tl = self.l_box.get(self.select_tunnel[0]) | ||||
|                 check_call(['nmcli', 'connection', 'up', select_tl]) | ||||
|                 wg_read = Path('/etc/wire_py') / str(select_tl + '.conf') | ||||
|                 wg_read = str(Path.home()) + '/.config/wire_py/' + str(select_tl + '.conf') | ||||
|                 with open(wg_read, 'r') as file: | ||||
|                     data = Tunnel.con_to_dict(file) | ||||
|  | ||||
| @@ -1075,29 +1102,29 @@ class FrameWidgets(ttk.Frame): | ||||
|             if self.l_box.size() != 0: | ||||
|  | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Select tunnel' | ||||
|                 msg_t = 'Please select a tunnel from the list.' | ||||
|                 wt = _('Select tunnel') | ||||
|                 msg_t = _('Please select a tunnel from the list') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|             else: | ||||
|  | ||||
|                 """img_w, img_i, w_title, w_txt hand over""" | ||||
|                 iw = r'/usr/share/icons/wp-icons/64/info.png' | ||||
|                 iw = r'/usr/share/icons/lx-icons/64/info.png' | ||||
|                 ii = r'/usr/share/icons/wp-icons/48/wg_msg.png' | ||||
|                 wt = 'Select tunnel' | ||||
|                 msg_t = 'Please first import tunnel.' | ||||
|                 wt = _('Select tunnel') | ||||
|                 msg_t = _('Please first import tunnel') | ||||
|                 msg_window(iw, ii, wt, msg_t) | ||||
|  | ||||
|  | ||||
| class MyToolTip(tk.Toplevel): | ||||
|     TIP_X_OFFSET = 20 | ||||
|     TIP_Y_OFFSET = 20 | ||||
|     if not tips: | ||||
|     if not wg_tips: | ||||
|         AUTO_CLEAR_TIME = 0 | ||||
|     else: | ||||
|         AUTO_CLEAR_TIME = 900  # Millisecond. (1/90 sec.) | ||||
|         AUTO_CLEAR_TIME = 2000  # Millisecond. (1/200 sec.) | ||||
|  | ||||
|     def __init__(self, x_pos, y_pos, message=None, auto_clear=True): | ||||
|         self.x_pos = x_pos | ||||
|   | ||||
| @@ -5,6 +5,6 @@ After=network-online.target | ||||
| [Service] | ||||
| Type=oneshot | ||||
| ExecStartPre=/bin/sleep 5 | ||||
| ExecStart=/usr/bin/start_wg.py | ||||
| ExecStart=/usr/local/bin/start_wg.py | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
| WantedBy=default.target | ||||
|   | ||||