/*jslint indent: 2, nomen: true, maxlen: 100, sloppy: true, vars: true, white: true, plusplus: true */ /*global require, module */ //////////////////////////////////////////////////////////////////////////////// /// @brief foxx administration actions /// /// @file /// /// DISCLAIMER /// /// Copyright 2010-2012 triagens GmbH, Cologne, Germany /// /// Licensed under the Apache License, Version 2.0 (the "License"); /// you may not use this file except in compliance with the License. /// You may obtain a copy of the License at /// /// http://www.apache.org/licenses/LICENSE-2.0 /// /// Unless required by applicable law or agreed to in writing, software /// distributed under the License is distributed on an "AS IS" BASIS, /// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. /// See the License for the specific language governing permissions and /// limitations under the License. /// /// Copyright holder is triAGENS GmbH, Cologne, Germany /// /// @author Dr. Frank Celler /// @author Copyright 2012, triAGENS GmbH, Cologne, Germany //////////////////////////////////////////////////////////////////////////////// var internal = require("internal"); var fs = require("fs"); var arangodb = require("org/arangodb"); var actions = require("org/arangodb/actions"); var foxxManager = require("org/arangodb/foxx/manager"); var easyPostCallback = actions.easyPostCallback; // ----------------------------------------------------------------------------- // --SECTION-- public functions // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @brief fetches a FOXX application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/fetch", context : "admin", prefix : false, callback : function (req, res) { 'use strict'; var safe = /^[0-9a-zA-Z_\-\.]+$/; if (req.suffix.length !== 0) { actions.resultBad(req, res, arangodb.ERROR_HTTP_BAD_PARAMETER); return; } var json = actions.getJsonBody(req, res, actions.HTTP_BAD); if (json === undefined) { return; } var serverFile = json.filename; var realFile = fs.join(fs.getTempPath(), serverFile); if (! fs.isFile(realFile)) { actions.resultNotFound(req, res, arangodb.errors.ERROR_FILE_NOT_FOUND.code); return; } try { var name = json.name; var version = json.version; if (! safe.test(name)) { fs.remove(realFile); throw "rejecting unsafe name '" + name + "'"; } if (! safe.test(version)) { fs.remove(realFile); throw "rejecting unsafe version '" + version + "'"; } var appPath = module.appPath(); if (typeof appPath === "undefined") { fs.remove(realFile); throw "javascript.app-path not set, rejecting app loading"; } var path = fs.join(appPath, name + "-" + version); if (fs.exists(path)) { fs.remove(realFile); throw "destination path '" + path + "' already exists"; } fs.makeDirectoryRecursive(path); fs.unzipFile(realFile, path, false, true); foxxManager.scanAppDirectory(); var found = arangodb.db._collection("_aal").firstExample({ type: "app", path: name + "-" + version }); if (found !== null) { found = found.app; } actions.resultOk(req, res, actions.HTTP_OK, { path: path, app: found }); } catch (err) { actions.resultException(req, res, err, undefined, false); } } }); //////////////////////////////////////////////////////////////////////////////// /// @brief mounts a FOXX application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/mount", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { var appId = body.appId; var mount = body.mount; var options = body.options || {}; return foxxManager.mount(appId, mount, options); } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief rescans the FOXX application directory //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/rescan", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { foxxManager.scanAppDirectory(); return true; } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief sets up a FOXX application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/setup", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { var mount = body.mount; return foxxManager.setup(mount); } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief tears down a FOXX application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/teardown", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { var mount = body.mount; return foxxManager.teardown(mount); } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief unmounts a FOXX application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/unmount", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { var mount = body.mount; return foxxManager.unmount(mount); } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief sets up a FOXX dev application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/dev-setup", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { var name = body.name; return foxxManager.devSetup(name); } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief tears down a FOXX dev application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/dev-teardown", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { var name = body.name; return foxxManager.devTeardown(name); } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief purges a FOXX application //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/purge", context : "admin", prefix : false, callback: easyPostCallback({ body: true, callback: function (body) { var name = body.name; return foxxManager.purge(name); } }) }); //////////////////////////////////////////////////////////////////////////////// /// @brief returns directory information //////////////////////////////////////////////////////////////////////////////// actions.defineHttp({ url : "_admin/foxx/config", context : "admin", prefix : false, callback : function (req, res) { var result = { appPath: module.appPath(), devAppPath: internal.developmentMode ? module.devAppPath() : null, logFilePath: internal.logfilePath, startupPath: module.startupPath() }; actions.resultOk(req, res, actions.HTTP_OK, { result: result }); } }); // ----------------------------------------------------------------------------- // --SECTION-- END-OF-FILE // ----------------------------------------------------------------------------- // Local Variables: // mode: outline-minor // outline-regexp: "/// @brief\\|/// @addtogroup\\|// --SECTION--\\|/// @page\\|/// @\\}" // End: