nextcloud-swarm-plugin/lib/Controller/BeeController.php
Mahyar Iranibazaz a3a0b0582e
pay-wall (#60)
* 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>
2024-08-12 16:50:32 +02:00

103 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);
}
}