2025-07-03 11:00:40 -06:00

40 lines
1.1 KiB
Markdown

# URL-safe Base64 for Python
A simple module for encoding without padding, fixing Python standard library's flaws.
Replaces the standard library's `base64.urlsafe_b64encode` and `base64.urlsafe_b64decode` with a cleaner implementation that returns strings instead of bytes and avoids unnecessary padding.
## Features
- **URL safe**: Uses only characters that are safe for URLs and filenames
- **No padding**: Removes trailing `=` characters for cleaner output
- **String output**: Returns proper strings instead of bytes (unlike Python's standard library)
- **Fast**: Based on Python stdlib, with constant-time padding restoration
## Installation
```sh
pip install base64url
```
Or for your project using [uv](https://docs.astral.sh/uv/):
```sh
uv add base64url
```
## Usage
```python
import base64url
text = base64url.enc(bytes(4)) # Returns "AAAAAA"
data = base64url.dec(text) # Recovers the bytes
```
### `enc(data: bytes) -> str`
Base64 encode bytes to a URL-safe string without padding.
### `dec(s: str) -> bytes`
Decode URL-safe Base64 into bytes. Padding optional.