The first thing I noticed is that the documentation for user_save() is not exactly stellar.
Fine, but is this where I should be putting my new user's information, or perhaps I should use the next parameter?
$array An array of fields and values to save. For example array('name' => 'My name'); Setting a field to NULL deletes it from the data column.
Ok, fine. Maybe I should use this one for adding my new user data. This doesn't mention anything about the profile fields though, or explain what I should be doing with the $account parameter. Maybe there's something else?
What? Category? Now I'm really confused. There's nothing obvious in user_save() that suggests how the profile fields get saved, or even where to put the profile fields. My only real clue is the call to user_module_invoke() towards the end of the function. This calls hook_user() in all the active modules on the site, and the one I'm interested in is the profile module, so my next stop was profile_user(). In turn, this calls profile_save_profile() with the details from the original call to user_save().
It was at this stage that I noticed that $category must refer to the various groups that profile information can be put in. For example, you can create a category for personal information, and one for notification preferences, and doing so will split the fields onto different tabs when the user edits his or her profile. Unfortunately, $category is a string, not an array, so for each call to profile_save_profile(), only one category can be changed.
Because profile_save_profile() is only called once per user_save(), it appears that when creating a user, it is only possible to create profile fields in one group! This causes a problem for me because I needed to import lots of profile fields in several groups.
My solution was to temporarily move all the profile fields into a single group. Once I had done that, I could populate $array with the information destined for the {users} table and the profile fields (this was not documented anywhere). It turns out I could just use NULL for $account (again, this was not documented).
Surely this is not the ideal way of creating new users programatically. My solution does work, but it is annoying and time-consuming. Is there another way to create users with profile fields in multiple categories?
2 comments:
not tested, please consider to be pseudo code
//$key corresponds to fid in profile_values table
if ($uid>0)
{
db_query('DELETE FROM {profile_values} WHERE uid = %d', $uid);
}
foreach($profile_fieldArray as $key=>$value){
if (strlen($value)>0){
db_query('INSERT INTO {profile_values} (fid, uid, value) VALUES (%d, %d, '%s')', $key, $uid, $value);
}
}
Actually, I just had to do this. You need to create the account first...
$account = user_save('',$user_array);
And then save all of the category data to the account with a separate call each like so:
user_save($account, $profile_data_1, 'Category 1');
user_save($account, $profile_data_2, 'Category 2');
This will do what you want.
Post a Comment