An open API service indexing awesome lists of open source software.

https://github.com/frodsan/frog

Dota 2 API for Hero, Ability and Item data
https://github.com/frodsan/frog

cloudfunctions dota2 javascript nodejs

Last synced: 9 months ago
JSON representation

Dota 2 API for Hero, Ability and Item data

Awesome Lists containing this project

README

          

# frog

[Google Cloud Function](https://cloud.google.com/functions/) that serves Dota 2 ability, hero and item data in a JSON format. It gets the data from the Steam source files through: [dotabuff/d2vpkr](https://github.com/dotabuff/d2vpkr).

## Requirements

- Node.js 8+

## Usage

To try it in development, fire up the server with:

```
$ npm run server # or npm run s
```

To start getting data, make a request to:

```
http://localhost:1437/GetSource
```

| Query param | Required | Description
| ---- | -------- | -----------
| type | ✓ | Can be one of: `abilities`, `heroes`, or `items`.
| pretty | | Prettify JSON response.

#### Example:

```
$ curl http://localhost:1437/GetSource?type=heroes | jq -s '.[0][0]'
{
"id": 1,
"key": "npc_dota_hero_antimage",
"name": "Anti-Mage",
"roles": [
"carry",
"escape",
"nuker"
],
"complexity": 1,
"primary_attribute": "agi",
"base_str": 23,
"base_agi": 22,
"base_int": 12,
"str_gain": 1.3,
"agi_gain": 2.8,
"int_gain": 1.8,
"base_health": 200,
"base_mana": 75,
"base_health_regen": 1.75,
"base_mana_regen": 0.9,
"attack_type": "melee",
"attack_range": 150,
"attack_rate": 1.4,
"base_attack_min": 29,
"base_attack_max": 33,
"base_armor": -1,
"base_magical_resistance": 25,
"movement_speed": 310,
"movement_turn_rate": 0.5,
"abilities": [
"antimage_mana_break",
"antimage_blink",
"antimage_spell_shield",
"generic_hidden",
"generic_hidden",
"antimage_mana_void"
],
"talents": [
"special_bonus_strength_10",
"special_bonus_attack_speed_20",
"special_bonus_unique_antimage_3",
"special_bonus_agility_15",
"special_bonus_unique_antimage_5",
"special_bonus_unique_antimage",
"special_bonus_unique_antimage_4",
"special_bonus_unique_antimage_2"
]
}
```

## Deployment

Use the `gcloud` utility, like:

```
$ gcloud beta functions deploy GetSource \
--trigger-http \
--runtime nodejs8 \
--region
Deploying function (may take a while - up to 2 minutes)...
```

The function can be triggered at .

## License

Released under MIT License, check LICENSE file for details.