Server IP : 10.111.20.6  /  Your IP : 216.73.217.121
Web Server : Apache
System : Linux webm006.cluster111.gra.hosting.ovh.net 5.15.206-ovh-vps-grsec-zfs-classid #1 SMP Fri May 15 02:41:25 UTC 2026 x86_64
User : edizioni ( 7252)
PHP Version : 8.3.23
Disable Function : _dyuweyrj4,_dyuweyrj4r,dl
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0705) :  /home/edizioni/stampaeweb/../wordpress/../extonymask/book/WebServices/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : /home/edizioni/stampaeweb/../wordpress/../extonymask/book/WebServices/AccountWebService.php
<?php

require_once(ROOT_DIR . 'lib/WebService/namespace.php');
require_once(ROOT_DIR . 'Domain/Access/namespace.php');
require_once(ROOT_DIR . 'WebServices/Requests/Account/CreateAccountRequest.php');
require_once(ROOT_DIR . 'WebServices/Requests/Account/UpdateAccountRequest.php');
require_once(ROOT_DIR . 'WebServices/Requests/Account/UpdateAccountPasswordRequest.php');
require_once(ROOT_DIR . 'WebServices/Responses/Account/AccountResponse.php');
require_once(ROOT_DIR . 'WebServices/Responses/Account/AccountActionResponse.php');
require_once(ROOT_DIR . 'WebServices/Controllers/AccountController.php');

class AccountWebService
{
    /**
     * @var IRestServer
     */
    private $server;
    /**
     * @var IAccountController
     */
    private $controller;

    public function __construct(IRestServer $server, IAccountController $controller)
    {
        $this->server = $server;
        $this->controller = $controller;
    }

    /**
     * @name GetAccount
     * @description Gets the currently authenticated users's account information
     * @response AccountResponse
     * @return void
     */
    public function GetAccount()
    {
        $session = $this->server->GetSession();
        $user = $this->controller->LoadUser($session);
        $userId = $user->Id();
        if (empty($userId)) {
            $this->server->WriteResponse(RestResponse::NotFound(), RestResponse::NOT_FOUND_CODE);
            return;
        }

        $attributes = $this->controller->GetUserAttributes($session);
        $this->server->WriteResponse(new AccountResponse($this->server, $user, $attributes));
    }

    /**
     * @name CreateAccount
     * @description Creates a user account. This does not authenticate
     * @request CreateAccountRequest
     * @response AccountCreatedResponse
     * @return void
     */
    public function Create()
    {
        if (!Configuration::Instance()->GetSectionKey(ConfigSection::API, ConfigKeys::ALLOW_REGISTRATION, new BooleanConverter())) {
            $this->server->WriteResponse(
                new FailedResponse($this->server, ['allow.self.registration is not enabled for the API']),
                RestResponse::UNAUTHORIZED_CODE
            );
            return;
        }

        /** @var $request CreateAccountRequest */
        $request = new CreateAccountRequest($this->server->GetRequest());

        Log::Debug('AccountWebService.Create()');

        $result = $this->controller->Create($request);

        if ($result->WasSuccessful()) {
            Log::Debug('AccountWebService.Create() - User Created. Created UserId=%s', $result->UserId());

            $this->server->WriteResponse(
                new AccountActionResponse($this->server, $result->UserId()),
                RestResponse::CREATED_CODE
            );
        } else {
            Log::Debug('AccountWebService.Create() - User Create Failed.');

            $this->server->WriteResponse(
                new FailedResponse($this->server, $result->Errors()),
                RestResponse::BAD_REQUEST_CODE
            );
        }
    }

    /**
     * @name UpdateAccount
     * @description Updates an existing user account
     * @request UpdateAccountRequest
     * @response AccountUpdatedResponse
     * @return void
     */
    public function Update($userId)
    {
        /** @var $request UpdateAccountRequest */
        $request = new UpdateAccountRequest($this->server->GetRequest());

        Log::Debug('AccountWebService.Update()');

        $result = $this->controller->Update($request, $this->server->GetSession());

        if ($result->WasSuccessful()) {
            Log::Debug('AccountWebService.Update() - User Updated. Updated UserId=%s', $result->UserId());

            $this->server->WriteResponse(
                new AccountActionResponse($this->server, $result->UserId()),
                RestResponse::OK_CODE
            );
        } else {
            Log::Debug('AccountWebService.Update() - User Update Failed.');

            $this->server->WriteResponse(
                new FailedResponse($this->server, $result->Errors()),
                RestResponse::BAD_REQUEST_CODE
            );
        }
    }

    /**
     * @name UpdatePassword
     * @description Updates the password for an existing user
     * @request UpdateAccountPasswordRequest
     * @response AccountUpdatedResponse
     * @return void
     */
    public function UpdatePassword($userId)
    {
        /** @var $request UpdateAccountPasswordRequest */
        $request = new UpdateAccountPasswordRequest($this->server->GetRequest());

        Log::Debug('AccountWebService.UpdatePassword()');

        $result = $this->controller->UpdatePassword($request, $this->server->GetSession());

        if ($result->WasSuccessful()) {
            Log::Debug('AccountWebService.UpdatePassword() - Password Updated. Updated UserId=%s', $result->UserId());

            $this->server->WriteResponse(
                new AccountActionResponse($this->server, $result->UserId()),
                RestResponse::OK_CODE
            );
        } else {
            Log::Debug('AccountWebService.Update() - User Update Failed.');

            $this->server->WriteResponse(
                new FailedResponse($this->server, $result->Errors()),
                RestResponse::BAD_REQUEST_CODE
            );
        }
    }
}