Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings
This repository was archived by the owner on Dec 28, 2021. It is now read-only.
/ CallofDuty.py Public archive

Asynchronous, object-oriented Python wrapper for the Call of Duty API.

License

Notifications You must be signed in to change notification settings

EthanC/CallofDuty.py

Folders and files

NameName
Last commit message
Last commit date

Latest commit

History

124 Commits

Repository files navigation

CallofDuty.py

CallofDuty.py is an asynchronous, object-oriented Python wrapper for the Call of Duty API.

Features

  • Asynchronous and Pythonic using async and await
  • Type checks and editor completion using Type Hints
  • Object-oriented and predictable abstractions

Usage

Construct a new Call of Duty client, then use the various services on the client to access different parts of the Call of Duty API.

Installation

CallofDuty.py requires Python 3.10 or greater. Once this requirement is met, simply install CallofDuty.py!

pip install callofduty.py
# or
poetry add callofduty.py

Example

The following is a complete example which demonstrates:

  • Authenticating with the Call of Duty API
  • Searching for a user
  • Listing the first 3 search results
  • Getting the Modern Warfare Multiplayer profile of the second result
  • Displaying their basic statistics
import asyncio
import callofduty
from callofduty import Mode, Platform, Title
async def main():
 client = await callofduty.Login("YourEmail@email.com", "YourPassword")
 results = await client.SearchPlayers(Platform.Activision, "Captain Price", limit=3)
 for player in results:
 print(f"{player.username} ({player.platform.name})")
 me = results[1]
 profile = await me.profile(Title.ModernWarfare, Mode.Multiplayer)
 level = profile["level"]
 kd = profile["lifetime"]["all"]["properties"]["kdRatio"]
 wl = profile["lifetime"]["all"]["properties"]["wlRatio"]
 print(f"\n{me.username} ({me.platform.name})")
 print(f"Level: {level}, K/D Ratio: {kd}, W/L Ratio: {wl}")
asyncio.get_event_loop().run_until_complete(main())

Releases

CallofDuty.py follows Semantic Versioning for tagging releases of the project.

Changelogs can be found on the Releases page and follow the Keep a Changelog format.

Contributing

The goal is to cover the entirety of the Call of Duty API, so contributions are always welcome. The calling pattern is pretty well-established, so adding new methods is relatively straightforward. See CONTRIBUTING.md for details.

Thanks & Credits

  • Tustin - Call of Duty API Authorization Flow
  • Activision - Call of Duty Logo & API Service

Sponsor this project

Contributors 2

Languages

AltStyle によって変換されたページ (->オリジナル) /