forked from 7aman/wdpass
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* py_sg renamed to py3_sg * update readme --------- Co-authored-by: Kunhee Ha <[email protected]>
- Loading branch information
Showing
6 changed files
with
83 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,95 +1,109 @@ | ||
# wdpass | ||
|
||
WD Passport Ultra Complete Utilities for Linux. | ||
|
||
Thanks to: | ||
|
||
- [Dan Lenski](https://github.com/dlenski) for [py_sg](https://pypi.org/project/py_sg/) (Python2) | ||
- [0-duke](https://github.com/0-duke) and [derekhe](https://github.com/derekhe) for [wdpassport-utils](https://github.com/derekhe/wdpassport-utils) (Python2) | ||
- [crypto-universe](https://github.com/crypto-universe/) for Python3 migration of [py_sg](https://github.com/crypto-universe/py3_sg) and [wdpassport-utils](https://github.com/crypto-universe/wdpassport-utils) | ||
- [tvladyslav](https://github.com/tvladyslav/) for Python3 migration of [py_sg](https://github.com/tvladyslav/py3_sg) and [wdpassport-utils](https://github.com/tvladyslav/wdpassport-utils) | ||
|
||
## Intro | ||
|
||
This script let you unlock, change password and erase Western Digital Passport devices on Linux platform. | ||
This script let you unlock, change password and erase Western Digital Passport devices on Linux platform. | ||
|
||
## Requirements | ||
|
||
- Install `lsscsi` package or any package that provides `lsscsi` command in your linux distro. | ||
|
||
## Install | ||
|
||
### Install the latest version from PyPi | ||
|
||
```shell | ||
sudo python3 -m pip install wdpass | ||
``` | ||
|
||
### Install the latest version manually | ||
|
||
- Install `lsscsi` package or any package that provides `lsscsi` command. | ||
- Provide `<Python.h>` header file by installing Python Developer Package. (usually `python3-dev` or `python3-devel`) | ||
- Install the latest py3_sg from [py3_sg](https://github.com/crypto-universe/py3_sg) | ||
- Install the latest py3_sg from [py3_sg](https://github.com/tvladyslav/py3_sg) | ||
- And finally install `wdpass` from this repository. | ||
|
||
For example on Ubuntu: | ||
|
||
```shell | ||
sudo apt install lsscsi python3-dev | ||
sudo python3 -m pip install https://github.com/crypto-universe/py3_sg/archive/master.zip | ||
sudo python3 -m pip install https://github.com/tvladyslav/py3_sg/archive/master.zip | ||
sudo python3 -m pip install https://github.com/7aman/wdpass/archive/master.zip | ||
``` | ||
|
||
### Install an old version from PyPi | ||
|
||
PyPi package is not based on the latest version but it works for most cases. | ||
|
||
```shell | ||
# install v0.0.3 | ||
sudo python3 -m pip install wdpass | ||
``` | ||
|
||
## Usage | ||
|
||
Run script as root. | ||
Run `wdpass` as root. | ||
|
||
There are few options: | ||
``` | ||
|
||
```shell | ||
-h, --help show this help message and exit | ||
``` | ||
|
||
Lists all possible arguments. | ||
|
||
``` | ||
```shell | ||
-s, --status Check device status and encryption type | ||
``` | ||
|
||
Get device encryption status and cipher suites used. | ||
``` | ||
|
||
```shell | ||
-u, --unlock Unlock | ||
``` | ||
|
||
You will be asked to enter the unlock password. If everything is fine device will be unlocked. | ||
|
||
``` | ||
```shell | ||
-us, --unlock_with_saved_passwd Unlock with the password saved | ||
``` | ||
|
||
Unlock using the saved password. If everything is fine device will be unlocked. | ||
|
||
``` | ||
```shell | ||
-sp, --save_passwd Save password | ||
``` | ||
|
||
When unlock password, it will save user password to passwd.bin, so you can use "-us" for next time to auto unlock. | ||
|
||
``` | ||
```shell | ||
-m, --mount Enable mount point for an unlocked device | ||
``` | ||
After unlock, your operating system still thinks that your device is a strange thing attached to his usb port and he don't know how to manage. You need this option to force the O.S. to rescan the device and handle it as a normal external usb harddrive. | ||
|
||
``` | ||
After unlock, your operating system still thinks that your device is a strange thing attached to his usb port and he don't know how to manage. You need this option to force the O.S. to re-scan the device and handle it as a normal external usb hard drive. | ||
|
||
```shell | ||
-c, --change_passwd Change (or disable) password | ||
``` | ||
|
||
This option let you to encrypt your device, remove password protection and change your current password. | ||
If device is "without lock" and you want it to be password protect leave the "OLD password" field empty and choose insert the new password. | ||
If the device is password protected and you want to be as a normal unencrypted device, inser the old password and leave the "NEW password" field empty. | ||
If the device is password protected and you want to be as a normal unencrypted device, insert the old password and leave the "NEW password" field empty. | ||
If you only want to change password do it as usual. | ||
|
||
``` | ||
```shell | ||
-e, --erase Secure erase device | ||
``` | ||
|
||
"Erase" the device. This will remove the internal key associated to you password and all your data will be unaccessible. You will also lose your partition table and you will need to create a new one (you can use fdisk and mkfs). | ||
|
||
``` | ||
```shell | ||
-d DEVICE, --device DEVICE Force device path (ex. /dev/sdb). Usually you don't need this option. | ||
``` | ||
The script will try to auto detect the current device path of your WD Passport device. | ||
If something is wrong or you want to manually specify the device path yourself you can use this option. | ||
## Disclaimer | ||
I'm in no way sponsored by or connected with Western Digital. | ||
Use any of the information contained in this repository at your own risk. I accept no | ||
responsibility. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
{ | ||
"version": "0.2", | ||
"ignorePaths": [], | ||
"dictionaryDefinitions": [], | ||
"dictionaries": [], | ||
"words": [ | ||
"derekhe", | ||
"devel", | ||
"distro", | ||
"fdisk", | ||
"geteuid", | ||
"htonl", | ||
"htons", | ||
"pwblen", | ||
"tvladyslav", | ||
"Unlocker", | ||
"urandom", | ||
"wdpass", | ||
"wdpassport", | ||
"Zaman" | ||
], | ||
"ignoreWords": [ | ||
"Lenski" | ||
], | ||
"import": [] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
__version__ = '0.0.5' | ||
__version__ = '0.1.0' |