Starting with version 1.7.0 Symfonium expose an API that allows other applications to interact with it.
The API is accessible via a Broadcast receiver, so all you need to do is send proper broadcast intents.
The receiver component name is “app.symfonik.music.player/app.symfonium.remote.api.ApiReceiver”
For apps that split the component this give:
- Package : “app.symfonik.music.player”
- Class: “app.symfonium.remote.api.ApiReceiver”
- Type: Broadcast
Fill the action value of the Intent to the API you want to call, and fill in the extras as documented below.
Change renderer
- Action: “app.symfonium.api.SELECT_RENDERER”
- Extras:
- “TYPE” [Int]: The renderer type
Possible value:
• 0 : Local device
• 1: UPnP Player
• 3 : Chromecast Player
• 6 : Remote Media Center - “IDENTIFIER” [String/Optional]: The renderer unique ID
The value can be seen from the cast screen by pressing the (i) button, you can long press the renderer to automatically copy the value to the clipboard
- “TYPE” [Int]: The renderer type
Force sync
- Action: “app.symfonium.api.MEDIA_SYNC”
- Extras:
- “PROVIDER_ID” [Int]: The provider ID (Can be seen in the bottom sheet menu of providers in settings)
Playback control
- Action: “app.symfonium.api.MEDIA_COMMAND”
- Extras:
- “COMMAND” [String]: The command you want to send
Possible value:
• “play”
• “pause”
• “stop”
• “next”
• “previous”
• “shuffle”
• “repeat”
• “mute”
• “togglemute”
• “seek_relative” (relative position in seconds as int parameter)
• “seek” (position in seconds as int parameter)
• “volume” (Volume as int parameter)
• “set_sleeptimer” (Delay in minutes as int parameter) (6.0.0+)
• “remove_sleeptimer” (6.0.0+) - “INT_PARAMETER” [Int/Optional]: An int value for the commands that requires it
- “COMMAND” [String]: The command you want to send
Media start
- Action: “app.symfonium.api.MEDIA_START”
- Extras:
- “MEDIA_TYPE” [String]: The media type to start
Possible value:
• “playlist”
• “artist”
• “album”
• “genre”
• “song”
• “song_mix”
• “album_mix”
• “internet_radio” (11.2.0+) - “NAME” [String/Optional]: The name of the media (Optional for songs if you provide the filename (1.9.0+))
- “ID” [Long/Optional]: The Id of the radio or the playlist (11.2.0+, optional if you pass the name)
- “FILE” [String/Optional/1.9.0+]: The full path of the media for songs only.
- “RESUME” [Boolean/Optional]: If the media should be resumed if possible.
- “SHUFFLE” [Boolean/Optional]: For media groups like playlist / genre if the content should be shuffled.
- “QUEUE” [Int/Optional/1.8.0+]: 1 to queue the media just after currently playing one. 2 to queue the media at the end of playlist.
- “MEDIA_TYPE” [String]: The media type to start
Setting change (1.10.0+)
- Action: “app.symfonium.api.CHANGE_SETTINGS”
- Extras:
-
“SETTING” [String]: The setting to change
Possible value:
• “wifi_transcode” : Wifi transcoding bitrate
• “mobile_transcode” : Mobile transcoding bitrate
• “available_offline” : Available offline filter (3.2.0+)
• “sleeptimer_endofsong” : Sleep timer wait end of song (6.0.0+) -
“INT_PARAMETER” [Int]: Transcoding value
Possible value for sleep timer wait end of song: • 0 : Disabled • 1 : Enabled Possible value for offline filter: • 0 : Filter disabled • 1 : Filter enabled Possible value for transcoding: • -1 : No transcoding • 1 : 64 Kbps • 2 : 96 Kbps • 3 : 128 Kbps • 4 : 160 Kbps • 5 : 192 Kbps • 6 : 256 Kbps • 7 : 320 Kbps
-
Playlist import (8.0.0+)
Import the playlists from a supported media provider. Existing playlists are automatically skipped.
- Action: “app.symfonium.api.PLAYLIST_IMPORT”
- Extras:
- “PROVIDER_ID” [Int]: The provider ID (Can be seen in the bottom sheet menu of providers in settings)
- “PLAYLIST_TYPE” [Int]: Imported playlist type
- 1: Offline first
- 2: Read only
- 3: Online first
Regenerate playlist thumbnail (11.3.0+)
Update the playlist thumbnail based on the songs thumbnails it contains.
- Action: “app.symfonium.api.CUSTOM_ACTION”
- Extras:
- “ACTION” [String]: “generate_playlist_thumbnail”
- “LONG_PARAMETER” [Long]: The playlist ID (Can be seen at the top of the playlist action bottom sheet)
Regenerate genre thumbnail (11.5.0+)
Update the genre thumbnail based on the songs thumbnails it contains.
- Action: “app.symfonium.api.CUSTOM_ACTION”
- Extras:
- “ACTION” [String]: “generate_genre_thumbnail”
- “NAME” [String]: The genre name (Note: You can use the special “
--ALL--
” value to regenerate all genres thumbnails, beware of duration and battery usage)
Cleanup offline cache (11.3.0+)
Trigger the Cleanup action from manage offline cache.
- Action: “app.symfonium.api.CUSTOM_ACTION”
- Extras:
- “ACTION” [String]: “cleanup_offline_cache”
Start backup (11.3.0+)
Start a backup with the selected settings (Password and at least one option must be passed)
- Action: “app.symfonium.api.CUSTOM_ACTION”
- Extras:
- “ACTION” [String]: “start_backup”
- “PASSWORD” [String]: The backup password. MANDATORY
- “SETTINGS” [Boolean]: If the backup should contain this.
- “PROVIDERS” [Boolean]: If the backup should contain this.
- “EQ_PROFILES” [Boolean]: If the backup should contain this.
- “INTERNET_RADIO” [Boolean]: If the backup should contain this.
- “PLAYLISTS” [Boolean]: If the backup should contain this.