Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/steamre/depotdownloader
Steam depot downloader utilizing the SteamKit2 library.
https://github.com/steamre/depotdownloader
c-sharp steam steam-games
Last synced: 6 days ago
JSON representation
Steam depot downloader utilizing the SteamKit2 library.
- Host: GitHub
- URL: https://github.com/steamre/depotdownloader
- Owner: SteamRE
- License: gpl-2.0
- Created: 2013-08-02T20:22:03.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2025-01-04T11:03:55.000Z (18 days ago)
- Last Synced: 2025-01-09T02:26:34.767Z (13 days ago)
- Topics: c-sharp, steam, steam-games
- Language: C#
- Homepage:
- Size: 1.21 MB
- Stars: 2,039
- Watchers: 38
- Forks: 271
- Open Issues: 33
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
DepotDownloader
===============Steam depot downloader utilizing the SteamKit2 library. Supports .NET 8.0
This program must be run from a console, it has no GUI.
## Installation
### Directly from GitHub
Download a binary from [the releases page](https://github.com/SteamRE/DepotDownloader/releases/latest).
### via Windows Package Manager CLI (aka winget)
On Windows, [winget](https://github.com/microsoft/winget-cli) users can download and install
the latest Terminal release by installing the `SteamRE.DepotDownloader`
package:```powershell
winget install --exact --id SteamRE.DepotDownloader
```### via Homebrew
On macOS, [Homebrew](https://brew.sh) users can download and install that latest release by running the following commands:
```shell
brew tap steamre/tools
brew install depotdownloader
```## Usage
### Downloading one or all depots for an app
```powershell
./DepotDownloader -app [-depot [-manifest ]]
[-username [-password ]] [other options]
```For example: `./DepotDownloader -app 730 -depot 731 -manifest 7617088375292372759`
By default it will use anonymous account ([view which apps are available on it here](https://steamdb.info/sub/17906/)).
To use your account, specify the `-username ` parameter. Password will be asked interactively if you do
not use specify the `-password` parameter.### Downloading a workshop item using pubfile id
```powershell
./DepotDownloader -app -pubfile [-username [-password ]]
```For example: `./DepotDownloader -app 730 -pubfile 1885082371`
### Downloading a workshop item using ugc id
```powershell
./DepotDownloader -app -ugc [-username [-password ]]
```For example: `./DepotDownloader -app 730 -ugc 770604181014286929`
## Parameters
Parameter | Description
----------------------- | -----------
`-app <#>` | the AppID to download.
`-depot <#>` | the DepotID to download.
`-manifest ` | manifest id of content to download (requires `-depot`, default: current for branch).
`-ugc <#>` | the UGC ID to download.
`-branch ` | download from specified branch if available (default: Public).
`-branchpassword ` | branch password if applicable.
`-all-platforms` | downloads all platform-specific depots when `-app` is used.
`-os ` | the operating system for which to download the game (windows, macos or linux, default: OS the program is currently running on)
`-osarch ` | the architecture for which to download the game (32 or 64, default: the host's architecture)
`-all-archs` | download all architecture-specific depots when `-app` is used.
`-all-languages` | download all language-specific depots when `-app` is used.
`-language ` | the language for which to download the game (default: english)
`-lowviolence` | download low violence depots when `-app` is used.
`-pubfile <#>` | the PublishedFileId to download. (Will automatically resolve to UGC id)
`-username ` | the username of the account to login to for restricted content.
`-password ` | the password of the account to login to for restricted content.
`-remember-password` | if set, remember the password for subsequent logins of this user. (Use `-username -remember-password` as login credentials)
`-dir ` | the directory in which to place downloaded files.
`-filelist ` | the name of a local file that contains a list of files to download (from the manifest). prefix file path with `regex:` if you want to match with regex. each file path should be on their own line.
`-validate` | Include checksum verification of files already downloaded
`-manifest-only` | downloads a human readable manifest for any depots that would be downloaded.
`-cellid <#>` | the overridden CellID of the content server to download from.
`-max-servers <#>` | maximum number of content servers to use. (default: 20).
`-max-downloads <#>` | maximum number of chunks to download concurrently. (default: 8).
`-loginid <#>` | a unique 32-bit integer Steam LogonID in decimal, required if running multiple instances of DepotDownloader concurrently.
`-use-lancache` | forces downloads over the local network via a Lancache instance
`-V` or `--version` | print version and runtime## Frequently Asked Questions
### Why am I prompted to enter a 2-factor code every time I run the app?
Your 2-factor code authenticates a Steam session. You need to "remember" your session with `-remember-password` which persists the login key for your Steam session.### Can I run DepotDownloader while an account is already connected to Steam?
Any connection to Steam will be closed if they share a LoginID. You can specify a different LoginID with `-loginid`.### Why doesn't my password containing special characters work? Do I have to specify the password on the command line?
If you pass the `-password` parameter with a password that contains special characters, you will need to escape the command appropriately for the shell you are using. You do not have to include the `-password` parameter on the command line as long as you include a `-username`. You will be prompted to enter your password interactively.### I am getting error 401 or no manifest code returned for old manifest ids
Try logging in with a Steam account, this may happen when using anonymous account.Steam allows developers to block downloading old manifests, in which case no manifest code is returned even when parameters appear correct.