forked from salesforceidentity/IdentityTrail-Module3
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Module3RegistrationHandler.cls
167 lines (145 loc) · 5.84 KB
/
Module3RegistrationHandler.cls
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
/**
Registration Handler for External Identity Trail
**/
global class Module3RegistrationHandler implements Auth.RegistrationHandler{
private static final String ORG_SUFFIX = '.sso.badge.org';
private static final String DEFAULT_ACCOUNTNAME = 'Partners';
private static final String EXTERNAL_USER_PROFILE = 'Partners';
private static final String INTERNAL_USER_PROFILE = 'Standard User';
private static final String TZSID = [SELECT timezonesidkey from User where profile.name = 'System Administrator' LIMIT 1].timezonesidkey;
/**
* Let anyone register as long as the required fields are supplied
*
* We require email, lastName, firstName
*
* @data - the user's info from the Auth Provider
**/
global boolean canCreateUser(Auth.UserData data) {
System.debug('canCreateUser was called for ' + (data != null ? data.email : 'null'));
Boolean retVal = (data != null
&& data.email != null
&& data.lastName != null
&& data.firstName != null);
System.debug('data.username='+data.username);
System.debug('data.email='+data.email);
System.debug('data.lastName='+data.lastName);
System.debug('data.firstName='+data.firstName);
return retVal;
}
/**
* Create the User - A required method to implement the Handler Interface
*
* @param portalId - Id of the Community
* @param data - Auth Provider user data describing the User to create
*
* @return User that has been initialized
**/
global User createUser(Id portalId, Auth.UserData data){
if(!canCreateUser(data)) {
// Returning null signals the auth framework we can't create the user
return null;
}
// Is this a Community Context?
if(data.attributeMap.containsKey('sfdc_networkid')) {
System.debug('Registering Community user: ' + data.email);
Id contactId;
// Checking to see if the email address is already used by another Contact
// If so, use that contact and user
List<Contact> existingContacts = [select id, email from Contact where email =: data.email];
if (existingContacts.size() > 0){
// Use the first Contact with matching email
Contact existingContact = existingContacts[0];
contactId = existingContact.Id;
List<User> existingUsers = [select id from User where ContactId =: contactId];
if (existingUsers.size() == 1){
// Use this User instead of creating a new one
// The Registration Handler system will assoicate the Auth Provider
// with this user
return existingUsers[0];
}
} else {
// No matching Contacts found
// So we create one
// To keep things modular, we're creating the Contact in a separate method
contactId = createContact(data);
System.debug('Created contact: '+ contactId);
}
// You'd likely use other logic to assign the Profile
Profile p = [SELECT Id FROM profile WHERE name=:EXTERNAL_USER_PROFILE];
System.debug('Found profile: '+ p);
// Keeping it modular, we initialize the user in another method
User u = createUser(data,p);
u.contactId = contactId;
return u;
} else {
//This is not a community, so we Assign an internal profile
Profile p = [SELECT Id FROM profile WHERE name=:INTERNAL_USER_PROFILE];
System.debug('Found profile: '+ p);
// Keeping it modular, we initialize the user in another method
User u = createUser(data,p);
return u;
}
}
/**
* Update the user
* @param portalId - Id of the Community
* @param data - Auth Provider user data describing the User to create
**/
global void updateUser(Id userId, Id portalId, Auth.UserData data){
System.debug('Update User called for: ' + data.email);
User u = new User(id=userId);
u.email = data.email;
u.lastName = data.lastName;
u.firstName = data.firstName;
update(u);
}
/**
* Create a Contact
*
* @param data - Facebook provided context for the User
**/
private Id createContact(Auth.UserData data){
Contact contact = new Contact();
contact.LastName = data.lastName;
contact.FirstName = data.firstName;
contact.Email = data.email;
// set Account Id
if (data.attributemap.get('accountId') != null){
contact.accountId = data.attributemap.get('accountId');
} else {
List<Account> accounts = [select Id from Account where Name =:DEFAULT_ACCOUNTNAME];
System.debug('Found account: ' + accounts);
contact.accountId = accounts[0].Id;
}
insert contact;
System.debug('Contact created for ' + data.email + ' id=' + contact.id);
return contact.id;
}
/**
* Create and initialize the User but don't save it yet
*
* @param data - the provided User context from FaceBook
* @param p - the Profile we are going to assign to this user
*
* @return User that has been initialized but not Saved
**/
private User createUser(Auth.UserData data, Profile p) {
User u = new User();
u.username = data.email + ORG_SUFFIX;
u.email = data.email;
u.lastName = data.lastName;
u.firstName = data.firstName;
String alias = data.firstName + data.lastName;
//Alias must be 8 characters or less
if(alias.length() > 8) {
alias = alias.substring(0, 8);
}
u.alias = alias;
u.languagelocalekey = UserInfo.getLanguage();
u.localesidkey = UserInfo.getLocale();
u.emailEncodingKey = 'UTF-8';
u.timeZoneSidKey = TZSID;
u.profileId = p.Id;
return u;
}
}