4

PHP 経由で 100 € 以上の金額を購入したメンバーに、一種の「プレミアム ステータス」を割り当てる必要があります。

条件付きアクションは既に設定されています (ユーザー = 匿名/認証済み AND 合計金額 = 等しい/100 以上 AND ユーザー =! プレミアム) が、実際に「彼にプレミアム メンバーシップを付与する」と言う PHP の部分がありません。

どうすればこれを達成できますか?

編集:以下のコードは正しいですか?

if ($account) {
  $uid = $account->uid;
  $role_name = 'authenticated user';
  $rid = db_result(db_query("SELECT rid FROM {role} WHERE name = '%s'", $role_name));
  db_query("INSERT INTO {users_roles} (uid, rid) VALUES(%d, %d)", $uid, $rid);
  watchdog('user', 'uc ca added role to Ubercart created user');
}
4

4 に答える 4

6

user_load()と でこれを行うことができますuser_save()

$uid = 1; // UID of user to add role to
$role_name = 'test role'; // Name of role to add

// Get RID of role
$rid = db_result(db_query("SELECT r.rid FROM {role} r WHERE r.name = '%s'", $role_name));

// Load user object
$account = user_load(array('uid' => 1));

// Save the user object with the new roles.
if ($account !== FALSE && !isset($account->roles[$rid])) {
  $roles = $account->roles + array($rid => $role_name);
  user_save($account, array('roles' => $roles));
}

複数のユーザーに対して一括でこれを行いたい場合は、次の方法がありますuser_multiple_role_edit()

$uids = array(1, 2, 3, 4); // UIDs of users to add role to
$role_name = 'test role'; // Name of role to add

// Get RID of role
$rid = db_result(db_query("SELECT r.rid FROM {role} r WHERE r.name = '%s'", $role_name));

// Add the role to UIDs
user_multiple_role_edit($uids, 'add_role', $rid);

編集

現在のユーザーに対してこれを実行したい場合 (コメントで言及したチェックの一部のように)、次のことができます。

// Check for value over 100.00
if ($total_value > 100) {
  global $user; // Retrieve user object for currently logged in user.

  $role_name = 'test role'; // Name of role to add

  // Get RID of role
  $rid = db_result(db_query("SELECT r.rid FROM {role} r WHERE r.name = '%s'", $role_name));

  // Save the user object with the new role.
  if (!isset($user->roles[$rid])) {
    $roles = $user->roles + array($rid => $role_name);
    user_save($user, array('roles' => $roles));
  }
}
// Other code here.
于 2010-08-20T18:11:05.277 に答える
3

Just though I'd update the snippet for Drupal 7. Otherwise it works fine :)

$rid = db_query("SELECT r.rid FROM {role} r WHERE r.name = :rname", 
                array(':rname' => $role_name))->fetchField();
于 2013-03-12T16:03:28.647 に答える
2

私はむしろuser_role_load_by_name関数を使用したいと思います。

于 2013-05-21T23:31:02.463 に答える