From 920a51f9975306908aee70ad885a528ff77e03db Mon Sep 17 00:00:00 2001 From: Brandon Schneider Date: Thu, 4 Feb 2016 22:34:01 -0600 Subject: [PATCH] Add new iocage API call to clean all RELEASEs REST Request: ------------------------------- PUT /sysadm/iocage { "action" : "cleanreleases" } WebSocket Request: ------------------------------- { "id" : "fooid", "namespace" : "sysadm", "args" : { "action" : "cleanreleases" }, "name" : "iocage" } Response: ------------------------------- { "args": { "cleanreleases": { "success": "All RELEASEs have been cleaned." } }, "id": "fooid", "name": "response", "namespace": "sysadm" } --- src/server/WebBackend.cpp | 4 ++++ src/server/library/sysadm-iocage.cpp | 23 +++++++++++++++++++++++ src/server/library/sysadm-iocage.h | 1 + 3 files changed, 28 insertions(+) diff --git a/src/server/WebBackend.cpp b/src/server/WebBackend.cpp index be4f607..04354ae 100644 --- a/src/server/WebBackend.cpp +++ b/src/server/WebBackend.cpp @@ -389,6 +389,10 @@ RestOutputStruct::ExitCode WebSocket::EvaluateSysadmIocageRequest(const QJsonVal bool ok = false; if(keys.contains("action")){ QString act = JsonValueToString(in_args.toObject().value("action")); + if(act=="cleanreleases"){ + ok = true; + out->insert("cleanreleases", sysadm::Iocage::cleanReleases()); + } if(act=="cleanjails"){ ok = true; out->insert("cleanjails", sysadm::Iocage::cleanJails()); diff --git a/src/server/library/sysadm-iocage.cpp b/src/server/library/sysadm-iocage.cpp index faa2bfb..0ebdab1 100644 --- a/src/server/library/sysadm-iocage.cpp +++ b/src/server/library/sysadm-iocage.cpp @@ -12,6 +12,29 @@ using namespace sysadm; //PLEASE: Keep the functions in the same order as listed in pcbsd-general.h +// Clean all RELEASEs on a box +QJsonObject Iocage::cleanReleases() { + QJsonObject retObject; + + QStringList output = General::RunCommand("iocage clean -fr ").split("\n"); + + for ( int i = 0; i < output.size(); i++) + { + // This means either a mount is stuck or a jail cannot be stopped, + // give them the error. + if ( output.at(i).indexOf("ERROR:") != -1 ) { + retObject.insert("error", output.at(i)); + break; + } else { + // iocage does a spinner for these that is distracting to see returned, + // returning what a user wants to actually see. + retObject.insert("success", "All RELEASEs have been cleaned."); + } + } + + return retObject; +} + // Clean all jails on a box QJsonObject Iocage::cleanJails() { QJsonObject retObject; diff --git a/src/server/library/sysadm-iocage.h b/src/server/library/sysadm-iocage.h index 97c579f..58745db 100644 --- a/src/server/library/sysadm-iocage.h +++ b/src/server/library/sysadm-iocage.h @@ -14,6 +14,7 @@ namespace sysadm{ class Iocage{ public: + static QJsonObject cleanReleases(); static QJsonObject cleanJails(); static QJsonObject capJail(QJsonObject); static QJsonObject deactivatePool(QJsonObject);