mirror of
https://github.com/Bubka/2FAuth.git
synced 2025-02-23 22:01:49 +01:00
Add Group model & controller
This commit is contained in:
parent
8dfa6d19fe
commit
273aaa9840
49
app/Group.php
Normal file
49
app/Group.php
Normal file
@ -0,0 +1,49 @@
|
||||
<?php
|
||||
|
||||
namespace App;
|
||||
|
||||
use App\Classes\Options;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class Group extends Model
|
||||
{
|
||||
|
||||
/**
|
||||
* model's array form.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $fillable = ['name'];
|
||||
|
||||
|
||||
/**
|
||||
* The accessors to append to the model's array form.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $appends = ['isActive'];
|
||||
|
||||
|
||||
/**
|
||||
* Get the TwoFAccounts of the group.
|
||||
*/
|
||||
public function twofaccounts()
|
||||
{
|
||||
return $this->hasMany('App\TwoFAccount');
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Get the group
|
||||
*
|
||||
* @return integer
|
||||
*/
|
||||
public function getIsActiveAttribute()
|
||||
{
|
||||
$activeGroupId = intval(Options::get('activeGroup'));
|
||||
|
||||
return $this->id === $activeGroupId ? true : false;
|
||||
}
|
||||
|
||||
}
|
137
app/Http/Controllers/GroupController.php
Normal file
137
app/Http/Controllers/GroupController.php
Normal file
@ -0,0 +1,137 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Group;
|
||||
use App\TwoFAccount;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class GroupController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
// The index method has to return the complete collection of groups
|
||||
// stored in db plus a pseudo group corresponding to 'all'
|
||||
|
||||
// Get the stored groups
|
||||
$groups = Group::withCount('twofaccounts')->get();
|
||||
|
||||
// Create the pseudo group
|
||||
$allGroup = new Group([
|
||||
'name' => __('commons.all')
|
||||
]);
|
||||
|
||||
$allGroup->id = 0;
|
||||
$allGroup->twofaccounts_count = TwoFAccount::count();
|
||||
|
||||
// Merge them all
|
||||
$groups->prepend($allGroup);
|
||||
|
||||
return response()->json($groups->toArray());
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
|
||||
$this->validate($request, [
|
||||
'name' => 'required|string|max:32|unique:groups',
|
||||
]);
|
||||
|
||||
$group = Group::create([
|
||||
'name' => $request->name,
|
||||
]);
|
||||
|
||||
return response()->json($group, 201);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param \App\Group $group
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show(Group $group)
|
||||
{
|
||||
return response()->json($group, 200);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \App\Group $twofaccount
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
|
||||
$this->validate($request, [
|
||||
'name' => 'required|string|max:32|unique:groups',
|
||||
]);
|
||||
|
||||
// Here we catch a possible missing model exception in order to
|
||||
// delete orphan submited icon
|
||||
try {
|
||||
|
||||
$group = Group::FindOrFail($id);
|
||||
|
||||
} catch (\Illuminate\Database\Eloquent\ModelNotFoundException $e) {
|
||||
|
||||
throw $e;
|
||||
}
|
||||
|
||||
$group->update([
|
||||
'name' => $request->name,
|
||||
]);
|
||||
|
||||
return response()->json($group, 200);
|
||||
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Associate the specified accounts with the group
|
||||
*
|
||||
* @param \App\Group $group
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function associateAccounts(Request $request)
|
||||
{
|
||||
|
||||
$twofaccounts = TwoFAccount::find($request->input('accountsIds'));
|
||||
$group = Group::FindOrFail($request->input('groupId'));
|
||||
|
||||
$group->twofaccounts()->saveMany($twofaccounts);
|
||||
|
||||
return response()->json($group, 200);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param \App\Group $group
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy(Group $group)
|
||||
{
|
||||
$group->delete();
|
||||
|
||||
return response()->json(null, 204);
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user