GithubHelp home page GithubHelp logo

zeropingheroes / lancache-autofill Goto Github PK

View Code? Open in Web Editor NEW
131.0 12.0 24.0 348 KB

Automatically fill a Lancache with content

License: GNU General Public License v3.0

Shell 1.74% PHP 98.26%

lancache-autofill's Introduction

lancache-autofill

Automatically fill a lancache with the content of your choosing, so that subsequent downloads for the same content will be served from the lancache, improving speeds and reducing load on your internet connection.

Features

  • Download the top popular free and/or paid apps on Steam
  • Download a specific app by ID
  • Choose which platform(s) apps should be downloaded for
  • Download one (or more) users recently played apps
  • Download using multiple Steam accounts
  • Check which apps will be downloaded
  • Alter the download queue as needed
  • Start downloading process and leave to run unattended
  • Check which apps downloaded successfully
  • Check which apps failed to download, and why
  • Retry downloading of some or all failed apps
  • Clear the temporary download directory

Screenshots

Queuing apps Starting the download process

Requirements

  • A working lancache
  • Ubuntu 18.04 x64, configured to download via the lancache
  • Sufficient disk space to (temporarily) store the downloaded content
  • Dependencies detailed in Installation section

Installation

  1. git clone https://github.com/zeropingheroes/lancache-autofill.git && cd lancache-autofill
  2. ./install.sh
  3. Get a Steam API key from http://steamcommunity.com/dev/apikey and add it to the .env file

Usage

$ ./lancache-autofill

Usage:

    lancache-autofill app:initialise-database
    lancache-autofill app:initialise-downloads-directory

    lancache-autofill steam:initialise
    lancache-autofill steam:authorise-account [<account>]
    lancache-autofill steam:update-app-list
    
    lancache-autofill steam:search-apps <app name>
    lancache-autofill steam:queue-app <app id> [<app id>...] [--windows=true] [--osx] [--linux]
    lancache-autofill steam:queue-popular-apps [<top X apps>] [--free] [--windows=true] [--osx] [--linux]
    lancache-autofill steam:queue-users-recent-apps <steam id 64> [<steam id 64>...] [--windows=true] [--osx] [--linux]
    lancache-autofill steam:queue-users-recent-apps <steam-ids.txt> [--windows=true] [--osx] [--linux]
    
    lancache-autofill steam:show-queue [<status>]
    lancache-autofill steam:start-downloading
    lancache-autofill steam:dequeue [--app_id=] [--platform=] [--status=] [--message=]
    lancache-autofill steam:requeue [status=failed] [--message=]

Limitations & Known Issues

  • Steam is the only supported platform currently
  • Paid apps can only be cached with access to a Steam account that owns them
  • No support for forcing download of 32 bit apps
  • Yes, it's written in PHP. No shame.

SteamCMD Errors

Error Possible Reason
ERROR! Timed out waiting for AppInfo update. Unknown
Login Failure: Rate Limit Exceeded (84) Unknown
ERROR! Failed to install (No subscription) Game not owned by any authorised accounts
Error! State is 0x202 after update job. Not enough space to download game
Error! State is 0x402 after update job. Update required but not completed - check network
Error! State is 0x602 after update job. Update required but not completed - check network

For other error codes, you can calculate the app's state(s) by converting the 0x000 code to decimal, and finding which AppState codes sum to the given code, which will give you some clues as to what's going on.

For example:

  • 0x402 to decimal = 1026
  • 1026 is the sum of:
    • 2: StateUpdateRequired
    • 1024: StateUpdateStarted

Reference

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.