mistralys/cyberpunk-mod-db-php

PHP classes to work with the Cyberpunk 2077 DB.

1.6.2 2024-11-28 15:55 UTC

This package is auto-updated.

Last update: 2024-12-29 14:49:45 UTC


README

PHP library used to access the data provided by the Cyberpunk 2077 Clothing Mod DB.

Features

  • Classes used to access all data in the mod DB
  • Get mod information, including screenshots
  • Filter mods by search terms and tags
  • Filter mod items by search terms and tags
  • Access all known tags used in the mod DB
  • Access all atelier mods used by the clothing mods
  • Minimum configuration required

Requirements

  • PHP 8.2 or higher
  • Composer
  • Webserver with PHP support

Installation

  1. Require the package using Composer
  2. Ensure that the vendor directory is accessible via the webserver.
composer require mistralys/cyberpunk-mod-db-php

NOTE: The database is included as a dependency, so there is no need to require it separately, unless you want a specific version to be installed.

Accessing mods

The mod collection class

The mod collection class ModCollection is the main entry point to the mod database. It provides methods to access all mods, as well as the filtering capabilities.

use CPMDB\Mods\Collection\ModCollection;

// Create a collection instance
$collection = ModCollection::create(
    __DIR__.'/vendor', // Absolute path to the composer vendor directory
    __DIR__.'/cache', // Path to a writable directory to store cache files
    'http://127.0.0.1/your-app/vendor' // Absolute URL to the composer vendor directory
);

// Get all mods
$mods = $collection->getAll();

// Get only clothing mods
$clothing = $collection->categoryClothing()->getAll();

// Get a mod by its UUID (unique identifier, category ID + mod ID)
$catsuit = $collection->getByID('clothing.catsuit');

// Get the screenshot URL for a mod
$images = $catsuit->getScreenshotCollection();
if($images->hasScreenshots()) {
    $default = $images->getDefault();
    ?>
    <img src"<?php php echo $default->getURL() ?>" alt="<?php echo $default->getTitle() ?>">
    <?php
}

Searching for mods

Use the mod filter to search for specific mods by search terms and/or tags.

use CPMDB\Mods\Collection\ModCollection;
use \CPMDB\Mods\Tags\Types\Outfit;

// Create a collection instance
$collection = ModCollection::create(
    __DIR__.'/vendor', // Absolute path to the composer vendor directory
    __DIR__.'/cache', // Path to a writable directory to store cache files
    'http://127.0.0.1/your-app/vendor' // Absolute URL to the composer vendor directory
);

// Search for "catsuit" and only get mods with the "Outfit" tag
$mods = $collection->createFilter()
    ->selectSearchTerm('catsuit')
    ->selectTag(Outfit::TAG_NAME)
    ->getMods();

Accessing mod items

Each mod can contain multiple items, such as clothing items. While each mod has a collection of items, there is also a global item collection that contains all items from all mods.

The item collection class

use CPMDB\Mods\Collection\ModCollection;

// Create a collection instance
$collection = ModCollection::create(
    __DIR__.'/vendor', // Absolute path to the composer vendor directory
    __DIR__.'/cache', // Path to a writable directory to store cache files
    'http://127.0.0.1/your-app/vendor' // Absolute URL to the composer vendor directory
);

// Get the item collection
$itemsCollection = $collection->getItemCollection();

// Get an item by its CET code 
$dress = $itemsCollection->getByID('nd_michiko_dress_black');

// Get the CET command to add the item in-game
$dress->getCETCommand();

Searching for items

Use the item filter to search for specific items by search terms and/or tags.

use CPMDB\Mods\Collection\ModCollection;
use CPMDB\Mods\Tags\Types\Jewelry;

// Create a collection instance
$collection = ModCollection::create(
    __DIR__.'/vendor', // Absolute path to the composer vendor directory
    __DIR__.'/cache', // Path to a writable directory to store cache files
    'http://127.0.0.1/your-app/vendor' // Absolute URL to the composer vendor directory
);

// Search for the Jewelry tag to get all jewelry mod items
$mods = $collection->createItemFilter()
    ->selectTag(Jewelry::TAG_NAME)
    ->getItems();

// Use the item collection for helper methods like getting
// items by their CET code
$mods = $collection->createItemFilter()
    ->selectTag(Jewelry::TAG_NAME)
    ->getItemsAsCollection()
    ->getByItemCode('earrings_08_basic_04_kwek');

// Combine as many filter criteria as needed
$mods = $collection->createItemFilter()
    ->selectSearchTerm('earrings')
    ->selectTag(Jewelry::TAG_NAME)
    ->selectTag(Physics::TAG_NAME)
    ->getItemsAsCollection();

NOTE: Items inherit their tags from the mod they belong to. Since a mod can have items that belong to different tags, searching for a specific tag may return unrelated items.

Accessing tags

Tags are used to categorize mods, using simple strings defined in the mod files (e.g. CET for the Cyber Engine Tweaks mod). All known tags used in the mod DB are included in the package.

Available meta data

Each tag has the following meta-data:

  • Name: The tag's name, e.g. CET.
  • Full name: The tag's full name, e.g. Cyber Engine Tweaks.
  • Description: A short description of the tag.
  • Category: The tag's category, e.g. Modder Resource.
  • Related tags: Tags that are related to the current tag, if any.
  • Links: Links to external resources related to the tag, if any.

Tag name constants

Tags can be referenced in code using the matching tag classes, which all have a constant with the tag's name. This makes it easier to avoid typos.

$cetTag = \CPMDB\Mods\Tags\Types\CyberEngineTweaks::TAG_NAME;
$clothingTag = \CPMDB\Mods\Tags\Types\Clothing::TAG_NAME;

An alternative way is to use the TagNames class, which has constants for all known tags. This can be easier to use in some cases.

use CPMDB\Mods\Tags\TagNames;

$cetTag = TagNames::TAG_CET;
$clothingTag = TagNames::TAG_CLOTHING;

The tag collection

All known tags are available via the TagCollection class, which has methods to access them.

use CPMDB\Mods\Tags\TagCollection;
use CPMDB\Mods\Tags\Types\CyberEngineTweaks;

$collection = TagCollection::getInstance();

// Get all tags
$all = $collection->getAll();

// Get a specific tag
$cet = $collection->getByID(CyberEngineTweaks::TAG_NAME);

// Additional tag meta data
echo 'Description: '.$cet->getDescription();
echo 'Tag category: '.$cet->getCategory();

Accessíng atelier mods

Background: To make clothing items added by mods available to purchase in-game, the Virtual Atelier mod is used. Modders can create atelier mods that contain the clothing items they have created.

For the clothing mods, all related atelier mods are included in the AtelierCollection class to access their metadata. Individual mods provide their own atelier instance via the getAtelier() method, but the atelier collection offers top-level access to all of them.

Available metadata

Each atelier has the following meta-data:

  • ID: The atelier's unique identifier, e.g. nc-fashion.
  • Name: The atelier's name, e.g. NC Fashion.
  • URL: A link to the atelier mod's home page.
  • Authors: A list of the mod's author names.
  • Mods: All database-known mods that belong to the atelier.

The atelier collection

Getting the atelier collection is done via the mod collection:

use CPMDB\Mods\Ateliers\AtelierCollection;
use CPMDB\Mods\Collection\ModCollection;
use \CPMDB\Mods\Ateliers\Atelier\NcFashionAtelier;

// Create a collection instance
$collection = ModCollection::create(
    __DIR__.'/vendor', // Absolute path to the composer vendor directory
    __DIR__.'/cache', // Path to a writable directory to store cache files
    'http://127.0.0.1/your-app/vendor' // Absolute URL to the composer vendor directory
);

$ateliers = $collection->createAteliers();

// Get all ateliers
$all = $ateliers->getAll();

// Get a specific atelier
$ncFashion = $ateliers->getByID(NcFashionAtelier::ATELIER_ID);

Getting a mod's atelier


Caching

By default, the collection will cache the mod data in the specified cache directory. This is done for performance reasons, as the mod data is read from my individual files in the filesystem.

The cache is created and updated automatically following the version of the mod database.

Turning off caching

The caching can be turned off if needed:

use CPMDB\Mods\Collection\DataWriter\CacheDataWriter;

CacheDataWriter::setCacheEnabled(false);

Performance tests

To check the performance of the caching on your system, you can run the performance tests:

php tests/performance/performance-test.php