Guide on how to change the port the client frontend listens on.
Cider defaults to using port 9000 for the client frontend. If you need to change this port, you can do so by setting the PORT environment variable.
Note: This only works on Electron Clients. Setting the port on Sabiiro is currently not supported.
Setting the Port in the CLI
When running Cider from the CLI you can set the ports as follows:
PORT=1111./cider-2.4.1.appimage
This will start the client frontend on port 1111.
Setting the Port in a etc/environment File
In linux you can set the port in a etc/environment file. This file is read by the system on startup and sets the environment variables for all processes. MacOS users can use the ~/.bash_profile file.
RPC Documentation
This website contains all the resources required to compile, create plugins and theme Cider!
All of the endpoints are paths that point to http://localhost:10769, we've observed that sometimes using 127.0.0.1 when IPv4 is disabled (don't do that btw) tends to break and not connect. We're not fixing this as it's user error for turning off IPv4, but if you cannot do anything about it, try using [::1]:10769.
GET/active
This will respond as quickly as possible with an empty 204: No Content response, it can be used to quickly check that the RPC is still active.
204: No Content
```json // No Response Body... ```
GET/currentPlayingSong
This will respond with an Apple Music API Response for the currently playing song, the following is an example response.
200: OK
{"info": {"albumName":"Skin","artistName":"Flume","artwork": {"bgColor":"aa96c7","height":600,"textColor1":"040a06","textColor2":"1b1937","textColor3":"25262c", "url": "https://is1-ssl.mzstatic.com/image/thumb/Music122/v4/20/84/1b/20841bcf-a7c1-8048-08ba-ea03e33dbdce/3614598524069.png/{w}x{h}bb.jpg",
"width":600 },"audioLocale":"en-US","audioTraits": ["atmos","lossless","lossy-stereo","spatial"],"composerName":"Harley Streten, Amanda Warner & Peter Wade Keusch","currentPlaybackProgress":0.63,"currentPlaybackTime":123.059955,"discNumber":1,"durationInMillis":193633,"endTime":1686069277080,"genreNames": ["Electronic"],"hasLyrics":true,"hasTimeSyncedLyrics":true,"isAppleDigitalMaster":false,"isMasteredForItunes":false,"isPlaying":true,"isVocalAttenuationAllowed":true,"isrc":"MtheoryLLCAUFF01600807","kind":"song","name":"Like Water (feat. MNDR)","playParams": {"id":"1481729389","kind":"song" },"previews": [ { "url": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview112/v4/9d/12/c3/9d12c393-bc10-14ba-b70b-a8ad27fb21b7/mzaf_1376031537628674471.plus.aac.ep.m4a"
} ],"releaseDate":"2016-05-27T12:00:00Z","remainingTime":70573.04500000001,"songId":"1481729389","startTime":1686069083447.045,"status":"playing","trackNumber":14,"url": {"appleMusic":"https://music.apple.com/au/song/1481729389","cider":"https://cider.sh/link?play/s/1481729389","songLink":"https://song.link/i/1481729389" } }}
GET/addToLibrary
This will save the currently playing track to the user's library. If no music is playing, this will do nothing.
204: No Content
```json // No Response Body... ```
GET/isPlaying
This will return a JSON string stating if the player is currently actively playing a song or not.
200: OK - Playing
```json { "is_playing": true } ```
200: OK - Not Playing
```json { "is_playing": false } ```
These are the only 2 potential responses to this request, if it is anything else, it's safe to assume something broke.
{/*
IMO the next 3 endpoints should be PUT or POST but they're GET because why not. (playPause, play, pause -Amaru8)
-d3rpp
*/}
GET/toggleAutoplay
This will change the autoplay setting to its opposite value and return the updated value in a JSON string.
200: OK - Enabled
```json { "autoplay": true } ```
200: OK - Disabled
```json { "autoplay": false } ```
These are the only 2 potential responses to this request, if it is anything else, it's safe to assume something broke.
GET/playPause
This is functionally equivalent to clicking the play/pause button within the application.
204: No Content
```json // No Response Body... ```
GET/play
This is functionally equivalent to clicking the play button within the application, if music is already playing, this will do nothing.
204: No Content
```json // No Response Body... ```
GET/pause
This is functionally equivalent to clicking the pause button within the application, if music is already paused, this will do nothing.
204: No Content
```json // No Response Body... ```
GET/stop
This is functionally equivalent to clicking the STOP button within the application, if nothing is happening, this will do nothing
204: No Content
```json // No Response Body... ```
GET/next
This will skip to the next song, behaviour is identical to clicking the button within the application.
204: No Content
```json // No Response Body... ```
GET/previous
This will skip to the previous song, behaviour is identical to clicking the button within the application.
204: No Content
```json // No Response Body... ```
GET/seekto/{t}
Where
t is the time you'd like to skip to in seconds
Set the playhead to this time in the song, you can use /currentPlayingSong to get the time, (using the durationInMillis property divided by 1,000 to get the duration in seconds).
This will always return 204 and if the call fails or the song is too long, it will silently fail, it is recommended that you check the song's actual length before running this function.
204: No Content
```json // No Response Body... ```
GET/show
Will show the window and demand user attention on the screen
204: No Content
```json // No Response Body... ```
GET/hide
Will hide the window, if enabled this will minise it to the system tray as well.
204: No Content
```json // No Response Body... ```
GET/album/{id}
Where
id is the ID of the album you'd like to lookup
This will run a query of the Apple Music API using the signed in user's account and will pipe the response back to here.
This will always return a 200 but with a different JSON Structure
200: OK - Failed Lookup
```json { "errors": [ { "code": "40400", "detail": "Resource with requested id was not found", "id": "", // redacted "status": "404", "title": "Resource Not Found" } ] } ```