|
|
|
|
@@ -1,222 +0,0 @@
|
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Livewire\Frontend;
|
|
|
|
|
|
|
|
|
|
use App\Models\Log;
|
|
|
|
|
use App\Models\ZEmail;
|
|
|
|
|
use Carbon\Carbon;
|
|
|
|
|
use Illuminate\Support\Facades\Http;
|
|
|
|
|
use Livewire\Component;
|
|
|
|
|
|
|
|
|
|
class ActionOld extends Component
|
|
|
|
|
{
|
|
|
|
|
public $in_app = false;
|
|
|
|
|
public $user, $domain, $domains, $email, $emails, $captcha;
|
|
|
|
|
|
|
|
|
|
protected $listeners = ['syncEmail', 'checkReCaptcha3'];
|
|
|
|
|
|
|
|
|
|
public function mount() {
|
|
|
|
|
$this->domains = config('app.settings.domains');
|
|
|
|
|
$this->email = ZEmail::getEmail();
|
|
|
|
|
$this->emails = ZEmail::getEmails();
|
|
|
|
|
$this->validateDomainInEmail();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function refreshMessages()
|
|
|
|
|
{
|
|
|
|
|
$this->emit('fetchMessages');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function loadMsg($email) {
|
|
|
|
|
$this->email = $email;
|
|
|
|
|
if (count($this->emails) == 0) {
|
|
|
|
|
$this->emails = [$email];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function syncEmail($email) {
|
|
|
|
|
$this->email = $email;
|
|
|
|
|
if (count($this->emails) == 0) {
|
|
|
|
|
$this->emails = [$email];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function setDomain($domain) {
|
|
|
|
|
$this->domain = $domain;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function checkReCaptcha3($token, $action) {
|
|
|
|
|
$response = Http::post('https://www.google.com/recaptcha/api/siteverify?secret=' . config('app.settings.recaptcha3.secret_key') . '&response=' . $token);
|
|
|
|
|
$data = $response->json();
|
|
|
|
|
if ($data['success']) {
|
|
|
|
|
$captcha = $data['score'];
|
|
|
|
|
if ($captcha > 0.5) {
|
|
|
|
|
if ($action == 'create') {
|
|
|
|
|
$this->create();
|
|
|
|
|
} else {
|
|
|
|
|
$this->random();
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
return $this->showAlert('error', __('Captcha Failed! Please try again'));
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
return $this->showAlert('error', __('Captcha Failed! Error: ') . json_encode($data['error-codes']));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public function create() {
|
|
|
|
|
if (!$this->user) {
|
|
|
|
|
return $this->showAlert('error', __('Please enter Username'));
|
|
|
|
|
}
|
|
|
|
|
$this->checkDomainInUsername();
|
|
|
|
|
if (strlen($this->user) < config('app.settings.custom.min') || strlen($this->user) > config('app.settings.custom.max')) {
|
|
|
|
|
return $this->showAlert('error', __('Username length cannot be less than') . ' ' . config('app.settings.custom.min') . ' ' . __('and greater than') . ' ' . config('app.settings.custom.max'));
|
|
|
|
|
}
|
|
|
|
|
if (!$this->domain) {
|
|
|
|
|
return $this->showAlert('error', __('Please Select a Domain'));
|
|
|
|
|
}
|
|
|
|
|
if (in_array($this->user, config('app.settings.forbidden_ids'))) {
|
|
|
|
|
return $this->showAlert('error', __('Username not allowed'));
|
|
|
|
|
}
|
|
|
|
|
if (!$this->checkEmailLimit()) {
|
|
|
|
|
return $this->showAlert('error', __('You have reached daily limit of MAX ') . config('app.settings.email_limit', 5) . __(' temp mail'));
|
|
|
|
|
}
|
|
|
|
|
if (!$this->checkUsedEmail()) {
|
|
|
|
|
return $this->showAlert('error', __('Sorry! That email is already been used by someone else. Please try a different email address.'));
|
|
|
|
|
}
|
|
|
|
|
if (!$this->validateCaptcha()) {
|
|
|
|
|
return $this->showAlert('error', __('Invalid Captcha. Please try again'));
|
|
|
|
|
}
|
|
|
|
|
$this->email = ZEmail::createCustomEmail($this->user, $this->domain);
|
|
|
|
|
$this->redirect(route('mailbox'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function random() {
|
|
|
|
|
if (!$this->checkEmailLimit()) {
|
|
|
|
|
return $this->showAlert('error', __('You have reached daily limit of maximum ') . config('app.settings.email_limit', 5) . __(' temp mail addresses.'));
|
|
|
|
|
}
|
|
|
|
|
if (!$this->validateCaptcha()) {
|
|
|
|
|
return $this->showAlert('error', __('Invalid Captcha. Please try again'));
|
|
|
|
|
}
|
|
|
|
|
$this->email = ZEmail::generateRandomEmail();
|
|
|
|
|
$this->redirect(route('mailbox'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function tempgmail() {
|
|
|
|
|
if (!$this->checkEmailLimit()) {
|
|
|
|
|
return $this->showAlert('error', __('You have reached daily limit of maximum ') . config('app.settings.email_limit', 5) . __(' temp mail addresses.'));
|
|
|
|
|
}
|
|
|
|
|
if (!$this->validateCaptcha()) {
|
|
|
|
|
return $this->showAlert('error', __('Invalid Captcha. Please try again'));
|
|
|
|
|
}
|
|
|
|
|
$this->email = ZEmail::generateRandomGmail();
|
|
|
|
|
$this->redirect(route('mailbox'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function deleteEmail() {
|
|
|
|
|
ZEmail::removeEmail($this->email);
|
|
|
|
|
if (count($this->emails) == 1 && config('app.settings.after_last_email_delete') == 'redirect_to_homepage') {
|
|
|
|
|
return redirect()->route('home');
|
|
|
|
|
}
|
|
|
|
|
$this->email = ZEmail::getEmail(true);
|
|
|
|
|
$this->emails = ZEmail::getEmails();
|
|
|
|
|
return redirect()->route('mailbox');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function render() {
|
|
|
|
|
if (count($this->emails) >= intval(config('app.settings.email_limit', 5))) {
|
|
|
|
|
for ($i = 0; $i < (count($this->emails) - intval(config('app.settings.email_limit', 5))); $i++) {
|
|
|
|
|
ZEmail::removeEmail($this->emails[$i]);
|
|
|
|
|
}
|
|
|
|
|
$this->emails = ZEmail::getEmails();
|
|
|
|
|
ZEmail::setEmail($this->email);
|
|
|
|
|
}
|
|
|
|
|
return view('livewire.frontend.action');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Private Functions
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
private function showAlert($type, $message) {
|
|
|
|
|
$this->dispatchBrowserEvent('showAlert', ['type' => $type, 'message' => $message]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Don't allow used email
|
|
|
|
|
*/
|
|
|
|
|
private function checkUsedEmail() {
|
|
|
|
|
if (config('app.settings.disable_used_email', false)) {
|
|
|
|
|
$check = Log::where('email', $this->user . '@' . $this->domain)->where('ip', '<>', request()->ip())->count();
|
|
|
|
|
if ($check > 0) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Validate Captcha
|
|
|
|
|
*/
|
|
|
|
|
private function validateCaptcha() {
|
|
|
|
|
if (config('app.settings.captcha') == 'hcaptcha') {
|
|
|
|
|
$response = Http::asForm()->post('https://hcaptcha.com/siteverify', [
|
|
|
|
|
'response' => $this->captcha,
|
|
|
|
|
'secret' => config('app.settings.hcaptcha.secret_key')
|
|
|
|
|
])->object();
|
|
|
|
|
return $response->success;
|
|
|
|
|
} else if (config('app.settings.captcha') == 'recaptcha2') {
|
|
|
|
|
$response = Http::asForm()->post('https://www.google.com/recaptcha/api/siteverify', [
|
|
|
|
|
'response' => $this->captcha,
|
|
|
|
|
'secret' => config('app.settings.recaptcha2.secret_key')
|
|
|
|
|
])->object();
|
|
|
|
|
return $response->success;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Check if the user is crossing email limit
|
|
|
|
|
*/
|
|
|
|
|
private function checkEmailLimit() {
|
|
|
|
|
$logs = Log::select('ip', 'email')->where('ip', request()->ip())->where('created_at', '>', Carbon::now()->subDay())->groupBy('email')->groupBy('ip')->get();
|
|
|
|
|
if (count($logs) >= config('app.settings.email_limit', 5)) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Check if Username already consist of Domain
|
|
|
|
|
*/
|
|
|
|
|
private function checkDomainInUsername() {
|
|
|
|
|
$parts = explode('@', $this->user);
|
|
|
|
|
if (isset($parts[1])) {
|
|
|
|
|
if (in_array($parts[1], $this->domains)) {
|
|
|
|
|
$this->domain = $parts[1];
|
|
|
|
|
}
|
|
|
|
|
$this->user = $parts[0];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Validate if Domain in Email Exist
|
|
|
|
|
*/
|
|
|
|
|
private function validateDomainInEmail() {
|
|
|
|
|
$data = explode('@', $this->email);
|
|
|
|
|
if (isset($data[1])) {
|
|
|
|
|
$domain = $data[1];
|
|
|
|
|
$domains = config('app.settings.domains');
|
|
|
|
|
if (!in_array($domain, $domains)) {
|
|
|
|
|
$key = array_search($this->email, $this->emails);
|
|
|
|
|
TMail::removeEmail($this->email);
|
|
|
|
|
if ($key == 0 && count($this->emails) == 1 && config('app.settings.after_last_email_delete') == 'redirect_to_homepage') {
|
|
|
|
|
return redirect()->route('home');
|
|
|
|
|
} else {
|
|
|
|
|
return redirect()->route('mailbox');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|