Skip to content

Feature/core functions #50

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
76 changes: 76 additions & 0 deletions app/Http/Controllers/ProjectController.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
<?php

namespace App\Http\Controllers;
use Illuminate\Support\Facades\Gate;
use\Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;
use Illuminate\Http\Request;
use App\Models\Project;

class ProjectController extends Controller
{
function getprojects(Request $request){

$name=$request->q ? $request->q : '';
$pageIndex=$request->pageIndex ? $request->pageIndex : '0';
$pageSize=$request->pageSize ? $request->pageSize : '3';
$sortBy=$request->sortBy ? $request->sortBy : 'name';
$sortDirection=$request->sortDirection ? $request->sortDirection : 'ASC';
$project_query=$data="";

if($name){
$project_query=Project::where("name", "like","%".$name."%");

if($pageIndex){
$project_query->offset($pageIndex);
}
if($pageSize){
$project_query->limit($pageSize);
}
if($sortDirection){
$project_query->orderBy($sortBy, $sortDirection);
}
$result = $project_query->get();
$data = json_decode($result, true);
}

if(!empty($data)){
return $result;
}else{
return response()->json(['message'=>'No Data Found']);
}

}

function createproject(Request $req){
if(Gate::allows('isProductOwner')){
$input['name']=$req->input('name');
$input['product_owner_id']=$req->input('product_owner_id');
$project = Project::create($input);
return $project;
}else{
return response()->json(['message'=>'Only PRODUCT OWNER is Allowed']);
}
}

function updateproject(Request $req){
$project = Project::find($req->id);
if($project){
if(Gate::allows('updateProject',$project)){
$input = $req->all();
$result=$project->update($input);
if($result){
return response()->json(['message'=>'Successfully Updated']);
}else{
return response()->json(['message'=>'Update Failed']);
}
}else{
return response()->json(['message'=>'Only PRODUCT OWNER is Allowed']);
}
}else{
return response()->json(['message'=>'Invalid Project']);
}

}

}
89 changes: 89 additions & 0 deletions app/Http/Controllers/TaskController.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
<?php

namespace App\Http\Controllers;
use Illuminate\Support\Facades\Gate;
use\Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;
use Illuminate\Http\Request;
use App\Models\Task;
use App\Models\Project;

class TaskController extends Controller
{
function getTasks($id=null){
if($id){
$result = Task::find($id);
}else{
$result = Task::all();
}
$data = json_decode($result, true);
if(!empty($data)){
return $result;
}else{
return response()->json(['message'=>'No Data Found']);
}
}

function createtask(Request $req){
$project = Project::find($req->project_id);
if($project){
if(Gate::allows('taskCreateByOwner',$project)){
$input = $req->all();
$input['task_owner_id']=$project->product_owner_id;
$task = Task::create($input);
return $task;
}else{
return response()->json(['message'=>'Only PROJECT OWNER is Allowed']);
}
}else{
return response()->json(['message'=>'Invalid Project']);
}
}

function updatetask(Request $req){
$task = Task::find($req->id);
if($task){
if(Gate::allows('taskByOwner',$task)){
$input = $req->all();
$result=$task->update($input);
if($result){
return response()->json(['message'=>'Successfully Updated']);
}else{
return response()->json(['message'=>'Update Failed']);
}
}else if(Gate::allows('taskByTeamMember',$task)){
$task->status=$req->input('status');
$result=$task->save();
if($result){
return response()->json(['message'=>'Successfully Updated']);
}else{
return response()->json(['message'=>'Update Failed']);
}
}
else{
return response()->json(['message'=>'Only PROJECT OWNER OR TEAM MEMBER is Allowed']);
}
}else{
return response()->json(['message'=>'Invalid Task']);
}
}

function deletetask(Request $req){
$task = Task::find($req->id);
if($task){
if(Gate::allows('taskByOwner',$task)){
$result = $task->delete();
if($result){
return response()->json(['message'=>'Successfully Deleted']);
}else{
return response()->json(['message'=>'Delete Failed']);
}
}else{
return response()->json(['message'=>'Only PRODUCT OWNER is Allowed']);
}
}else{
return response()->json(['message'=>'Invalid Task']);
}
}

}
113 changes: 113 additions & 0 deletions app/Http/Controllers/UserController.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,113 @@
<?php

namespace App\Http\Controllers;
use Illuminate\Support\Facades\Gate;
use\Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;
use Illuminate\Http\Request;
use App\Models\User;

class UserController extends Controller
{
function getresources($id=null){
if(Gate::allows('isAdmin')){
if($id){
$result = User::find($id);
}else{
$result = User::all();
}
$data = json_decode($result, true);
if(!empty($data)){
return $result;
}else{
return response()->json(['message'=>'No Data Found']);
}
}else{
return response()->json(['message'=>'Only Admin is Allowed']);
}
}

function createresource(Request $req){
if(Gate::allows('isAdmin')){
$input = $req->all();
$input['password']=Hash::make($req->input('password'));
$user = User::create($input);
$response=[
'user'=>$user->name,
'email'=>$user->email,
'role'=>$user->role,
];
return response($response,201);
}else{
return response()->json(['message'=>'Only Admin is Allowed']);
}
}

function updateresource(Request $req){
$user = User::find($req->id);
if($user){
if(Gate::allows('isAdmin')){
$input = $req->all();
$result=$user->update($input);
if($result){
return response()->json(['message'=>'Successfully Updated']);
}else{
return response()->json(['message'=>'Update Failed']);
}
}else{
return response()->json(['message'=>'Only Admin is Allowed']);
}
}else{
return response()->json(['message'=>'Invalid User']);
}
}

function deleteresource(Request $req){
$user = User::find($req->id);
if($user){
if(Gate::allows('isAdmin')){
$result = $user->delete();
if($result){
return response()->json(['message'=>'Successfully Deleted']);
}else{
return response()->json(['message'=>'Delete Failed']);
}
}else{
return response()->json(['message'=>'Only Admin is Allowed']);
}
}else{
return response()->json(['message'=>'Invalid User']);
}
}

function registerUser(Request $req){
$user = new User;
$user->name=$req->input('name');
$user->email=$req->input('email');
$user->password=Hash::make($req->input('password'));
$user->save();
$response=[
'user'=>$user->name,
'email'=>$user->email,
'role'=>$user->role,
];
return response($response,201);
}


function login(Request $req){
$user = User::where('email', $req->email)->first();
if (!$user || !Hash::check($req->password, $user->password)) {
return response([
'message' => ['These credentials do not match our records.']
], 404);
}
$token = $user->createToken('my-app-token')->plainTextToken;
$response = [
'user' => $user,
'token' => $token
];
return response($response, 201);
}

}
2 changes: 1 addition & 1 deletion app/Http/Kernel.php
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ class Kernel extends HttpKernel
],

'api' => [
// \Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class,
\Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class,
'throttle:api',
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
Expand Down
19 changes: 19 additions & 0 deletions app/Models/Project.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Notifications\Notifiable;
use App\Traits\UUID;

class Project extends Model
{
use HasFactory, Notifiable, UUID;

protected $fillable = [
'name',
'product_owner_id',
];

}
20 changes: 20 additions & 0 deletions app/Models/Task.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
<?php

namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use App\Traits\UUID;
class Task extends Model
{
use HasFactory, UUID;

protected $fillable = [
'title',
'description',
'status',
'project_id',
'team_member_id',
'task_owner_id',
];

}
13 changes: 5 additions & 8 deletions app/Models/User.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,11 @@
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
use Laravel\Sanctum\HasApiTokens;
use App\Traits\UUID;

class User extends Authenticatable
{
use HasApiTokens, HasFactory, Notifiable;
use HasApiTokens, HasFactory, Notifiable, UUID;

/**
* The attributes that are mass assignable.
Expand All @@ -21,24 +22,20 @@ class User extends Authenticatable
'name',
'email',
'password',
'role',
];

/**
* The attributes that should be hidden for serialization.
*
* @var array<int, string>
*/
protected $hidden = [
'password',
'remember_token',
];


/**
* The attributes that should be cast.
*
* @var array<string, string>
*/
protected $casts = [
'email_verified_at' => 'datetime',
];

}
Loading