mirror of
				https://github.com/elyby/accounts.git
				synced 2025-05-31 14:11:46 +05:30 
			
		
		
		
	* start updating to PHP 8.3 * taking off! Co-authored-by: ErickSkrauch <erickskrauch@yandex.ru> Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * dropped this Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * migrate to symfonymailer Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * this is so stupid 😭 Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * ah, free, at last. Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * oh, Gabriel. Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * now dawns thy reckoning. Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * and thy gore shall GLISTEN before the temples of man. Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * creature of steel. Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * my gratitude upon thee for my freedom. Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * but the crimes thy kind has committed against humanity Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * Upgrade PHP-CS-Fixer and do fix the codebase * First review round (maybe I have broken something) * are NOT forgotten. Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * Enable parallel PHP-CS-Fixer runner * PHPStan level 1 * PHPStan level 2 * PHPStan level 3 * PHPStan level 4 * PHPStan level 5 * Levels 6 and 7 takes too much effort. Generate a baseline and fix them eventually * Resolve TODO's related to the php-mock * Drastically reduce baseline size with the Rector * More code modernization with help of the Rector * Update GitLab CI --------- Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> Co-authored-by: ErickSkrauch <erickskrauch@yandex.ru>
		
			
				
	
	
		
			75 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
declare(strict_types=1);
 | 
						|
 | 
						|
namespace api\models;
 | 
						|
 | 
						|
use api\models\base\ApiForm;
 | 
						|
use common\helpers\Error as E;
 | 
						|
use common\models\Account;
 | 
						|
use Webmozart\Assert\Assert;
 | 
						|
use Yii;
 | 
						|
use yii\base\InvalidConfigException;
 | 
						|
 | 
						|
class FeedbackForm extends ApiForm {
 | 
						|
 | 
						|
    public mixed $subject = null;
 | 
						|
 | 
						|
    public mixed $email = null;
 | 
						|
 | 
						|
    public mixed $type = null;
 | 
						|
 | 
						|
    public mixed $message = null;
 | 
						|
 | 
						|
    public function rules(): array {
 | 
						|
        return [
 | 
						|
            [['subject'], 'required', 'message' => E::SUBJECT_REQUIRED],
 | 
						|
            [['email'], 'required', 'message' => E::EMAIL_REQUIRED],
 | 
						|
            [['message'], 'required', 'message' => E::MESSAGE_REQUIRED],
 | 
						|
            [['subject'], 'string', 'max' => 255],
 | 
						|
            [['email'], 'email', 'message' => E::EMAIL_INVALID],
 | 
						|
            [['message'], 'string', 'max' => 65535],
 | 
						|
        ];
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @throws InvalidConfigException
 | 
						|
     */
 | 
						|
    public function sendMessage(): bool {
 | 
						|
        if (!$this->validate()) {
 | 
						|
            return false;
 | 
						|
        }
 | 
						|
 | 
						|
        /** @var \yii\symfonymailer\Mailer $mailer */
 | 
						|
        $mailer = Yii::$app->mailer;
 | 
						|
        $supportEmail = Yii::$app->params['supportEmail'];
 | 
						|
        if (!$supportEmail) {
 | 
						|
            throw new InvalidConfigException('Please specify supportEmail value in the app params');
 | 
						|
        }
 | 
						|
 | 
						|
        $account = $this->getAccount();
 | 
						|
        /** @var \yii\symfonymailer\Message $message */
 | 
						|
        $message = $mailer->compose('@common/emails/views/feedback', [
 | 
						|
            'model' => $this,
 | 
						|
            'account' => $account,
 | 
						|
        ]);
 | 
						|
        $message
 | 
						|
            ->setTo($supportEmail)
 | 
						|
            ->setFrom([$this->email => $account?->username ?? $this->email])
 | 
						|
            ->setSubject($this->subject);
 | 
						|
 | 
						|
        Assert::true($message->send(), 'Unable send feedback email.');
 | 
						|
 | 
						|
        return true;
 | 
						|
    }
 | 
						|
 | 
						|
    protected function getAccount(): ?Account {
 | 
						|
        $identity = Yii::$app->user->identity;
 | 
						|
        if ($identity === null) {
 | 
						|
            return null;
 | 
						|
        }
 | 
						|
 | 
						|
        return $identity->getAccount();
 | 
						|
    }
 | 
						|
 | 
						|
}
 |