Utwórz użytkownika programowo i nadaj mu rolę

46

Tworzę użytkownika programowo takiego:

$newUser = array(
  'name' => $mail, 
  'pass' => 'password',  // note: do not md5 the password
  'mail' => $mail, 
  'status' => 1, 
  'init' => $mail,
  'roles' => array(5)
);
$user = user_save(null, $newUser);

Mam rolę o identyfikatorze roli równym pięciu; kiedy tworzę użytkownika, w tabeli „users_roles” jest tylko wiersz o wartości 0 dla identyfikatora roli, ale jeśli wydrukuję obiekt użytkownika var_dump(), wygląda to tak, jakby role zostały utworzone.

Co ja robię źle?

Nicola Peluchetti
źródło
Sprawdza tylko prawdziwość wartości, klucz jest najważniejszy. array($role_id => 'anything')
RaisinBranCrunch

Odpowiedzi:

46

Ten kod działał dla mnie:

$new_user = array(
  'name' => $name,
  'pass' => $sifra, // note: do not md5 the password
  'mail' => $email,
  'status' => 1,
  'init' => $email,
  'roles' => array(
    DRUPAL_AUTHENTICATED_RID => 'authenticated user',
    3 => 'custom role',
  ),
);

// The first parameter is sent blank so a new user is created.
user_save('', $new_user);
Nebojsa
źródło
Czy powinienem napisać hasło hasło takie jak „abc12345” i user_save () przekonwertuje się na md5?
xstean,
1
user_savezajmie się tym
Gulok
Tak długo, jak hasło jest user_save()drugim argumentem, będzie mieszane. Jeśli zrobisz to user_save($account)bez $editargumentu, konwersja md5 nie nastąpi. Odpowiedź @SMTF poniżej to pokazuje.
alec
Dzięki uratowałem mój dzień
Rishab,
13

To przykład znalazłem na stronie.

$account = new stdClass;
$account->is_new = TRUE;
$account->name = 'foo';
$account->pass = user_hash_password('bar');
$account->mail = '[email protected]';
$account->init = '[email protected]';
$account->status = TRUE;
$account->roles = array(DRUPAL_AUTHENTICATED_RID => TRUE);
$account->timezone = variable_get('date_default_timezone', '');
user_save($account);
SMTF
źródło
Przepraszam, myślę, że DRUPAL_AUTHENTICATED_RID => PRAWDA wydaje się błędna i nie sądzę, że hasło użytkownika_hash_hash jest potrzebne.
stefgosselin
user_hash_password('bar');jest źle
Joel James,
Są przypadki, w których user_save()hasło nie jest hashowane przed ich zapisaniem (z własnego doświadczenia i widzę, że inni w sieci również go czasami doświadczają). Nie wiem dlaczego (ale chciałbym!). W takich przypadkach dzwonienie user_hash_password()wydaje się konieczne.
alec
Kod w tej odpowiedzi nie wymaga user_hash_password()się nazywać ręcznie. To dlatego, że nie przechodzi $editdo user_save(). Jeśli kod zawiera $edit = array('pass' => 'bar');(czego nie ma w tej odpowiedzi), to zamiast tego $account->pass = user_hash...możesz zrobić user_save($account, $edit);i user_save()zaszyfrować.
alec
13

Aby programowo utworzyć użytkownika z rolami i niestandardowymi wartościami pól (np. Imię i Nazwisko), możesz użyć następującego kodu:

$new_user = array(
  'name' => 'xgramp',
  'pass' => 'idontwantnoonebutyoutoloveme',
  'mail' => '[email protected]',
  'signature_format' => 'full_html',
  'status' => 1,
  'language' => 'en',
  'timezone' => 'America/Los_Angeles',
  'init' => 'Email',
  'roles' => array(
    DRUPAL_AUTHENTICATED_RID => 'authenticated user',
    6 => 'member', // role id for custom roles varies per website
  ),
  'field_first_name' => array(
    'und' => array(
      0 => array(
        'value' => 'Gram',
      ),
    ),
  ),
  'field_last_name' => array(
    'und' => array(
      0 => array(
        'value' => 'Parsons',
      ),
    ),
  ),
);

$account = user_save(NULL, $new_user);

Zobacz ten post na blogu i komentarze, aby uzyskać więcej informacji: http://codekarate.com/blog/create-user-account-drupal-7-programmatically

batigolix
źródło
Brakowało Ci nawiasu w tablicy ról
SeanJA
2

Aby utworzyć użytkownika programowo z adresu e-mail, spróbuj tego:

// Use the e-mail address prefix as a user name.
$name = substr($mail, 0, strpos($mail, '@'));

// Make sure the user name isn't already taken.
$query = db_select('users', 'u')
  ->fields('u', array('uid'))
  ->condition('u.name', $name)
  ->execute();
$result = $query->fetch();

// If the user name is taken, append a random string to the end of it.
if ($result->uid) { $name .= '-' . user_password(); }

// Build the user account object and then save it.
$account = new stdClass();
$account->name = $name;
$account->mail = $mail;
$account->init = $mail;
$account->pass = user_password();
$account->status = 1;
user_save($account);
if ($account->uid) {
  drupal_set_message('Created new user with id %uid', array('%uid' => $account->uid));
}
tyler.frankenstein
źródło
0

Aby utworzyć użytkownika programowo:

$newUser = array(
      'name' => 'theUserName,
      'pass' => 'thePassWord',
      'mail' => 'the@mail.com',
      'status' => 1,
      'roles' => array(DRUPAL_AUTHENTICATED_RID => 'authenticated user'),
      'init' =>  'the@mail.com',
  );
user_save(null, $newUser);
houmem
źródło