diff options
author | Lars-Dominik Braun <lars@6xq.net> | 2020-08-07 08:08:10 +0200 |
---|---|---|
committer | Lars-Dominik Braun <lars@6xq.net> | 2020-08-08 15:15:19 +0200 |
commit | 7f6457aa9b7110869e89111c42651b1055728679 (patch) | |
tree | ca1138c88748679ad6a564576e922803fdab5ec7 /src/libpiano/response.c | |
parent | bcc0c5fecfb79f412f45b7befc65b380a7e2bb5d (diff) | |
download | pianobar-7f6457aa9b7110869e89111c42651b1055728679.tar.gz pianobar-7f6457aa9b7110869e89111c42651b1055728679.tar.bz2 pianobar-7f6457aa9b7110869e89111c42651b1055728679.zip |
Allow changing station mode
Fixes #700.
Diffstat (limited to 'src/libpiano/response.c')
-rw-r--r-- | src/libpiano/response.c | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/src/libpiano/response.c b/src/libpiano/response.c index 4b706e2..1a0f2d5 100644 --- a/src/libpiano/response.c +++ b/src/libpiano/response.c @@ -651,6 +651,66 @@ PianoReturn_t PianoResponse (PianoHandle_t *ph, PianoRequest_t *req) { } break; } + + case PIANO_REQUEST_GET_STATION_MODES: { + PianoRequestDataGetStationModes_t *reqData = req->data; + assert (reqData != NULL); + + int active = -1; + + json_object *activeMode; + if (json_object_object_get_ex (result, "currentModeId", &activeMode)) { + active = json_object_get_int (activeMode); + } + + json_object *availableModes; + if (json_object_object_get_ex (result, "availableModes", &availableModes)) { + for (int i = 0; i < json_object_array_length (availableModes); i++) { + json_object *val = json_object_array_get_idx (availableModes, i); + + assert (json_object_is_type (val, json_type_object)); + + PianoStationMode_t *mode; + if ((mode = calloc (1, sizeof (*mode))) == NULL) { + return PIANO_RET_OUT_OF_MEMORY; + } + + json_object *modeId; + if (json_object_object_get_ex (val, "modeId", &modeId)) { + mode->id = json_object_get_int (modeId); + mode->name = PianoJsonStrdup (val, "modeName"); + mode->description = PianoJsonStrdup (val, "modeDescription"); + mode->isAlgorithmic = getBoolDefault (val, "isAlgorithmicMode", + false); + mode->isTakeover = getBoolDefault (val, "isTakeoverMode", + false); + mode->active = active == mode->id; + } + + reqData->retModes = PianoListAppendP (reqData->retModes, + mode); + } + } + break; + } + + case PIANO_REQUEST_SET_STATION_MODE: { + PianoRequestDataSetStationMode_t *reqData = req->data; + assert (reqData != NULL); + + int active = -1; + + json_object *activeMode; + if (json_object_object_get_ex (result, "currentModeId", &activeMode)) { + active = json_object_get_int (activeMode); + } + + if (active != reqData->id) { + /* this did not work */ + return PIANO_RET_ERR; + } + break; + } } cleanup: |