/MapDownloader.Cli

A Command Line Tool to download maps off a FastDL url

Primary LanguageC#MIT LicenseMIT

Map Downloader Command Line Tool

MapDownloader NuGet Version

Map Downloader CLI is a .NET Core 3.1/.NET 5.0 command line tool that automates the process of downloading maps from a server's map list.
This tool is inspired by Vauff's WinForms version.

Why a tool? Idk, I just wanted to make one.

Table of contents

  1. Prerequisites
  2. Installing
  3. Uninstalling
  4. Available Options
  5. Example Usage
  6. FAQ
  7. Screenshots

Prerequisites

Before installing the tool, you need to have either .NET Core 3.1 or .NET 5.0 installed on your machine. To check whether you have .NET installed, run the following in a command prompt:

> dotnet --info

If you don't have them installed, click the links below to install either:

Installing

The fastest and easiest way to get the tool is to install it via NuGet Package

> dotnet tool install --global MapDownloader

If you want to update the tool, run the following command:

> dotnet tool update --global MapDownloader

Uninstalling

The easiest way to uninstall the tool is by running the following command:

> dotnet tool uninstall --global MapDownloader

Options

There are a few basic options that are packed in the tool, the full list is as shown

Option Description
-i, --input [Path to json file] (REQUIRED) The option to specify the json file
-o, --output [Path to output folder] (OPTIONAL) An optional argument to override the output folder
--csv [Path to csv file] (OPTIONAL) An optional argument to override the csv file. Must be hosted locally
--fastdl [Link to fastDL] (OPTIONAL) An optional argument to override the fastdl link
-a, --async, --multi-thread (OPTIONAL) Downloads and extract the file concurrently. Recommended.
--version Show version information
-?, -h, --help Show help and usage information

Examples

In order for the tool to work, you need to have a valid json file with the following information:

  • MapList > A hosted location for the csv file
  • FastDL > URL containing the fastdl link
  • OutputDirectory > Path to where your maps folder are located (This will be the location where it scans for your currently downloaded maps)

Each of the following can be overidden by the options above.
Alternatively, you can view an example here: gflze.json

Once you have a valid json file, open command prompt and use the following command:

> mapdownloader -i <Path to json file>

OR if the json file is in the current directory

> mapdownloader -i gflze.json

If you wish to override any of the settings in the json, just include it in the command afterwards:

> mapdownloader -i gflze.json --fastdl "https://fastdl.thisisalink.com/csgo/maps"

FAQ

Q: Does this work on all platforms?
A: Please refer to the table below:

Platform Tested and working
Windows 10 ✔️
Linux ✔️
MacOS Untested

Q: Can I add my server into the samples folder?
A: Sure. Just make a pull request and include the json.

Q: I have an error, what do I do?
A: Take a screenshot of the error message, open an issue in github and include the steps to reproduce it. You can also contact me on discord @ Snowy#9716

Q: Does it support maps bigger than 150mb?
A: Currently, no. Perhaps in the future if it's a regular occurance.

Q: I want improvements!
A: Sure, open a pull request and describe the feature you want added.

Q: What if I cancelled while downloading/extracting midway?
A: Unfortunately, the file might get corrupted if you interrupted the download/extract process. Find the file in the output directory and delete it.

Screenshots

Synchronous download: Synchronous Download Asynchronous download: Asynchronous Download Info screen: Info Ubuntu download: Ubuntu