Skip to main content

A Python library for parsing and modifying RPF files for GTA IV.

Project description

pyrpfiv

A Python library for parsing and modifying RPF (Resource Package Format) files, specifically designed for Grand Theft Auto IV. This library provides simple functionality to read, extract, and modify files within RPF archives while handling encryption and file name hashing.

Table of Contents

Core Functions

Setup & Requirements

Documentation

Additional Information

Features

  • Parse RPF3 file format used in GTA IV
  • Extract files from RPF archives
  • Add/Replace files in RPF archives while preserving hash structure
  • Automatic handling of encrypted TOC (Table of Contents)
  • Support for file name hash resolution using hashes.ini
  • JSON export of RPF contents
  • Detailed logging of operations

Installation

pip install pyrpfiv

Requirements

  • Python 3.8 or higher
  • pycryptodome >= 3.19.0
  • GTA IV executable version 1.0.4.0, 1.0.4r2, 1.0.6.0, 1.0.7.0, 1.0.8.0, 1.2.0.32, 1.2.0.43, or 1.2.0.59 (other versions are not supported)
  • hashes.ini file in working directory (for filename resolution)

Basic Usage

from pyrpfiv import RPFParser

# Initialize parser with RPF file and GTA IV executable path
parser = RPFParser(
    rpf_filename="path/to/your.rpf",
    gtaiv_exe_path="path/to/gtaiv.exe"  # Must be a supported version (e.g. 1.0.4.0, 1.0.7.0, 1.0.8.0, 1.2.0.59)
)

API Reference

RPFParser Class

Initialization

parser = RPFParser(rpf_filename: str, gtaiv_exe_path: str)
  • rpf_filename: Path to the RPF file you want to work with
  • gtaiv_exe_path: Path to GTA IV executable (versions 1.0.4.0, 1.0.4r2, 1.0.6.0, 1.0.7.0, 1.0.8.0, 1.2.0.32, 1.2.0.43, or 1.2.0.59 supported for AES key extraction)

File Operations

Extracting Files
parser.extract_file(
    file_path="RADIO_VLADIVOSTOK/track_01",  # Note: RPF files don't use extensions
    output_dir="output/directory"
)
  • file_path: Path of the file within the RPF archive
  • output_dir: Directory where the file should be extracted
Replacing Files
parser.add_file(
    source_file="path/to/new/audio",
    rpf_path="RADIO_VLADIVOSTOK/track_01"  # Note: RPF files don't use extensions
)
  • source_file: Path to the new file that will replace the existing one
  • rpf_path: Path of the file to replace within the RPF archive
Listing Files
# Access all files in the RPF
for entry in parser.paths:
    print(f"File: {entry['path']}")
    print(f"Size: {entry['size']} bytes")
    print(f"Offset: 0x{entry['offset']:X}")
Exporting RPF Contents
# Export to JSON
parser.save_json("rpf_contents.json")

File Structure Requirements

hashes.ini

The library requires a hashes.ini file in the working directory for resolving file name hashes. Format:

hash_value=filename
# Example:
123456789=track_01

Error Handling

The library provides several custom exceptions for proper error handling:

  • RPFParsingError: General parsing errors
  • FileExtractionError: File extraction failures
  • FileNotFoundInRPFError: File not found in RPF archive
  • HashesFileNotFoundError: Missing hashes.ini file
  • InvalidTOCEntryError: Invalid TOC entry
  • AESKeyExtractionError: Failed to extract AES key
  • TOCDecryptionError: Failed to decrypt TOC

Example error handling:

from pyrpfiv import RPFParser, FileNotFoundInRPFError

try:
    parser.extract_file("nonexistent/file", "output")
except FileNotFoundInRPFError as e:
    print(f"Error: {e}")

Technical Details

Version Support

Currently, GTA IV versions 1.0.4.0, 1.0.4r2, 1.0.6.0, 1.0.7.0, 1.0.8.0, 1.2.0.32, 1.2.0.43, and 1.2.0.59 are supported. The AES key extraction is specifically tailored for these versions of the executable. Other versions of GTA IV will not work with this library.

Disclaimer

This tool is provided for educational and research purposes only. The RPF file format is proprietary to Rockstar Games. Users of this library should:

  1. Respect Rockstar Games' intellectual property rights
  2. Comply with Rockstar Games' terms of service and EULA
  3. Only use this tool with legally obtained copies of supported GTA IV versions
  4. Not use this tool for unauthorized distribution or modification of game files

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

Special thanks to:

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

pyrpfiv-0.1.4.tar.gz (894.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyrpfiv-0.1.4-py3-none-any.whl (905.0 kB view details)

Uploaded Python 3

File details

Details for the file pyrpfiv-0.1.4.tar.gz.

File metadata

  • Download URL: pyrpfiv-0.1.4.tar.gz
  • Upload date:
  • Size: 894.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.14.2 Linux/6.11.0-1018-azure

File hashes

Hashes for pyrpfiv-0.1.4.tar.gz
Algorithm Hash digest
SHA256 a606f0ee845b7ed98da5443875d4c8e0ce1401fb61349f4e323731fd7b96e150
MD5 2bc3badc49cb3b322cab4621b903d950
BLAKE2b-256 95f8ca97996f5e1c20601a5c9bf4b2ce2308484abf547098d80d50ad0ad82ee0

See more details on using hashes here.

File details

Details for the file pyrpfiv-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: pyrpfiv-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 905.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.14.2 Linux/6.11.0-1018-azure

File hashes

Hashes for pyrpfiv-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 8b1939d453558767fc311810d45349fd27ac84c7fe317bf1e4b18341fe5e1661
MD5 3f738c753b433fabbe1f4cb7e5394e1f
BLAKE2b-256 d7a3c89d20904c0200536dd12fe2eeade13ae86d6cfd9c97cbe87a406abeb758

See more details on using hashes here.

Supported by

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