mirror of
https://github.com/MetaProvide/nextcloud-swarm-plugin.git
synced 2025-01-11 21:59:13 +00:00
a3a0b0582e
* add env for swarm access * check access * use storage config from external storage to set access key * Update README.md (#50) updated settings menu in readme * feat(intellisense): (#51) - update: remap the docker volume for main nextcloud to local project directory to access the nc code * add env for swarm access * feat(hooks): - add: entrypoint hooks volume - add: change-owner.sh script * feat(apache): - update: Dockerfile apache user and id - delete: hooks setup - add: .env setup - add: theme volume - update: turn off debugger at start * feat(.env): - add: .env example file * fix(docker): - add: theme volume * fix(docker): - revert: xdebug start config * backend options not persistant * access key works * feat(docker): - update: reduce the volumes to lib and apps * chore(env): - add: swarm api key in example * chore(env): - add: env file instructions - fix: typos * docs(readme): - fix: image path typo * merge(docker): - fix: revert the dev-env folder volumes * chore(main): - add: curl ext to project requirements * feat(util): curl - add: curl helper * feat(swarm): curl - update: request to use new Curl helper - update: check connection using new endpoint of gateway - update: type safety - refactor: remove unused methods * refactor(swarm): - refactor: upload and download methods - update: code style * feat(pay-wall): licence - add: License auth implementation - update: external storage definition - remove: nocodb access token setup - remove: basic auth setup * feat(swarm): - update: disable custom settings page * feat(gitignore): - update: categorize gitignore - add: DS_Store entry =) * refactor(gitignore): - update: url check using regex * fix(swarm): upload - update: remove extra param * fix(swarm): file preview - update: write file to memory to stream * feat(settings): add link - add: script to display link on settings page - update: load script on plugin boot --------- Co-authored-by: Henry Bergstrom <henrybergstrom@protonmail.com> Co-authored-by: rampall <rameshpallikara@gmail.com>
102 lines
3.1 KiB
PHP
Executable file
102 lines
3.1 KiB
PHP
Executable file
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
/**
|
|
* @copyright Copyright (c) 2023, MetaProvide Holding EKF
|
|
*
|
|
* @author Ron Trevor <ecoron@proton.me>
|
|
*
|
|
* @license GNU AGPL version 3 or any later version
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
namespace OCA\Files_External_Ethswarm\Controller;
|
|
|
|
use OCP\AppFramework\Controller;
|
|
use OCP\IConfig;
|
|
use OCP\IRequest;
|
|
use OCA\Files_External_Ethswarm\Settings\Admin;
|
|
use OCP\AppFramework\Http\DataResponse;
|
|
use OCP\AppFramework\Http;
|
|
|
|
class BeeController extends Controller {
|
|
|
|
/** @var Admin */
|
|
private $admin;
|
|
|
|
/** @var string */
|
|
protected $appName;
|
|
|
|
/** @var IConfig */
|
|
private $config;
|
|
|
|
/**
|
|
* @param IConfig $config
|
|
* @param IRequest $request
|
|
*/
|
|
public function __construct(
|
|
string $appName,
|
|
IConfig $config,
|
|
IRequest $request,
|
|
Admin $admin,
|
|
) {
|
|
parent::__construct($appName, $request);
|
|
$this->config = $config;
|
|
$this->admin = $admin;
|
|
}
|
|
|
|
/**
|
|
* @NoCSRFRequired
|
|
* @NoAdminRequired
|
|
* Create a new postage batch stamp
|
|
* @return \DataResponse
|
|
*/
|
|
public function createPostageBatch(): DataResponse {
|
|
if ($this->request->getParam("postageBatch")) {
|
|
$postageBatch = json_decode($this->request->getParam("postageBatch"), true);
|
|
|
|
$response_data = $this->admin->buyPostageStamp($postageBatch["amount"],$postageBatch["depth"],$postageBatch["mount_urloptions"]);
|
|
|
|
if (isset($response_data["batchID"])) {
|
|
return new DataResponse(array('batchID' => $response_data["batchID"]), Http::STATUS_OK);
|
|
} else if (isset($response_data["message"])) {
|
|
return new DataResponse(array('msg' => $response_data["message"]), $response_data["code"]);
|
|
}
|
|
}
|
|
return new DataResponse(array('msg' => "Error in request"), Http::STATUS_CONFLICT);
|
|
}
|
|
|
|
/**
|
|
* @NoCSRFRequired
|
|
* @NoAdminRequired
|
|
* Top up an existing batch stamp based on the batchID
|
|
* @return \DataResponse
|
|
*/
|
|
public function topUpBatch(): DataResponse {
|
|
if ($this->request->getParam("postageBatch")) {
|
|
$postageBatch = json_decode($this->request->getParam("postageBatch"), true);
|
|
|
|
$response_data = $this->admin->topUpPostageStamp($postageBatch["activeBatchId"],$postageBatch["topUpValue"],$postageBatch["mount_urloptions"]);
|
|
if (isset($response_data["batchID"])) {
|
|
return new DataResponse(array('batchID' => $response_data["batchID"]), Http::STATUS_OK);
|
|
} else if (isset($response_data["message"])) {
|
|
return new DataResponse(array('msg' => $response_data["message"]), $response_data["code"]);
|
|
}
|
|
}
|
|
return new DataResponse(array('msg' => "Error in request"), Http::STATUS_CONFLICT);
|
|
}
|
|
}
|