Misc
Get Frontend Migrations
getMigrationsFrontend
Operator user required
Retrieve list of migrations with a flag to tell if they have been done or not. Frontend migrations are just pages the frontend loads with information for the user on new features or improtant notices. With a new installation all migrations are marked as done already.
[
{
name: 'KMOnline'
flag_done: false
}
]
If a migration is false, you should display it to the user.
{
code: 500
}
Set frontend migration
setFrontendMigration
Operator user required
Set a migration as done/undone.
{
mig: {
name: 'KMOnline'
flag_done: true
}
}
Promise just ersolves
{
code: 500
}
Get remote status
getRemoteData
Operator user required Frontend needs to be open
Returns information about if the current app instance is available via remote access (through xxx.mykmrepo.net)
{
active: true,
info: {
host: 'mykmrepo.net',
code: 'kkkk',
token: 'blah',
},
token: 'remoteToken' // Token from the settings table
}
If active
is false
, no other information is returned.
{
code: 500
}
Reset remote token
resetRemoteToken
Operator user required Frontend needs to be open
Resets the remote token used to enable remote access and communicate with a KM Server instance. Use this if the token has been compromised.
Actions taken by this command :
- destroy the remote access
- reinitialize token in settings table
- initialize new remote
Promise just resolves.
{
code: 500,
}
Shutdown application
shutdown
Operator user required Frontend needs to be open
Shutdowns the entire application.
Get Settings
getSettings
No authentication needed Frontend can be closed, restricted or open
Return settings, state and version.
{
version: {
name: 'Axel Acrobate',
number: '26.1.1',
image: 'AxelAcrobate.jpg',
sha: <git commit SHA>
},
config: { // Depending on user level, not all configuration is returned
...
},
state: { // Application state depending on user level
currentPlaid: 1,
publicPlaid: 1,
appPath: '...' // only for admins, undefined for others
dataPath: '...' // same
os: 'win32' // same
electron: // does the app run on electron or node ?
defaultLocale: 'fr',
supportedLyrics: [
'ass',
'srt',
'kar',
'txt',
'kfn',
'lrc'
],
supportedMedias: [
'avi',
'mkv',
'mp4',
'webm',
'mov',
'wmv',
'mpg',
'm2ts',
'rmvb',
'ts',
'm4v',
'ogg',
'm4a',
'mp3',
'wav',
'flac',
'mid'
],
environment: 'production',
sentrytest: false // Sentry is enabled if false.
url: 'http://mykmrepo.net',
}
}
For more information about configuration, see sample file in the git repo
{
code: 500,
}
Update setting
updateSettings
Operator user required Frontend needs to be open
Updates one or more configuration options.
{
Frontend: {
GeneratePreviews: false
}
}
Configuration is returned as a result.
For more information about configuration, see sample file in the git repo
{
code: 500,
message: {
code: 'SETTINGS_UPDATE_ERROR'
}
}
Get displays
getDisplays
Operator user required Frontend can be closed, restricted or open
Return the list of displays the host computer has and their names. Only displays with positive resolutions are returned.
Returns an array of displays. See systeminformation module's documentation
Get Stats
getStats
Operator user required Frontend can be closed, restricted or open
Get basic database statistics
{
tags: 15029,
singers: 2039,
songwriters: 8021,
creators: 1122,
authors: 250,
karas: 11203,
languages: 26,
whitelist: 880, // number of songs whitelisted
blacklist: 2, // number of songs blacklisted
series: 5002,
played: 12913 // number of songs played,
playlists: 5,
duration: 102391823908 // duration of all songs in database in seconds.
}
Request simply returns.
{
code: 500,
message: {
code: 'STATS_ERROR'
}
}
Refresh user quotas
refreshUserQuotas
Authentication needed Frontend needs to be open
Forces a refresh of the current user's quota (uses the authorization token)
Promise resolves immediately, but you'll receive a websocket event once calculations are complete
Get player state
getPlayerStatus
Authentication needed Frontend needs to be restricted or open
Returns the media player's state
{
volume: 98,
playing: true,
playerStatus: 'play', // 'stop' or 'pause' too,
_playing: true, // internal delay flag,
timeposition: 57.2, // in seconds
mute: false,
currentSong: {
...PlaylistContent,
avatar: '...' // Path to avatar file ,
infos: '...' // ASS script to display song information in the player
},
currentMedia: { // If a playlist media is playing instead of a song
series: 'One Piece',
filename: 'One Piece - EC1.mp4',
type: 'Jingles'
},
mediaType: 'song',
showSubs: true,
onTop: true,
fullscreen: true,
border: true,
url: 'http://abcd.mykmrepo.net',
monitorEnabled: false // Second player monitor enabled?
songNearEnd: false // Is the song about to end (8 seconds left or less),
nextSongNotifSent: false,
isOperating: false // Player lock status to avoid sending multiple commands
currentSessionID: <uuid>, // Current karaoke session,
currentRequester: 'Axel', // Who asked the current song,
stopping: false // true if player is going to stop after current song
defaultLocale: 'fr',
songsBeforeJingle: 22,
songsbeforeSponsors: 42
}
currentMedia.type
can be :
Jingles
Sponsors
,Outros
,Intros
,Encores
mediaType
can be :
- one of
currentMedia.type
song
background
: when the player is stoppedpauseScreen
: when the player is inbetween songs in classic or streamer mode
Get news feed
getNewsFeed
No authentication needed Frontend needs to be open
Returns a news feed from the lab and KM's mastodon account.
[
{
name: 'git_base',
body: <stringified JSON>
},
{
name: 'git_app',
body: <stringified JSON>
},
{
name: 'mastodon',
body: <stringified JSON>
}
]
For info on feeds, check the feed tool code
{
code: 500,
}
Get catchphrase
getCatchphrase
Authentication needed Frontend needs to be open
Returns a random catchphrase string
Response is in plain text.
Blablabla
Get logs
getLogs
Operator user required Frontend can be closed, restricted or open
Get Karaoke Mugen system logs.
This aligns logs from websocket to the ones you'll have received through this route.
{
level: 'info'
}
[
{
level: 'info',
service: 'Player',
message: 'Hey! Listen!',
timestamp: '2021-03-03T15:43:52.755Z',
obj: {} // optional detail object, usually for errors
}
]
{
code: 500,
message: {
code: 'ERROR_READING_LOGS'
}
}
Backup settings
backupSettings
Operator user required Frontend can be closed, restricted or open
Saves configuration as another file `config.backup.yml`
[
code: 200,
message: {
code: 'CONFIG_BACKUPED'
}
]
{
code: 500,
message: {
code: 'CONFIG_BACKUPED_ERROR'
}
}
Generate database
generateDatabase
Operator user required
Triggers a new database generation from the current data files.
A new Task will start with progress immediately after the call is made.
Once completed you'll get :
{
code: 200,
message: {
code: 'DATABASE_GENERATED'
}
}
{
code: 500,
message: {
code: 'DATABASE_GENERATED_ERROR'
}
}
Validate files
validateFiles
Operator user required
Triggers a data files validation process. Files are read and verified. Any inconsistency is fixed (wrong subchecksum, wrong media metadata, etc.) Useful when files have been modified from outside Karaoke Mugen.
A new Task will start with progress immediately after the call is made.
Once completed you'll get :
{
code: 200,
message: {
code: 'FILES_VALIDATED'
}
}
{
code: 500,
message: {
code: 'FILES_VALIDATED_ERROR'
}
}
Dump database
dumpDatabase
Operator user required
Dumps database to a SQL file. This works only on installation relying on the bundled PostgreSQL server.
The file is saved as karaokemugen.sql
in dataPath
.
{
code: 200,
message: {
code: 'DATABASE_DUMPED'
}
}
{
code: 500,
message: {
code: 'DATABASE_DUMPED_ERROR'
}
}
Restore database
restoreDatabase
Operator user required
Restores database from the `karaokemugen.sql` file in `dataPath`.
WARNING: This obviously destroys any data not dumped previously.
{
code: 200,
message: {
code: 'DATABASE_RESTORED'
}
}
{
code: 500,
message: {
code: 'DATABASE_RESTORED_ERROR'
}
}
Get directory from filesystem
getFS
Operator user required
Returns a list of files and folders in the choosen `path`. Useful to provide browsing capabilities to your app without Electron's native open file dialogs.
{
contents: [
{
name: 'KaraokeMugen',
isDirectory: true
},
...
]
drives: [
// Windows only.
],
fullPath: 'C:\Users\something\'
}
For drives
, please refer to systeminformation's documentation : blockDevices
{
code: 500,
message: {
code: 'FS_ERROR'
}
}
Get Electron Versions
getElectronVersions
Authentication needed
Returns `process.versions` from Electron.
See Electron and Node's API for process.versions
.
Get audio devices
getAudioDevices
Operator user required Frontend can be closed, restricted or open
Returns a list of audio devices MPV supports
[ ['auto', 'Autoselect device'], ['wasapi/{d5df6e9d-1ff9-4318-bc82-a79bed31abb0}', 'Haut-parleurs (Realtek(R) Audio)'], ['openal', 'Default (openal)'], ['sdl' 'Default (sdl)'] ]
Open current log file
openLogFile
Operator user required Frontend can be closed, restricted or open
Stats a file explorer on the host computer with the current log file selected.
On Linux, it'll try xdg-open
then nautilus
and then dolphin
before giving up.
Simply resolves.