wakeonlan

Pypi version Supported Python versions Build Status Documentation Status Code coverage

A small python module for wake on lan.

For more information on the wake on lan protocol please take a look at Wikipedia.

Installation

pip install wakeonlan

Usage

To wake up a computer using wake on lan it must first be enabled in the BIOS settings. Please note the computer you are trying to power on does not have an ip address, but it does have a mac address. The package needs to be sent as a broadcast package.

As a Python Module

Wake up a single computer by its mac address

import wakeonlan

wakeonlan.wake('ff.ff.ff.ff.ff.ff')

Wake up a single computer by its mac address with a SecureOn password

import wakeonlan

wakeonlan.wake('ff.ff.ff.ff.ff.ff/01:23:45:67:89:ab')

Wake up multiple computers by their mac addresses.

import wakeonlan

wakeonlan.wake(
    'ff.ff.ff.ff.ff.ff',
    '00-00-00-00-00-00',
    'FFFFFFFFFFFF'
)

An external host may be specified. Do note that port forwarding on that host is required. The default ip address is 255.255.255.255 and the default port is 9.

import wakeonlan

wakeonlan.wake('ff.ff.ff.ff.ff.ff',
    host='example.com',
    port=1337
)

A network adapter may be specified. The magic packet will be routed through this interface.

import wakeonlan

wakeonlan.wake(
    'ff.ff.ff.ff.ff.ff',
    interface='192.168.0.2'
)

As a Standalone Script

$ wakeonlan --help
usage: wakeonlan [-h] [-4] [-6] [-o HOST] [-p PORT] [-n INTERFACE] mac address [mac address ...]

Wake one or more computers using the wake on lan protocol.

positional arguments:
mac address           The mac addresses or "mac address/secureon password" tuples of the computers you are trying to wake.

options:
-h, --help            show this help message and exit
-o HOST, --host HOST  The host name to send the magic packet to. (default: 255.255.255.255)
-p PORT, --port PORT  The port of the host to send the magic packet to. (default: 9)
-n INTERFACE, --interface INTERFACE
                      The ip address of the network adapter to route the magic packet through. (default: None)
-4, --ipv4            To indicate ipv4 should be used. (default: False)
-6, --ipv6            To indicate ipv6 should be used. (default: False)

Compatibility

This project works with Python 3.10 or greater.

License

MIT © Remco Haszing