Branch | Workflow |
---|---|
master |
|
develop |
Legit DLC Unlocker for Epic Online Services
๐ฌ Official Forum Topic
๐ Compatibility Spreadsheet
๐ Test Result Form
๐ DLC Database
Hint: Click on spoilers (
โถ
) to expand their content
What is ScreamAPI?
ScreamAPI is a DLC unlocker for the games that are legitimately owned in your Epic Games account. It attempts to fool games that uses Epic Online Services Software Development Kit (EOSSDK) into thinking that you own the desired DLCs. However, ScreamAPI does not modify the rest of the EOSSDK, hence features like multiplayer, achievements, etc. remain fully functional.
Which games are supported?
Only the games that use Epic Online Services Software Development Kit (EOS SDK) for the DLC ownership verification are supported. So if a game's installation directory does not contain any EOSSDK-WinXX-Shipping.dll files, then it's definitely not supported. Even if the game uses EOS SDK DLL, it's not guaranteed to be supported because each game might implement its own additional verification checks. Therefore, you have to first research the game's topic, to see if it supports unlocking.
I have created a Google Sheets document which contains the information about which games are compatible with ScreamAPI. If a game is compatible then it means that it is possible to unlock all or some DLCs with ScreamAPI. The spreadsheet contains 2 main sheets: the Official Sheet and the Community Sheet. The Official Sheet is hand-filled by me based on my test results and test results of other users of this forum. The Community Sheet is auto-filled by a Google Forms document, which is accessible to everybody, so feel free to submit your feedback via the form. You can submit forms anonymously and as many times as you want.
Additionally, there are several points to bear in mind when it comes to ScreamAPI and Epic Games Store:
- ScreamAPI most definitely will not work with games that use 3rd party DRM, such as games from Ubisoft, Rockstar, etc. Furthermore, ScreamAPI is also unlikely to unlock anything in Free-To-Play games since they typically store all player data on the corresponding game server and hence all the checks are server-side.
- ScreamAPI will not work with games that employ additional ownership protection or if the game is using alternative DLC verification mechanism (like Borderlands 3). However, it can unlock DLCs in Denuvo-protected games if there are no other integrity checks (like Death Stranding)
- ScreamAPI is unlikely to work with games that use Anti-Cheat, since they typically detect any DLL/EXE that has been tampered with. Sometimes it is possible to disable an anti-cheat, but that typically entails the loss of online capabilities. Search in the respective game topic for more information about how to disable anti-cheat.
- Some games include the DLC files in their base game, regardless of whether you own the DLC or not (like World War Z). This is the ideal scenario for ScreamAPI. However, some games download additional files only after a user has bought the corresponding DLC (like Civilization VI). In this case, not only you will need to install ScreamAPI, but you also have to get the additional DLC files elsewhere and put them into the game folder.
- Some games don't use any DRM at all, in which case ScreamAPI is useless. All you need to do is to get the DLC files elsewhere and put them into the game folder.
Will I get banned for it?
Epic Games or a game publisher will obviously have the right to do so, as modifying game components is a violation of Epic Games store EULA. However, if you keep this to yourself, don't publicize your usage of it and don't try messing with games that have Anti-Cheats like BattleEye, Easy Anti-Cheat, etc. you should be fine. Either way, as mentioned in the license agreement of this project, I take no responsibility for the damages you might sustain. All I can say is that I have tried and used it in several games and have not been banned or punished in any shape or form.
There are several simple steps required to install and use the ScreamAPI.
Note: This example assumes a 64-bit game. If you are interested in a 32-bit game, then repeat the same steams with 32-bit versions of the binaries instead.
- Find a file EOSSDK-Win64-Shipping.dll in your game's installation folder.
- Rename it by adding 2 characters: _o (notice that it is a letter o at the end, not a numeral 0). In the end it should be named as EOSSDK-Win64-Shipping_o.dll.
- Download the latest release zip from GitHub Releases. In case you have a hard time finding it, click on the Assets spoiler, then click on the link that looks like ScreamAPI-vX.Y.Z.zip
- Open up the downloaded zip and unpack the EOSSDK-Win64-Shipping.dll file alongside the original EOSSDK-Win64-Shipping_o.dll in the game's binary folder.
This completes the installation process. Now you can launch the game from Epic Game Store or using the shortcut created by EGS, and check if all DLCs have been unlocked. Sometimes you may have to accept a game's request to connect your EGS account in order to unlock DLCs, which some games require regardless of ScreamAPI. Keep in mind that you have to repeat this process again if the game gets updated by the Epic Games launcher.
If the game is crashing...
If the game is crashing or not opening as expected after installing ScreamAPI, then try to download and install the latest Microsoft Visual C++ Redistributable for Visual Studio 2015, 2017 and 2019
ScreamAPI does not require any manual configuration. By default, it uses most reasonable options and tries to unlock all DLCs that it can. However, there might be circumstances in which you need more custom-tailored behaviour. In this case you can use a configuration file ScreamAPI.json
that you can find in the release zip. To use it, just drop it alongside the ScreamAPI dll (EOSSDK-WinXX-Shipping.dll). It will be read upon each launch of a game. Configuration file itself is optional, but options within the file are not. In the absence of the config file, default value specified below will be used.
The description of each available option is presented below:
version
: This field is used by ScreamAPI to identify how to parse the config file. This allows ScreamAPI to parse older config files in a backward compatible manner. Therefore, this field must not be edited manually! Default:1
.logging
: Enables or disables logging into a ScreamAPI.log file. Default:false
.block_metrics
: Blocks reporting of analytics and usage metrics by the game to Epic Online Services. Metrics sent by EOS SDK itself remain unaffected. Default:false
.catalog_items
: Options in this object specify behaviour when games useEOS_Ecom_QueryOwnership
function.unlock_all
: Controls if all items should be automatically unlocked. Default:true
.override
: Specifies items idsยน that override the behaviour ofunlock_all
. Ifunlock_all
is true, then items ids in this array will be locked. Ifunlock_all
is false, then items ids in this array will be unlocked. Default:[]
(empty array).
entitlements
: Options in this object specify behaviour when games useEOS_Ecom_QueryEntitlements
function.unlock_all
: Controls if all entitlements that were requested by their IDs should be automatically unlocked. Default:true
.auto_inject
: Controls if ScreamAPI should fetch from online database a list of all available entitlement IDs, when a game doesn't provide them itself. Default:true
.inject
: Specifies which entitlement idsยน to inject when a game asks for a list of entitlements that a user owns. Default:[]
(empty array).
ยน Item/Entitlement IDs can be obtained from https://scream-db.web.app/. The log file will contain the link to the exact page which lists the game's DLCs
ScreamAPI makes use of the following open source projects:
This software is licensed under BSD Zero Clause License, terms of which are available in LICENSE.txt