Créer un utilisateur administrateur par programmation dans Magento 2.0

8

Il est simple d'ajouter un nouvel utilisateur administrateur dans Magento 1.9

<?php
require_once('app/Mage.php');
umask(0);
Mage::app();

$user = Mage::getModel('admin/user')
    ->setData(array(
        'username'  => 'admin',
        'firstname' => 'admin',
        'lastname'  => 'admin',
        'email'     => '[email protected]',
        'password'  => 'hacker@123',
        'is_active' => 1
    ))
    ->save();

$user->setRoleIds(array(1))
    ->setRoleUserId($user->getUserId())
    ->saveRelations();

echo "User has been created successfully!";

?>

Mais comment puis-je ajouter un utilisateur administrateur dans Magento 2.0?

Prahlad
la source
1
Vous avez marqué cela avec magento-2.1 mais mentionnez Magento 2.0 dans le texte. Laquelle est-ce? Il existe une balise générique magento2 que vous pouvez utiliser.

Réponses:

8

Vous pouvez créer un utilisateur à l'aide de userFactory

/**
 * User model factory
 *
 * @var \Magento\User\Model\UserFactory
 */    
protected $_userFactory;

public function __construct(
    \Magento\User\Model\UserFactory $userFactory,
) {
    $this->_userFactory = $userFactory;
}

public function execute(){

    $adminInfo = [
        'username'  => 'killer',
        'firstname' => 'admin',
        'lastname'    => 'admin',
        'email'     => '[email protected]',
        'password'  =>'hello@123',       
        'interface_locale' => 'en_US',
        'is_active' => 1
    ];

    $userModel = $this->_userFactory->create();
    $userModel->setData($adminInfo);
    $userModel->setRoleId(1);
    try{
       $userModel->save(); 
    } catch (\Exception $ex) {
        $ex->getMessage();
    }
}

Vous pouvez également consulter la façon dont magento crée une source git utilisateur

Priyank
la source
L'URL git partagée est 404
Gagan
Modification de l'URL
Priyank
7

Vous pouvez créer l'utilisateur administrateur en exécutant la commande suivante via SSH au niveau du répertoire racine.

php bin/magento admin:user:create --admin-user="admin" --admin-firstname="Admin" --admin-lastname="A" --admin-email="[email protected]" --admin-password="admin@5252"
sandip
la source
De cette façon, comment pouvez-vous définir le rôle?
slayerbleast
Pas sûr de devoir vérifier
sandip
1
parfait fait ma journée !!! +1 :)
SagarPPanchal
2

Créez un fichier dans le répertoire racine. par ex. admin.php

<?php 
use Magento\Framework\App\Bootstrap;
require 'app/bootstrap.php';
$bootstrap = Bootstrap::create(BP, $_SERVER);
$objectManager = $bootstrap->getObjectManager();
$UserFactory = $objectManager->get('\Magento\User\Model\UserFactory');

    try{
        $adminInfo = [
        'username'  => 'magento',
        'firstname' => 'magento',
        'lastname'    => 'magento',
        'email'     => '[email protected]',
        'password'  =>'magento@123',       
        'interface_locale' => 'en_US',
        'is_active' => 1
    ];

    $userModel = $UserFactory->create();
    $userModel->setData($adminInfo);
    $userModel->setRoleId(1);
    $userModel->save(); 

    } catch (\Exception $ex) {
        echo $ex->getMessage();
         exit;
    }
    echo "User is sucessfully created!"
?>
Ishvar Patel
la source
1

S'il s'agit d'une utilisation unique ou si vous en avez besoin pendant le développement, vous pouvez également exécuter les commandes mysql ci-dessous sur phpMyAdmin ou la ligne de commande mysql pour créer un utilisateur administrateur.

LOCK TABLES `admin_role` WRITE , `admin_user` WRITE;
SET @SALT = "rp";
SET @PASS = CONCAT(MD5(CONCAT( @SALT , "password") ), CONCAT(":", @SALT ));
SELECT @EXTRA := MAX(extra) FROM admin_user WHERE extra IS NOT NULL;
INSERT INTO `admin_user` (firstname,lastname,email,username,password,created,lognum,reload_acl_flag,is_active,extra,rp_token_created_at) 
VALUES ('Firstname','Lastname','[email protected]','adminuser',@PASS,NOW(),0,0,1,@EXTRA,NOW());
INSERT INTO `admin_role` (parent_id,tree_level,sort_order,role_type,user_id,role_name) 
VALUES (1,2,0,'U',(SELECT user_id FROM admin_user WHERE username = 'adminuser'),'Firstname');
UNLOCK TABLES;

Trouvez l'explication et plus de détails ici

J'espère que cela aide les personnes qui recherchent un problème / une solution similaire.

nikin
la source