Skip to content

Latest commit

 

History

History
248 lines (210 loc) · 7.92 KB

README.md

File metadata and controls

248 lines (210 loc) · 7.92 KB

Age of Empires 2 API

Coverage Status Docker Image

Disclaimer

The Age of Empires II API was originally conceived as a pet project 6 years ago (...already, phew!). Initially I had it running on Heroku and was working just fine.

As time passed people was using it, paired with good ole' Heroku changing its ways and quotes, we were running out of the free tier hours, so unfortunately I had to shut it down.

Don't have time these days to dedicate to it and I'm not sure if it's still working as intended, so take the project with a pinch of salt! Anyways, feel free to improve it, fork it, self-host it (there's the docker image still dangling around), or do with it whatever you see fit!

Farewell, paladins!


Age of Empires II API created with:

  • Flask + FlaskRESTful
  • SQLite (DB)
  • SQLAlchemy (ORM)
  • Flasgger (Swagger Docs)
  • Pytest + Coverage (Tests)

Which allows you to retrieve information about the civilizations, technologies, units and structures of AOE2. To run you can use Docker, for example:

docker build -t aoe2api:v1 .
docker run --name aoe2api -p 8080:80 -d aoe2api:v1 

or pull the image from DockerHub:

docker pull aalises/aoe2api:latest

The routes are:

  • Main API route: localhost:8080/api/v1
  • Docs Route: localhost:8080/docs

To test using pytest, just run

python -m pytest

For testing the coverage using coverage run:

coverage run -m pytest

Models


Civilization


Model describing a civilization in AOE2. Parameters:

  • _id: Integer denoting the unique ID for that civilization
  • name: Name of the civilization (e.g Britons)
  • expansion: Expansion the civilization was introduced
  • army_type: Predominant army type of the civilization (e.g Archers, or Infantry)
  • unique_unit: Unique unit of the civilization
  • unique_tech: Unique Technology of the Civilization
  • team_bonus: Bonuses for the Team the civilization belongs to
  • civilization_bonus: Bonuses of the civilization

Technology


Model describing a Technology in AOE2. Parameters:

  • _id: Integer denoting the unique ID for that technology
  • name: Name of the technology
  • expansion: Expansion the technology was introduced
  • age: Age in which the technology can be developed
  • develops_in: structure in which the technology is developed
  • cost: Cost of the technology (JSON object)
  • build_time: Build time in seconds
  • applies_to: Units or civilizations the technology applies to
  • description: Description of the technology

Unit


Model describing a Unit in AOE2. Parameters:

  • _id: Integer denoting the unique ID for that unit
  • name: Name of the unit
  • description: Description of the unit
  • expansion: Expansion the unit was introduced
  • age: Age in which the unit can be produced
  • created_in: Structure the unit is created in
  • cost: Cost of the unit (JSON object)
  • build_time: Build time in seconds
  • reload_time: Reload time (Float)
  • attack_delay: Attack delay when you give the order to attack (Float)
  • movement_rate: Movement Rate
  • line_of_sight: Line of sight of the unit
  • hit_points: Hit points (health) of the unit
  • range: Range of the unit. There can be a minimum and maximum range in the format (min-max)
  • attack: Attack of the unit
  • armor: Armor of the unit divided into melee/pierce
  • attack_bonus: Attack bonuses of the unit
  • armor_bonus: Armor bonuses of the unit
  • search_radius: Search Radius of the unit
  • accuracy: Attack accuracy (percentage) of the unit
  • blast_radius: Attack blast radius

Structure


Model describing a Structure in AOE2. Parameters:

  • _id: Integer denoting the unique ID for that structure
  • name: Name of the structure
  • expansion: Expansion the structure was introduced
  • age: Age in which the structure can be created
  • cost: Cost of the structure (JSON object)
  • build_time: Build time in seconds
  • hit_points: Hit points (health) of the structure
  • line_of_sight: Line of sight of the structure
  • armor: Armor of the structure divided into melee/pierce
  • range: Range of the structure. There can be a minimum and maximum range in the format (min-max)
  • reload_time: Reload time in seconds between projectiles
  • attack: Attack of the structure
  • special: Some other properties of the structure / garrison

Resources

The API allows to retrieve information about civilizations, structures, units and technologies for the AOE2 Age of Kings and The Conquerors. The base route returns an object with the different resources you can access

  • GET /civilizations

Gets all civilizations in a JSON list

  • GET /civilization/<id: string>

Gets a given civilization with a string representing an ID (integer e.g 1, 34), or the name (britons,teutons). The name instead of spaces can be parsed with underscores or hyphens.

Example call /api/v1/civilization/bizantines

{
  "id": 3, 
  "name": "Bizantines", 
  "expansion": "Age of Kings", 
  "army_type": "Defensive", 
  "unique_unit": [
    "http://localhost/unit/cataphract"
  ], 
  "unique_tech": [
    "http://localhost/technology/logistica"
  ], 
  "team_bonus": "Monks +50% heal speed", 
  "civilization_bonus": [
    "Buildings (except gates) have +10% HP in Dark Age / +20% HP in Feudal Age  / +30% in Castle Age / +40% in Imperial Age", 
    "Spearman skirmisher and camel lines cost 25% less", 
    "Fire Ships attack 20% faster", 
    "Imperial Age costs -33%", 
    "Town Watch is free"
  ]
}
  • GET /units

Gets all units in a JSON list

  • GET /unit/<id: string>

Gets a given unit with a string representing an ID (integer e.g 1, 34), or the name longbowman, archer). The name instead of spaces can be parsed with underscores or hyphens (unit/teutonic_knight or unit/turtle-ship, for example)

Example call /api/v1/unit/berserk

{
  "id": 69, 
  "name": "Berserk", 
  "description": "Viking unique unit. Infantry that slowly heals itself", 
  "expansion": "Age of Kings", 
  "age": "Castle", 
  "created_in": "http://localhost/structure/castle", 
  "cost": {
    "Food": 65, 
    "Gold": 25
  }, 
  "build_time": 16, 
  "reload_time": 2.0, 
  "movement_rate": 1.05, 
  "line_of_sight": 3, 
  "hit_points": 55, 
  "attack": 9, 
  "armor": "0/1", 
  "attack_bonus": [
    "+2 eagles", 
    "+2 buildings"
  ]
}
  • GET /structures

Gets all structures in a JSON list

  • GET /structure/<id: string>

Gets a given structure with a string representing an ID (integer e.g 1, 34), or the name (mill, market). The name instead of spaces can be parsed with underscores or hyphens (structure/siege_workshop, for example)

Example call /api/v1/structure/29

 {
    "id": 29, 
    "name": "Mill", 
    "expansion": "Age of Kings", 
    "age": "Castle", 
    "cost": {
      "Wood": 100
    }, 
    "build_time": 35, 
    "hit_points": 1000, 
    "line_of_sight": 5, 
    "armor": "2/9", 
    "special": [
      "Max 40 farms queued"
    ]
  }
  • GET /technologies

Gets all technologies in a JSON list

  • GET /technology/<id: string>

Gets a given technology with a string representing an ID (integer e.g 1, 34), or the name (masonry, architecture). The name instead of spaces can be parsed with underscores or hyphens (technology/garland_wars, for example)

Example call /api/v1/technology/gold_mining

{
  "id": 58, 
  "name": "Gold Mining", 
  "expansion": "Age of Kings", 
  "age": "Feudal", 
  "develops_in": "http://localhost/structure/mining_camp", 
  "cost": {
    "Food": 100, 
    "Wood": 75
  }, 
  "build_time": 30, 
  "applies_to": [
    "Gold Miners"
  ], 
  "description": "Work rate * 1.15 (15% faster)"
}