https://github.com/mtslzr/pokeapi-go
Wrapper for PokeAPI; written in Go.
https://github.com/mtslzr/pokeapi-go
api-client circleci go golang pokeapi
Last synced: about 1 year ago
JSON representation
Wrapper for PokeAPI; written in Go.
- Host: GitHub
- URL: https://github.com/mtslzr/pokeapi-go
- Owner: mtslzr
- License: mit
- Created: 2019-06-22T03:37:36.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-06-23T16:34:49.000Z (about 2 years ago)
- Last Synced: 2025-03-25T01:33:06.505Z (over 1 year ago)
- Topics: api-client, circleci, go, golang, pokeapi
- Language: Go
- Homepage: https://pokeapi.co
- Size: 92.8 KB
- Stars: 88
- Watchers: 1
- Forks: 26
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# pokeapi-go


[](https://codecov.io/gh/mtslzr/pokeapi-go)
[](https://goreportcard.com/report/github.com/mtslzr/pokeapi-go)
[](http://godoc.org/github.com/mtslzr/pokeapi-go)
[](https://raw.githubusercontent.com/mtslzr/pokeapi-go/master/LICENSE)
Wrapper for [Poke API](https://pokeapi.co), written in Go. *Supports PokeAPI v2.*
- [pokeapi-go](#pokeapi-go)
- [Documentation](#Documentation)
- [Getting Started](#Getting-Started)
- [Endpoints](#Endpoints)
- [Berries](#Berries)
- [Contests](#Contests)
- [Encounters](#Encounters)
- [Evolution](#Evolution)
- [Games](#Games)
- [Items](#Items)
- [Locations](#Locations)
- [Machines](#Machines)
- [Moves](#Moves)
- [Pokemon](#Pokemon)
- [Utility](#Utility)
- [Additional Options](#Additional-Options)
- [Resource List Parameters](#Resource-List-Parameters)
- [Resource List Filters](#Resource-List-Filters)
- [Caching](#Caching)
## Documentation
Full API documentation can be found at [Poke API](https://pokeapi.co/docs/v2.html).
## Getting Started
```bash
go get github.com/mtslzr/pokeapi-go
```
```go
import "github.com/mtslzr/pokeapi-go"
```
## Endpoints
### Berries
Berries
#### Get Berries
```go
b := pokeapi.Resource("berry")
```
#### Get Berry
*Must pass an ID (e.g. "1") or name (e.g. "cheri").*
```go
b := pokeapi.Berry("cheri")
```
Berry Firmness
#### Get Berry Firmnesses
```go
b := pokeapi.Resource("berry-firmness")
```
#### Get Berry Firmness
*Must pass an ID (e.g. "1") or name (e.g. "very-soft").*
```go
b := pokeapi.BerryFirmness("very-soft")
```
Berry Flavors
#### Get Berry Flavors
```go
b := pokeapi.Resource("berry-flavor")
```
#### Get Berry Flavor
*Must pass an ID (e.g. "1") or name (e.g. "spicy").*
```go
b := pokeapi.BerryFlavor("spicy")
```
### Contests
Contest Types
#### Get Contest Types
```go
c := pokeapi.Resource("berry")
```
#### Get Contest Type
*Must pass an ID (e.g. "1") or name (e.g. "cool").*
```go
c := pokeapi.ContestType("cool")
```
Contest Effects
#### Get Contest Effects
```go
c := pokeapi.Resource("contest-effect")
```
#### Get Contest Effect
*Must pass an ID (e.g. "1").*
```go
c := pokeapi.ContestEffect("1")
```
Super Contest Effects
#### Get Super Contest Effects
```go
c := pokeapi.Resource("super-contest-effect")
```
#### Get Super Contest Effect
*Must pass an ID (e.g. "1").*
```go
c := pokeapi.SuperContestEffect("1")
```
### Encounters
Encounter Methods
#### Get Encounter Methods
```go
e := pokeapi.Resource("encounter-method")
```
#### Get Encounter Method
*Must pass an ID (e.g. "1") or name (e.g. "walk").*
```go
e := pokeapi.EncounterMethod("walk")
```
Encounter Conditions
#### Get Encounter Conditions
```go
e := pokeapi.Resource("encounter-condition")
```
#### Get Encounter Condition
*Must pass an ID (e.g. "1") or name (e.g. "swarm").*
```go
e := pokeapi.EncounterCondition("swarm")
```
Encounter Condition Values
#### Get Encounter Condition Values
```go
e := pokeapi.Resource("encounter-condition-value")
```
#### Get Encounter Condition Value
*Must pass an ID (e.g. "1") or name (e.g. "swarm-yes").*
```go
e := pokeapi.EncounterConditionValue("swarm-yes")
```
### Evolution
Evolution Chains
#### Get Evolution Chains
```go
e := pokeapi.Resource("evolution-chain")
```
#### Get Evolution Chain
*Must pass an ID (e.g. "1").*
```go
e := pokeapi.EvolutionChain("1")
```
Evolution Triggers
#### Get Evolution Triggers
```go
e := pokeapi.Resource("evolution-trigger")
```
#### Get Evolution Trigger
*Must pass an ID (e.g. "1") or name (e.g. "level-up").*
```go
e := pokeapi.EvolutionTrigger("level-up")
```
### Games
Generations
#### Get Generations
```go
g := pokeapi.Resource("generation")
```
#### Get Generation
*Must pass an ID (e.g. "1") or name (e.g. "generation-i").*
```go
g := pokeapi.Generation("generation-i")
```
Pokedex
#### Get All Pokedex
```go
g := pokeapi.Resource("pokedex")
```
#### Get Single Pokedex
*Must pass an ID (e.g. "1") or name (e.g. "national").*
```go
g := pokeapi.Pokedex("national")
```
Versions
#### Get Versions
```go
g := pokeapi.Resource("version")
```
#### Get Version
*Must pass an ID (e.g. "1") or name (e.g. "red").*
```go
g := pokeapi.Version("red")
```
Version Groups
#### Get Version Groups
```go
g := pokeapi.Resource("version-group")
```
#### Get Version Group
*Must pass an ID (e.g. "1") or name (e.g. "red-blue").*
```go
g := pokeapi.VersionGroup("red-blue")
```
### Items
Items
#### Get Items
```go
i := pokeapi.Resource("item")
```
#### Get Item
*Must pass an ID (e.g. "1") or name (e.g. "master-ball").*
```go
i := pokeapi.Item("master-ball")
```
Item Attributes
#### Get Item Attributes
```go
i := pokeapi.Resource("item-attribute")
```
#### Get Item Attribute
*Must pass an ID (e.g. "1") or name (e.g. "countable").*
```go
i := pokeapi.ItemAttribute("countable")
```
Item Categories
#### Get Item Ctegories
```go
i := pokeapi.Resource("item-category")
```
#### Get Item Category
*Must pass an ID (e.g. "1") or name (e.g. "stat-boosts").*
```go
i := pokeapi.ItemCategory("stat-boosts")
```
Item Fling Effects
#### Get Item Fling Effects
```go
i := pokeapi.Resource("item-fling-effect")
```
#### Get Item Fling Effect
*Must pass an ID (e.g. "1") or name (e.g. "badly-poison").*
```go
i := pokeapi.ItemFlingEffect("badly-poison")
```
Item Pockets
#### Get Item Pockets
```go
i := pokeapi.Resource("item-pocket")
```
#### Get Item Pocket
*Must pass an ID (e.g. "1") or name (e.g. "misc").*
```go
i := pokeapi.ItemPocket("misc")
```
### Locations
Locations
#### Get Locations
```go
l := pokeapi.Resource("location")
```
#### Get Location
*Must pass an ID (e.g. "1") or name (e.g. "canalave-city").*
```go
l := pokeapi.Location("canalave-city")
```
Location Areas
#### Get Location Areas
```go
l := pokeapi.Resource("location-area")
```
#### Get Location Area
*Must pass an ID (e.g. "1") or name (e.g. "canalave-city-area").*
```go
l := pokeapi.LocationArea("canalave-city-area")
```
Pal Park Areas
#### Get Pal Park Areas
```go
l := pokeapi.Resource("pal-park-area")
```
#### Get Pal Park Area
*Must pass an ID (e.g. "1") or name (e.g. "forest").*
```go
l := pokeapi.PalParkArea("forest")
```
Regions
#### Get Regions
```go
l := pokeapi.Resource("region")
```
#### Get Region
*Must pass an ID (e.g. "1") or name (e.g. "kanto").*
```go
l := pokeapi.Region("kanto")
```
### Machines
Machines
#### Get Machines
```go
m := pokeapi.Resource("machine")
```
#### Get Machine
*Must pass an ID (e.g. "1").*
```go
m := pokeapi.Machine("1")
```
### Moves
Moves
#### Get Moves
```go
m := pokeapi.Resource("move")
```
#### Get Move
*Must pass an ID (e.g. "1") or name (e.g. "pound").*
```go
m := pokeapi.Move("pound")
```
Move Ailments
#### Get Move Ailments
```go
m := pokeapi.Resource("move-ailment")
```
#### Get Move Ailment
*Must pass an ID (e.g. "1") or name (e.g. "paralysis").*
```go
m := pokeapi.MoveAilment("paralysis")
```
Move Battle Styles
#### Get Move Battle Styles
```go
m := pokeapi.Resource("move-battle-style")
```
#### Get Move Battle Style
*Must pass an ID (e.g. "1") or name (e.g. "attack").*
```go
m := pokeapi.MoveBattleStyle("attack")
```
Move Categories
#### Get Move Categories
```go
m := pokeapi.Resource("move-catgory")
```
#### Get Move Category
*Must pass an ID (e.g. "1") or name (e.g. "ailment").*
```go
m := pokeapi.MoveCategory("ailment")
```
Move Damage Classes
#### Get Move Damage Classes
```go
m := pokeapi.Resource("move-damage-class")
```
#### Get Move Damage Class
*Must pass an ID (e.g. "1") or name (e.g. "status").*
```go
m := pokeapi.MoveDamageClass("status")
```
Move Learn Methods
#### Get Move Learn Methods
```go
m := pokeapi.Resource("move-learn-method")
```
#### Get Move Learn Method
*Must pass an ID (e.g. "1") or name (e.g. "level-up").*
```go
m := pokeapi.MoveLearnMethod("level-up")
```
Move Targets
#### Get Move Targets
```go
m := pokeapi.Resource("move-target")
```
#### Get Move Target
*Must pass an ID (e.g. "1") or name (e.g. "specific-move").*
```go
m := pokeapi.MoveTarget("specific-move")
```
### Pokemon
Abilities
#### Get Abilities
```go
p := pokeapi.Resource("ability")
```
#### Get Ability
*Must pass an ID (e.g. "1") or name (e.g. "stench").*
```go
p := pokeapi.Ability("stench")
```
Characteristics
#### Get Characteristics
```go
p := pokeapi.Resource("characteristic")
```
#### Get Characteristic
*Must pass an ID (e.g. "1").*
```go
p := pokeapi.Characteristic("1")
```
Egg Groups
#### Get Egg Groups
```go
p := pokeapi.Resource("egg-group")
```
#### Get Egg Group
*Must pass an ID (e.g. "1") or name (e.g. "monster").*
```go
p := pokeapi.EggGroup("monster")
```
Genders
#### Get Genders
```go
p := pokeapi.Resource("gender")
```
#### Get Gender
*Must pass an ID (e.g. "1") or name (e.g. "female").*
```go
p := pokeapi.Gender("female")
```
Growth Rates
#### Get Growth Rates
```go
p := pokeapi.Resource("growth-rate")
```
#### Get Growth Rate
*Must pass an ID (e.g. "1") or name (e.g. "slow").*
```go
p := pokeapi.GrowthRate("slow")
```
Natures
#### Get Natures
```go
p := pokeapi.Resource("nature")
```
#### Get Nature
*Must pass an ID (e.g. "1") or name (e.g. "hardy").*
```go
p := pokeapi.Nature("hardy")
```
Pokeathlon Stats
#### Get Pokeathlon Stats
```go
p := pokeapi.Resource("pokeathlon-stat")
```
#### Get Pokeathlon Stat
*Must pass an ID (e.g. "1") or name (e.g. "speed").*
```go
p := pokeapi.PokeathlonStat("speed")
```
Pokemon
#### Get All Pokemon
```go
l := pokeapi.Resource("pokemon")
```
#### Get Single Pokemon
*Must pass an ID (e.g. "1") or name (e.g. "bulbasaur").*
```go
l := pokeapi.Pokemon("bulabsaur")
```
Pokemon Colors
#### Get Pokemon Colors
```go
p := pokeapi.Resource("pokemon-color")
```
#### Get Pokemon Color
*Must pass an ID (e.g. "1") or name (e.g. "black").*
```go
p := pokeapi.PokemonColor("black")
```
Pokemon Forms
#### Get Pokemon Forms
```go
p := pokeapi.Resource("pokemon-form")
```
#### Get Pokemon Form
*Must pass an ID (e.g. "1") or name (e.g. "bulbasaur").*
```go
p := pokeapi.PokemonForm("bulabsaur")
```
Pokemon Habitats
#### Get Pokemon Habitats
```go
p := pokeapi.Resource("pokemon-habitat")
```
#### Get Pokemon Habitat
*Must pass an ID (e.g. "1") or name (e.g. "cave").*
```go
p := pokeapi.PokemonHabitat("cave")
```
Pokemon Shapes
#### Get Pokemon Shapes
```go
p := pokeapi.Resource("pokemon-shape")
```
#### Get Pokemon Shape
*Must pass an ID (e.g. "1") or name (e.g. "ball").*
```go
p := pokeapi.PokemonShape("ball")
```
Pokemon Species
#### Get All Pokemon Species
```go
p := pokeapi.Resource("pokemon-species")
```
#### Get Single Pokemon Species
*Must pass an ID (e.g. "1") or name (e.g. "bulbasaur").*
```go
p := pokeapi.PokemonSpecies("bulabsaur")
```
Stats
#### Get Stats
```go
p := pokeapi.Resource("stat")
```
#### Get Stat
*Must pass an ID (e.g. "1") or name (e.g. "hp").*
```go
p := pokeapi.Stat("hp")
```
Types
#### Get Types
```go
p := pokeapi.Resource("type")
```
#### Get Type
*Must pass an ID (e.g. "1") or name (e.g. "normal").*
```go
p := pokeapi.Type("normal")
```
### Utility
Languages
#### Get Languages
```go
u := pokeapi.Resource("language")
```
#### Get Language
*Must pass an ID (e.g. "1") or name (e.g. "en").*
```go
u := pokeapi.Language("en")
```
## Additional Options
### Resource List Parameters
When calling `pokeapi.Resource()` for any resource list, you can optionally pass up to two integers. The first will be an offset (defaults to zero), and the second will be the limit (defaults two twenty).
Default
```go
r := pokeapi.Resource("pokemon")
fmt.Println(len(r.Results)) // 20
fmt.Println(r.Results[0].Name) // "bulbasaur"
```
Offset
```go
r := pokeapi.Resource("pokemon", 3)
fmt.Println(len(r.Results)) // 20
fmt.Println(r.Results[0].Name) // "charmander"
```
Offset and Limit
```go
r := pokeapi.Resource("pokemon", 6, 10)
fmt.Println(len(r.Results)) // 10
fmt.Println(r.Results[0].Name) // "squirtle"
```
### Resource List Filters
As an alternative to `pokeapi.Resource()`, you can use Search to filter resource lists. Pass the endpoint, followed by the search term. Or pass a string starting with `^` to search for items starting with the search team.
*result.Count is updated after the search with the new total (to get the full count, use `pokeapi.Resource()`.*
Search
```go
s := pokeapi.Search("pokemon", "saur")
fmt.Println(len(s.Results)) // 4
fmt.Println(s.Results[3].Name) // venusaur-mega
```
Starts With
```go
s := pokeapi.Search("pokemon", "^a")
fmt.Println(len(s.Results)) // 44
fmt.Println(s.Results[0].Name) // arbok
```
```go
s := pokeapi.Search("pokemon", "^bulb")
fmt.Println(len(s.Results)) // 1
fmt.Println(s.Results[0].Name) // bulbasaur
```
### Caching
Calls are automatically cached to cut down on API traffic to PokeAPI, with subsequent calls returning local data.
#### Clearing Cache
```go
// Clear all existing cache entries.
pokeapi.ClearCache()
```
#### Custom Expiration
Custom cache expiration remains for all calls until changed or unset.
```go
// Set cache expiration to twenty minutes.
pokeapi.CacheSettings.CustomExpire = 20
// Turn custom expiration back off.
pokeapi.CacheSettings.CustomExpire = 0
```
#### Disable Cache
_Please be considerate of PokeAPI and be sure to always operate within this requested limits._
As with custom expiration, this setting remains for all calls until changed or unset.
```go
// Disable checking for cached data
pokeapi.CacheSettings.UseCache = false
// Re-enable checking for cached data
pokeapi.CacheSettings.UseCache = true
```