PHP - Как удалить повторяющиеся значения из массива (сравните 2 массива) - PullRequest
0 голосов
/ 23 декабря 2018

Я хотел бы удалить значения из массива $allPermissions, которые находятся в массиве $userPermissions.

Как это сделать?Я уже объединил array_unique, array_diff, и до сих пор не пришел, чтобы решить эту проблему.Кто-то что-то?

public function notAssigned($id, Request $request)
{
    $user = User::findOrFail($id);
    $userPermissions = [{"id":5,"name":"create post","guard_name":"web","created_at":"2018-12-22 02:44:35","updated_at":"2018-12-22 02:44:35","pivot":{"model_id":3,"permission_id":5,"model_type":"App\\User"}}];
    $allPermissions = [{"id":5,"name":"create post","guard_name":"web","created_at":"2018-12-22 02:44:35","updated_at":"2018-12-22 02:44:35"},{"id":6,"name":"edit post","guard_name":"web","created_at":"2018-12-22 02:44:46","updated_at":"2018-12-22 02:44:46"},{"id":7,"name":"delete post","guard_name":"web","created_at":"2018-12-22 02:44:59","updated_at":"2018-12-22 02:44:59"}];

    $permissions = array_unique(array_merge($userPermissions, $allPermissions));
    $role = auth()->user()->hasRole([2]);
    $permission = auth()->user()->can('edit user permission');

    if ( $role == true || $permission == true ) {
        return $permissions;
    } else {
        abort(403, 'Access Denied');
    }
}

РЕДАКТИРОВАТЬ:

Это выходные данные var_dump до $userPermissions и $allPermissionsallPermissions:

var_dump($userPermissions):

    array(1) { [0]=> object(stdClass)#361 (6) { ["id"]=> int(5) ["name"]=> string(11) "create post" ["guard_name"]=> string(3) "web" ["created_at"]=> string(19) "2018-12-22 02:44:35" ["updated_at"]=> string(19) "2018-12-22 02:44:35" ["pivot"]=> object(stdClass)#360 (3) { ["model_id"]=> int(3) ["permission_id"]=> int(5) ["model_type"]=> string(8) "App\User" } } }

var_dump($allPermissions):

    array(3) { [0]=> object(stdClass)#374 (5) { ["id"]=> int(5) ["name"]=> string(11) "create post" ["guard_name"]=> string(3) "web" ["created_at"]=> string(19) "2018-12-22 02:44:35" ["updated_at"]=> string(19) "2018-12-22 02:44:35" } [1]=> object(stdClass)#377 (5) { ["id"]=> int(6) ["name"]=> string(9) "edit post" ["guard_name"]=> string(3) "web" ["created_at"]=> string(19) "2018-12-22 02:44:46" ["updated_at"]=> string(19) "2018-12-22 02:44:46" } [2]=> object(stdClass)#376 (5) { ["id"]=> int(7) ["name"]=> string(11) "delete post" ["guard_name"]=> string(3) "web" ["created_at"]=> string(19) "2018-12-22 02:44:59" ["updated_at"]=> string(19) "2018-12-22 02:44:59" } }

1 Ответ

0 голосов
/ 23 декабря 2018

Предполагая, что ваш массив верен, вы можете использовать array-filter для этого:

$userP = '[{"id":5,"name":"create post","guard_name":"web","created_at":"2018-12-22 02:44:35","updated_at":"2018-12-22 02:44:35"}]';
$userPermissions = json_decode($userP, true); // will convert to array.

$allP = '[{"id":5,"name":"create post","guard_name":"web","created_at":"2018-12-22 02:44:35","updated_at":"2018-12-22 02:44:35"},{"id":6,"name":"edit post","guard_name":"web","created_at":"2018-12-22 02:44:46","updated_at":"2018-12-22 02:44:46"},{"id":7,"name":"delete post","guard_name":"web","created_at":"2018-12-22 02:44:59","updated_at":"2018-12-22 02:44:59"}]';
$allPermissions = json_decode($allP , true); // will convert to array.

$userPermissionIds = array_column($userPermissions, "id")
$filteredPermission = array_filter($allPermissions , function($elem) use ($userPermissionIds) {
    return !in_array($elem["id"], $userPermissionIds);
});  

В результате $filteredPermission будет содержать только элемент, который не существует в разрешении пользователямассив

Отредактировано : Если вы хотите остаться с вашим массивом объектов, вы можете использовать:

$userPermissionIds = array();
foreach($userPermissions as $per)
    $userPermissionIds[] = $per->id;

$filteredPermission = array_filter($allPermissions , function($elem) use ($userPermissionIds) {
    return !in_array($elem->id, $userPermissionIds);
});
...