Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jcla1/goquizduell
Inofficial API client for the Quizduell REST API
https://github.com/jcla1/goquizduell
Last synced: about 1 month ago
JSON representation
Inofficial API client for the Quizduell REST API
- Host: GitHub
- URL: https://github.com/jcla1/goquizduell
- Owner: jcla1
- License: mit
- Created: 2014-04-21T11:22:18.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2014-05-13T17:39:51.000Z (over 10 years ago)
- Last Synced: 2024-06-20T12:37:43.713Z (7 months ago)
- Language: Go
- Size: 461 KB
- Stars: 5
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Quizduell API client
===========Inofficial API client for the Quizduell REST API written in Go.
Inspired by [https://github.com/mtschirs/quizduellapi](https://github.com/mtschirs/quizduellapi) and [easysurfer.me](http://easysurfer.me/wordpress/?p=761)For documentation, [see here](http://godoc.org/github.com/jcla1/goquizduell).
## Use cases
This API library supports all functionality that can be found in the official Quizduell app, besides posting new questions. There is also no need to have downloaded, or registered a premium account in order to use features in this client library that would otherwise be unavailable to a normal user (like setting a new avatar and playing more than 8 games simulanously).Included in the repo is a demo of the API in which an automated player logs into Quizduell and plays active games, accepts game invites and keeps a constant pool of games against random opponents. It also supports things like: adjusting the standard deviation from the correct answer (how often does the player answer correctly), excluding players on your friends list from gameplay against the automated player and a few other things.
To automate the process of starting the player, there is [a script](runner.sh) included that starts the player every few minutes with a cookie in `cookie.gob` (which you will have to create yourself). To run it, just do: `./runner.sh`
When starting the player for the first time, you'll have to provide your username, password and a name for the cookie file in environmental variables named `QD_USERNAME`, `QD_PASSWORD`, `QD_COOKIE_FILE`, respectively. After this initial run, you'll only ever have to provide the `QD_COOKIE_FILE` variable, provided the file actually still exists.
__*Warning*__: Most calls to the API do __not__ populate all fields of the returned structs. Some may still contain their respective null values. i.e. when retrieving the list of active games from a `*quizduell.Status` the list of questions for a particular game will be empty.
__*Note*__: When calling `func (c *Client) UploadRoundAnswers` you must also pass all of your previous answers to the questions, in addition to your answers of this round. If you are passing the answers to questions where your opponent choose the category, you must also pass the correct category for those questions/answers (i.e. `game.CategoryChoices[len(game.CategoryChoices)-1]`).
## License
Pubished under the [MIT License](LICENSE).Quizduell is a registered trademark of FEO Media AB, Stockholm, SE registered in Germany and other countries. This project is an independent work and is in no way affiliated with, authorized, maintained, sponsored or endorsed by FEO Media AB.