Retreive and save all WiFi networks and passwords on the device. Cross platform windows, linux, macOS
Project description
wifipasswords
Retrieve and save all WiFi networks and passwords on the device.
On windows uses the netsh subprocess.
On linux reads the NetworkManager files or wpa_supplicant.conf.
Cross platform:
- Windows
- Linux (work in progress - need to add DNS and visible network config)
- macOS (to be implemented)
NOTE: requires sudo privileges on linux when running the get_password() function due to file ownership permissions.
Features
- Importable as a package or able to be run directly on the command line.
- Tested in Python 3.6 - 3.9
- Tested on Windows 10, Ubuntu 18 - 20.04 and Debian Buster.
- Returns WiFi passwords as a dictionary
- Able to show visible wifi networks
- Able to show currently connected SSID.
- Able to show current DNS config (Windows only at present)
- Can save networks as JSON or wpa_supplicant.conf file.
Installation
Installed via pip using: pip install wifipasswords
Usage
from wifipasswords import WifiPasswords
passwords = WifiPasswords().get_passwords()
connected_ssids = WifiPasswords().get_currently_connected_ssids()
print(passwords)
WifiPasswords().save_wpa_supplicant('.', passwords, True, 'GB')
Command Line Usage
Provides a command line interface callable after installation with:
python3 -m wifipasswords
wifipasswords
~ $ wifipasswords
To see command line options run wifipasswords -h
Packaging as EXE
Can be packaged to an EXE on windows with:
pyinstaller --clean --noconsole --onefile -i <icon> wifipasswords_exe.py
The wifipasswords_exe.py file is the same as the main.py file in the package except will pause after console output is finished to prevent the terminal from auto-closing if the EXE is run directly.
To-Do
- Add macOS Support
- Add getters for accessing variables directly
- Fix visible network, DNS config and number of interfaces for Linux
- Add automated tests
- Add method to check and return only the connected SSID name and Password
- Use nmcli to retrieve passwords on linux rather than reading files (may not require sudo)
About
Creation date: 10-02-2019
Modified date: 23-03-2021
Dependencies: colorama
Licence
Copyright (C) 2019-2021 Joe Campbell
GNU GENERAL PUBLIC LICENSE (GPLv3)
This program is free software: you can redistribute it and / or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see < https: // www.gnu.org/licenses/>.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file wifipasswords-0.3.2-beta-.tar.gz
.
File metadata
- Download URL: wifipasswords-0.3.2-beta-.tar.gz
- Upload date:
- Size: 12.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b6ac0a62b016a3ab1f4c3ef5540010f64dca45987adb7c08f03a81f0bd7098e6 |
|
MD5 | aa94aaaa5a7a9eed99aa93cb153e1097 |
|
BLAKE2b-256 | ef96719d6c756f1e0139c8fd5c9c4ce0276bd51ce9890a41e1d7cc600f36e71b |
File details
Details for the file wifipasswords-0.3.2b0-py3-none-any.whl
.
File metadata
- Download URL: wifipasswords-0.3.2b0-py3-none-any.whl
- Upload date:
- Size: 26.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 26b378a79d810990b195f2dabc98fc4c829db379ab9845ead0b29f27c24a344e |
|
MD5 | 97866bf15a2d0ec768cc6074b72d8a77 |
|
BLAKE2b-256 | 3fdfdb0ab054deaf6f9c0b76d6c8cf76e0b6c6f09f9abb230102a9ac9d20c23f |