A Python client for interacting with the pfSense web interface. This library provides programmatic access to pfSense's user management, VPN configuration, and certificate management features.
-
User Management
- Create new users with certificates
- Edit existing users
- Remove users
- List all users
-
OpenVPN Configuration
- Download OpenVPN bundles for users
- Support for various client configurations (Windows, Android, iOS)
- Bundle customization options
-
Certificate Management
- Parse and list certificates
- Renew certificates
- Remove certificates
- Auto-renewal support for expiring certificates
You can install the package using pip:
pip install pfsense-api-client
Or install from source:
git clone https://github.com/hadamrd/PfsenseApiPyClient.git
cd pfsense-api-client
pip install -e .
Here's a simple example to get you started:
from pfsense_api import PfsenseAPI
# Initialize the client
config = {
"host": "your-pfsense-host",
"username": "admin",
"password": "your-password"
}
client = PfsenseAPI(config)
# Create a new user with certificate
client.create_user(
user_name="newuser",
user_password="userpass123",
groups=["VPNUsers"],
create_cert=True
)
# Download OpenVPN configuration for the user
client.download_openvpn_bundle(
username="newuser",
dest_folder="./vpn_configs",
bundle_cat1="Current Windows Installers (2.5.2-Ix01)",
bundle_cat2="64-bit"
)
The PfsenseAPI client accepts the following configuration parameters:
host
: Your pfSense server hostname or IP addressusername
: Administrator usernamepassword
: Administrator password
# Create a user
client.create_user(
user_name="newuser",
user_password="password123",
groups=["VPNUsers"],
create_cert=True,
key_type="RSA",
key_len=4096
)
# Edit a user
client.edit_user(
username="existinguser",
new_password="newpass123",
groups=["NewGroup"]
)
# Remove a user
client.remove_user("username")
# Renew certificates that will expire within 90 days
client.renew_certs(days_before_expiration=90)
# Renew specific user's certificate
client.renew_cert_user("username")
# Remove user's certificate
client.remove_cert_user("username")
# Download Windows 64-bit installer
client.download_openvpn_bundle(
username="user",
dest_folder="./vpn_configs",
bundle_cat1="Current Windows Installers (2.5.2-Ix01)",
bundle_cat2="64-bit"
)
# Download Android configuration
client.download_openvpn_bundle(
username="user",
dest_folder="./vpn_configs",
bundle_cat1="Inline Configurations",
bundle_cat2="Android"
)
The library includes several custom exceptions for specific error cases:
AuthenticationException
: Failed to authenticate with pfSenseUserAlreadyExistsError
: Attempted to create a user that already existsUserNotFoundError
: User not found in the systemCertificateNotFoundError
: Certificate not found for the specified userCertificateRenewalError
: Failed to renew certificateVpnExportForUserNotFoundError
: VPN configuration not found for user
The library uses Python's built-in logging system. You can configure the logging level and format according to your needs:
import logging
logging.basicConfig(
level=logging.DEBUG,
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
)
Contributions are welcome! Please feel free to submit a Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.