Skip to main content

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
  • macOS (to be implemented)

NOTE: requires sudo privileges on linux only if NetworkManager is not used.

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
  • 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_passwords = WifiPasswords().get_currently_connected_passwords()

print(passwords)
print(connected_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

exampleoutput

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)
  • Multithreading support for windows to imporove execution speed

About

Creation date: 10-02-2019
Modified date: 26-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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wifipasswords-0.3.4-beta-.tar.gz (13.0 kB view details)

Uploaded Source

Built Distribution

wifipasswords-0.3.4b0-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file wifipasswords-0.3.4-beta-.tar.gz.

File metadata

  • Download URL: wifipasswords-0.3.4-beta-.tar.gz
  • Upload date:
  • Size: 13.0 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.0

File hashes

Hashes for wifipasswords-0.3.4-beta-.tar.gz
Algorithm Hash digest
SHA256 c84a8305efbb3054bc9c58bc56a701683caf9601e967454221ec06717a04b1c1
MD5 ef896dff4b55006ce2fbc7dfe4293e6a
BLAKE2b-256 29a348f658696873ebc401dbb1f6c87307ef13369aa8d1efe87726e3cced228c

See more details on using hashes here.

File details

Details for the file wifipasswords-0.3.4b0-py3-none-any.whl.

File metadata

  • Download URL: wifipasswords-0.3.4b0-py3-none-any.whl
  • Upload date:
  • Size: 27.6 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.0

File hashes

Hashes for wifipasswords-0.3.4b0-py3-none-any.whl
Algorithm Hash digest
SHA256 3c62860594f548cf50f87e5aebae0e59eeb2f4785a133397dc9eda2ad8deb83a
MD5 67f6c777fa5731ff493694cf89f7ab48
BLAKE2b-256 30da5023c048f6927ef3e4d0e72b9c9c8dc34fa7e4bb41b784afb3f821a044c9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page