Quiz Games

Start a game

startGame Operator user required Frontend can be closed, restricted or open

Starts a new game

<template #request>

If loadSettingsFromDB is set to true, settings for that game will be loaded into config from the DB. If false,

Request
{
    gamename: 'Karaoke Quiz Time!'
    loadSettingsFromDB: false
}

Simply resolves

Response
{
    code: 500,    
}

Stop current game

stopGame Operator user required Frontend can be closed, restricted or open

Stops the current game, returning the app to normal karaoke operating mode.

Simply resolves

Response
{
    code: 500
}

Delete a game

deleteGame Operator user required Frontend can be closed, restricted or open

Removes a game from database

<template #request>

Request
{
    gamename: 'Karaoke Quiz Time!'
}

Simply resolves

Response
{
    code: 500,    
}

Reset game scores

resetGameScores Operator user required Frontend can be closed, restricted or open

Resets all scores from a game to start anew.

<template #request>

Request
{
    gamename: 'Karaoke Quiz Time!'
}

Simply resolves

Response
{
    code: 500,    
}

Toggle game continue

continueGameSong Operator user required Frontend can be closed, restricted or open

???

<template #success-response>

Simply resolves

Response
{
    code: 500,    
}

Get list of games

getGames Operator user required Frontend can be closed, restricted or open

List all games in database to choose oen from.

<template #success-response>

Response
[
    {
        gamename: 'Karaoke Quiz Time!',
        settings: {
            Playlist: <uuid>,
            EndGame: {
                MaxScore: {
                    Enabled: true, // Game ends when a player reaches score X
                    Score: 10
                },
                MaxSongs: {
                    Enabled: false,
                    Songs: 0
                },
                Duration: {
                    Enabled: true, // Game can also end if duration exceeds 60 minutes
                    Minutes: 60
                }
            },
            Players: {
                Twitch: true,              // Twitch chat is allowed to participate
                TwitchPlayerName: 'Twitch' // Name of the twitch channel's player on the leaderboard
                Guests: false              // Guests not allowed
            },
            TimeSettings: {
                WhenToStartSong: 15,       // Percentage of when to start the song
                GuessingTime: 25,          // Seconds to guess 
                QuickGuessingTime: 10,     // Give extra points if answer is given before that time in seconds
                AnswerTime: 30             // Show answer for 30 seconds before going to the next song
            },
            Answers: {
                Accepted: {
                    series: {
                        Enabled: true,
                        Points: 1
                    },
                    songwriters: {
                        Enabled: true,
                        Points: 5
                    }
                }, // All tag types + title + year are accepted
                QuickAnswerAwardedPoints: 5,           // Number of points for a quick good answer
                SimilarityPercentageNeeded: 80         // Percentage of how much similar the answer given needs to be to the real answer to award points
            },
            Modifiers: { // What to hide 
                Mute: false,
                Blind: 'black', // Also 'blur' or 'none'
                NoLyrics: true,
                Pitch: 0
                Speed: 0
            },
            RandomHide: 0     // If >0 uses this number of modifiers randomly for each song
        },
        state: {
            running: true,
            currentSongNumber: 5,        // song currently on
            currentTotalDuration: 1200,  // seconds
            playlist: <uuid>,
            currentSong: <kara object>
        },
        date: <Date>,
        flag_active: true // is it the currently active game?
    }, ...
]

Response
{
    code: 500,    
}

Get user's game score

getGameScore Authentication needed Frontend can be closed, restricted or open

Returns a specific user's game score list. If the game had 10 songs, you'll get 10 entries.

<template #request>

Request
{
    gamename: 'Karaoke Quiz Time!',
    username: 'axel@mykmrepo.net'
}

Response
[
    {
        nickname: 'Axel Terizaki',
        kid: '55688483-19b8-4268-9691-9052ac88ac1a', // Full answer
        answer: 'Kaerimichi',                       // User entered this
        points: 3,                                  // points awarded,
        gamename: 'Karaoke Quiz Time!'
    }, ...
]
Response
{
    code: 500
}

Get game's total scores

getTotalGameScore Authentication needed Frontend can be closed, restricted or open

Returns a leaderbooard with a game's scores for each player involved.

Entries are sorted by best score first.

<template #request>

Request
{
    gamename: 'Karaoke Quiz Time!'  
}

Response
[
    {
        nickname: 'Axel Terizaki',
        total: 50
    },
    {
        nickname: 'QCTX',
        total: 47
    }
]
Response
{
    code: 500
}

Get possible answers

getPossibleAnswers Authentication needed Frontend can be closed, restricted or open

Returns an array of possible answers to choose from depending on what the user typed. Like a search engine allowing players to select the answer they want from what they typed.

<template #request>

Request
{
    answer: 'Mahoro'
}

Response
[
    {
        ktid: '<uuid>',              // Can be either a Kara ID or Tag ID
        type: null                   // Tag type if applicable,
        default_name: 'Mahoromatic', // Tag name if applicable
        default_language: 'eng',     // Default language to display the name to the user
        i18n: {...}                  // i18n object with language = name
    }, ...  
]
Response
{
    code: 500
}

Give an answer

setAnswer Authentication needed

Give answer for a specific player. The player identity is defined by its auth token. Answers can be either specific TIDs or KIDs, but also simple strings, depending on what kind of answers are accepted.

<template #request>

Request
{
    anser: <uuid>
}

Simply resolves

Response
{
    code: 500
}

Get quiz timers

getQuizTimers Authentication needed

Get remaining time for all different timers.

<template #success-response>

  • guessTime: Time left for the players to guess the song playing. 0 if the time is over already
  • revealTime: Time left for the reveal of the song players had to guess.
  • quickGuess: Time left before answers can be considered a "quick guess". A period of time that allows players to earn bonus points.
Response
{
    guessTime: 0,
    revealTime: 12,
    quickGuess: 0
}

Response
{
    code: 500
}