Files
api-extranetwork/app/Core/Service/UserService.php
ExtraNetwork e5c4b6aa13 first commit
2026-05-12 17:04:54 +03:00

519 lines
18 KiB
PHP

<?php
namespace App\Core\Service;
use App\Core\Repository\User\UserRepository;
use Illuminate\Http\Request;
use App;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Facades\Config;
use Exception;
use App\Exceptions\ApiErrorException;
use App\Core\Validator\User\UserCreateValidator;
use App\Core\Validator\User\UserNewPasswordValidator;
use App\Core\Validator\User\ChangePasswordValidator;
use App\Core\Validator\User\ResetPasswordValidator;
use Illuminate\Support\Str;
use App\Core\Validator\User\UserProfileUpdateValidator;
class UserService
{
private $request ;
private $userRepository ;
private $userCreateValidator ;
private $userNewPasswordValidator;
private $changePasswordValidator;
private $resetPasswordValidator ;
private $profileUpdateValidator;
public function __construct
(
Request $request,
ResetPasswordValidator $resetPasswordValidator,
UserRepository $userRepository,
UserNewPasswordValidator $userNewPasswordValidator,
ChangePasswordValidator $changePasswordValidator,
UserCreateValidator $userCreateValidator,
UserProfileUpdateValidator $profileUpdateValidator
)
{
$this->request = $request;
$this->userRepository = $userRepository;
$this->userCreateValidator = $userCreateValidator;
$this->userNewPasswordValidator = $userNewPasswordValidator;
$this->changePasswordValidator = $changePasswordValidator;
$this->resetPasswordValidator = $resetPasswordValidator;
$this->profileUpdateValidator = $profileUpdateValidator;
}
/*
*
select
create
update
delete
* */
public function select($param = [], $column = ['*'])
{
$response = ['status' => -1, 'message' => '', 'data' => null];
try {
$data = $this->userRepository->findByCriteria($param, $column);
if(!$data){
throw new ApiErrorException(lang('An unknown error occurred'));
}
$response['status'] = 1;
$response['data'] = $data;
} catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function create($param = [])
{
$response = ['status' => -1, 'message' => '', 'data' => null];
try {
// Todo add permission
$userData =
[
"gender" => fillOnUndefined($param, "gender"),
"name" => fillOnUndefined($param, "name"),
"surname" => fillOnUndefined($param, "surname"),
"phone" => fillOnUndefined($param, "phone"),
"language" => fillOnUndefined($param, "language"),
"email" => fillOnUndefined($param, "email"),
"password" => Str::random(6),
"hash_key" => hash('sha512', Str::random(32) ),
"status" => fillOnUndefined($param, "status", 0),
"created_by" => fillOnUndefined($param, "user_id", 1),
"updated_by" => fillOnUndefined($param, "user_id", 1),
"created_at" => time(),
"updated_at" => time(),
];
$validationResult = $this->userCreateValidator->validate($userData);
if ($validationResult->errors()->first()) {
$errors = $validationResult->errors()->all();
throw new ApiErrorException($errors);
}
$userPassword = $userData['password'] ;
$userData['password'] = Hash::make($userData['password']) ;
$userCreateResult = $this->userRepository->create($userData);
if ($userCreateResult['status'] != 'success') {
throw new Exception('api-unknown_error');
}
$response['status'] = 1;
$userCreateResult["data"]["userPassword"] = $userPassword;
$response['data'] = $userCreateResult["data"];
} catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function update($param = [])
{
$response = ['status' => -1, 'message' => '', 'data' => null ];
try {
// Todo add permission
$userUpdateData = fillOnUndefined($param, 'user_update_data', []) ;
$validateKeys = ['name', 'surname', 'gender', 'phone', 'password', 'status'];
$updateData = [] ;
foreach ($userUpdateData as $key => $value){
if(!in_array($key,$validateKeys)){
throw new ApiErrorException(lang('Disallowed field'));
}
$updateData[$key] = $value ;
if($key == 'password'){
$updateData['password'] = Hash::make($value) ;
}
}
if($updateData){
$updateData['updated_by'] = $param['user_id'] ;
}
$userUpdateResult = $this->userRepository->update($param['update_user_id'], $updateData);
if ($userUpdateResult['status'] != 'success') {
throw new Exception('api-unknown_error');
}
$response['status'] = 1;
$response['data'] = $userUpdateResult["data"];
} catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
private function _updateUserProfile($id, $param = [])
{
$response = ['status' => -1, 'message' => '', 'data' => null];
try {
$updateResult = $this->userRepository->update($id, $param);
if ($updateResult['status'] != 'success') {
throw new Exception('api-unknown_error');
}
$updateData = $updateResult["data"];
$response = [
'status' => true,
'data' => $updateData,
];
} catch (ApiErrorException $e) {
$response['message'] = implode(', ', $e->getMessageArr());
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function forgotPassword($params = [])
{
$response = ['status' => -1, 'message' => '', 'data' => null ];
try {
$userCriteria = [
'criteria' => [
['field' => 'email', 'condition' => '=', 'value' => $params['email']],
],
'firstRow' => 1
];
$findUser = $this->select($userCriteria);
if (!$findUser['status'] || !$findUser['data']) {
throw new ApiErrorException(lang('User not found'));
}
$findUser = $findUser['data'] ;
$hashKey = hash('sha512', Str::random(32) );
$updateParams = [
'hash_key' => $hashKey,
'updated_by' => $findUser['id'],
'updated_at' => time()
];
$userUpdateResult = $this->userRepository->update($findUser['id'], $updateParams);
if ($userUpdateResult['status'] != 'success') {
throw new Exception('api-unknown_error');
}
$userData = $userUpdateResult["data"];
$response = [
'status' => 1,
'data' => $userData,
];
} catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function resetPassword($params = [])
{
$response = ['status' => -1, 'message' => '', 'data' => null];
try {
$validationResult = $this->resetPasswordValidator->validate($params);
if ($validationResult->errors()->first()) {
$errors = $validationResult->errors()->all();
throw new ApiErrorException($errors);
}
$userCriteria = [
'criteria' => [
['field' => 'email', 'condition' => '=', 'value' => $params['email']],
['field' => 'hash_key', 'condition' => '=', 'value' => $params['hash_key']],
],
'firstRow' => 1
];
$findUser = $this->select($userCriteria);
if (!$findUser['status'] || !$findUser['data']) {
throw new ApiErrorException(lang('User not found'));
}
$findUser = $findUser['data'] ;
$hashKey = hash('sha512', Str::random(32) );
$updateParams = [
'hash_key' => $hashKey,
'password' => Hash::make($params['password']),
'updated_by' => $findUser['id'],
'updated_at' => time()
];
$userUpdateResult = $this->userRepository->update($findUser['id'], $updateParams);
if ($userUpdateResult['status'] != 'success') {
throw new Exception('api-unknown_error');
}
$response['status'] = 1;
$response['data'] = $userUpdateResult["data"];
} catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function findUser($id)
{
return $this->userRepository->find($id);
}
public function checkUserKey($params){
$response = ['status' => -1, 'message' => '', 'data' => null];
try{
$userCriteria = [
'criteria' => [
['field' => 'email' , 'condition' => '=' , 'value' => $params['email'] ],
['field' => 'hash_key' , 'condition' => '=' , 'value' => $params['key'] ],
],
'firstRow' => true,
];
$userData = $this->userRepository->findByCriteria($userCriteria, ['id', 'name', 'surname', 'email', 'hash_key', 'status']) ;
if(!$userData){
throw new ApiErrorException(lang('User not found')) ;
}
if($userData['status'] == 1){
throw new ApiErrorException(lang('This user already activated'));
}
$response['status'] = 1;
$response['data'] = $userData;
}catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
}catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function newPassword($params){
$response = ['status' => -1, 'message' => '', 'data' => null ];
try{
$userData = [
'email' => fillOnUndefined($params, 'email'),
'hash_key' => fillOnUndefined($params, 'hash_key'),
'password' => fillOnUndefined($params, 'password'),
'password_confirmation' => fillOnUndefined($params, 'password_confirmation'),
];
$validationResult = $this->userNewPasswordValidator->validate($userData);
if ($validationResult->errors()->first()) {
$errors = $validationResult->errors()->all();
throw new ApiErrorException($errors);
}
$userUpdateData = [
'password' => Hash::make($userData['password']) ,
'status' => 1 ,
'updated_by' => $params['user_id'],
'updated_at' => time()
];
$userData = $this->userRepository->update($params['user_id'], $userUpdateData) ;
if(!$userData){
throw new Exception('api-unknown_error');
}
$response['status'] = 1;
$response['data'] = $userData;
} catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
}catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function changePassword($params){
$response = ['status' => -1, 'message' => '', 'data' => null ];
try{
$userData = [
'user_id' => fillOnUndefined($params, 'user_id'),
'old_password' => fillOnUndefined($params, 'old_password'),
'password' => fillOnUndefined($params, 'password'),
'password_confirmation' => fillOnUndefined($params, 'password_confirmation'),
];
$validationResult = $this->changePasswordValidator->validate($userData);
if ($validationResult->errors()->first()) {
$errors = $validationResult->errors()->all();
throw new ApiErrorException($errors);
}
$userUpdateData = [
'password' => Hash::make($userData['password']) ,
'updated_by' => $params['user_id'],
'updated_at' => time()
];
$userData = $this->userRepository->update($userData['user_id'], $userUpdateData) ;
if(!$userData){
throw new Exception('api-unknown_error');
}
$response['status'] = 1;
$response['data'] = $userData;
} catch (ApiErrorException $e) {
$response['status'] = 0;
$response['message'] = implode(', ', $e->getMessageArr());
}catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
public function getProfile($params, $fields = ['*']){
$response = ['status' => false, 'message' => '', 'data' => null, 'statusCode' => 500];
try {
$profileRequest = [
'criteria' => [
['field' => 'id', 'condition' => '=', 'value' => $params['user_id']],
['field' => 'status', 'condition' => '=', 'value' => $params['status']],
],
'firstRow' => true
];
$profileData = $this->select($profileRequest, $fields);
$response = ['status' => 1, 'statusCode' => 200, 'message' => null, 'data' => $profileData['data'] ];
} catch (ApiErrorException $e) {
$response['message'] = implode(', ', $e->getMessageArr());
$response['statusCode'] = 400;
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
$response['statusCode'] = 500;
}
return output($response);
}
public function profileUpdate($params = []){
$response = ['status' => -1, 'message' => '', 'data' => null];
try {
$validationResult = $this->profileUpdateValidator->validate($params);
if ($validationResult->errors()->first()) {
$errors = $validationResult->errors()->all();
throw new ApiErrorException($errors);
}
$updateData =
[
'name' => fillOnUndefined($params, 'name'),
'surname' => fillOnUndefined($params, 'surname'),
'gender' => fillOnUndefined($params, 'gender'),
'language' => fillOnUndefined($params, 'language'),
'phone' => fillOnUndefined($params, 'phone'),
"updated_by" => fillOnUndefined($params, "user_id"),
"updated_at" => time()
];
$updateResult = $this->_updateUserProfile($params['user_id'], $updateData);
if ($updateResult['status'] != 'success') {
throw new ApiErrorException($updateResult['message']);
}
$userData = $updateResult["data"];
$response = [
'status' => true,
'data' => $userData,
];
} catch (ApiErrorException $e) {
$response['message'] = implode(', ', $e->getMessageArr());
} catch (Exception $e) {
$message = $e->getFile() . " " . $e->getLine() . " " . $e->getMessage();
Log::error($message);
$response['message'] = $e->getMessage();
}
return output($response);
}
}