2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4 * SugarCRM Community Edition is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
7 * This program is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU Affero General Public License version 3 as published by the
9 * Free Software Foundation with the addition of the following permission added
10 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
14 * This program is distributed in the hope that it will be useful, but WITHOUT
15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
19 * You should have received a copy of the GNU Affero General Public License along with
20 * this program; if not, see http://www.gnu.org/licenses or write to the Free
21 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
24 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
27 * The interactive user interfaces in modified source and object code versions
28 * of this program must display Appropriate Legal Notices, as required under
29 * Section 5 of the GNU Affero General Public License version 3.
31 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32 * these Appropriate Legal Notices must retain the display of the "Powered by
33 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34 * technical reasons, the Appropriate Legal Notices must display the words
35 * "Powered by SugarCRM".
36 ********************************************************************************/
38 $dictionary['User'] = array(
48 'name' => 'user_name',
49 'vname' => 'LBL_USER_NAME',
50 'type' => 'user_name',
51 'dbType' => 'varchar',
53 'importable' => 'required',
56 'no_duplicate' => true,
59 'quickcreate' => false,
60 'basic_search' => false,
61 'advanced_search' => false,
62 //BEGIN SUGARCRM flav=pro
63 'wirelesseditview' => false,
64 'wirelessdetailview' => true,
65 'wirelesslistview' => false,
66 'wireless_basic_search' => false,
67 'wireless_advanced_search' => false,
69 //END SUGARCRM flav=pro
73 'name' => 'user_hash',
74 'vname' => 'LBL_USER_HASH',
77 'reportable' => false,
78 'importable' => 'false',
86 'system_generated_password' => array(
87 'name' => 'system_generated_password',
88 'vname' => 'LBL_SYSTEM_GENERATED_PASSWORD',
91 'reportable' => false,
92 'massupdate' => false,
98 'wirelesseditview' => false,
102 'pwd_last_changed' => array(
103 'name' => 'pwd_last_changed',
104 'vname' => 'LBL_PSW_MODIFIED',
105 'type' => 'datetime',
107 'massupdate' => false,
108 'studio' => array('formula' => false),
111 * authenticate_id is used by authentication plugins so they may place a quick lookup key for looking up a given user after authenticating through the plugin
113 'authenticate_id' => array(
114 'name' => 'authenticate_id',
115 'vname' => 'LBL_AUTHENTICATE_ID',
118 'reportable' => false,
119 'importable' => 'false',
120 'studio' => array('listview' => false, 'searchview'=>false, 'related' => false),
123 * sugar_login will force the user to use sugar authentication
124 * regardless of what authentication the system is configured to use
126 'sugar_login' => array(
127 'name' => 'sugar_login',
128 'vname' => 'LBL_SUGAR_LOGIN',
131 'reportable' => false,
132 'massupdate' => false,
133 'importable' => false,
134 'studio' => array('listview' => false, 'searchview'=>false, 'formula' => false),
136 'first_name' => array(
137 'name' => 'first_name',
138 'vname' => 'LBL_FIRST_NAME',
139 'dbType' => 'varchar',
143 'last_name' => array(
144 'name' => 'last_name',
145 'vname' => 'LBL_LAST_NAME',
146 'dbType' => 'varchar',
149 'importable' => 'required',
152 'full_name' => array(
153 'name' => 'full_name',
154 'rname' => 'full_name',
155 'vname' => 'LBL_NAME',
161 'source' => 'non-db',
162 'sort_on' => 'last_name',
163 'sort_on2' => 'first_name',
164 'db_concat_fields' => array(
169 'studio' => array('formula' => false),
174 'vname' => 'LBL_NAME',
176 'source' => 'non-db',
178 'db_concat_fields' => array(
182 'importable' => 'false',
185 'name' => 'is_admin',
186 'vname' => 'LBL_IS_ADMIN',
189 'studio' => array('listview' => false, 'searchview'=>false, 'related' => false),
191 'external_auth_only' => array(
192 'name' => 'external_auth_only',
193 'vname' => 'LBL_EXT_AUTHENTICATE',
195 'reportable' => false,
196 'massupdate' => false,
198 'studio' => array('listview' => false, 'searchview'=>false, 'related' => false),
200 'receive_notifications' => array(
201 'name' => 'receive_notifications',
202 'vname' => 'LBL_RECEIVE_NOTIFICATIONS',
205 'massupdate' => false,
208 'description' => array(
209 'name' => 'description',
210 'vname' => 'LBL_DESCRIPTION',
213 'date_entered' => array(
214 'name' => 'date_entered',
215 'vname' => 'LBL_DATE_ENTERED',
216 'type' => 'datetime',
218 'studio' => array('editview' => false, 'quickcreate' => false, 'wirelesseditview' => false),
220 'date_modified' => array(
221 'name' => 'date_modified',
222 'vname' => 'LBL_DATE_MODIFIED',
223 'type' => 'datetime',
225 'studio' => array('editview' => false, 'quickcreate' => false, 'wirelesseditview' => false),
227 'modified_user_id' => array(
228 'name' => 'modified_user_id',
229 'rname' => 'user_name',
230 'id_name' => 'modified_user_id',
231 'vname' => 'LBL_MODIFIED_BY_ID',
232 'type' => 'assigned_user_name',
237 'modified_by_name' => array(
238 'name' => 'modified_by_name',
239 'vname' => 'LBL_MODIFIED_BY',
241 'source' => 'non-db',
244 'created_by' => array(
245 'name' => 'created_by',
246 'rname' => 'user_name',
247 'id_name' => 'modified_user_id',
248 'vname' => 'LBL_ASSIGNED_TO',
249 'type' => 'assigned_user_name',
255 'created_by_name' => array(
256 'name' => 'created_by_name',
257 'vname' => 'LBL_CREATED_BY_NAME', //bug 48978
259 'source' => 'non-db',
260 'importable' => 'false',
264 'vname' => 'LBL_TITLE',
268 'department' => array(
269 'name' => 'department',
270 'vname' => 'LBL_DEPARTMENT',
274 'phone_home' => array(
275 'name' => 'phone_home',
276 'vname' => 'LBL_HOME_PHONE',
278 'dbType' => 'varchar',
281 'phone_mobile' => array(
282 'name' => 'phone_mobile',
283 'vname' => 'LBL_MOBILE_PHONE',
285 'dbType' => 'varchar',
288 'phone_work' => array(
289 'name' => 'phone_work',
290 'vname' => 'LBL_WORK_PHONE',
292 'dbType' => 'varchar',
295 'phone_other' => array(
296 'name' => 'phone_other',
297 'vname' => 'LBL_OTHER_PHONE',
299 'dbType' => 'varchar',
302 'phone_fax' => array(
303 'name' => 'phone_fax',
304 'vname' => 'LBL_FAX_PHONE',
306 'dbType' => 'varchar',
311 'vname' => 'LBL_STATUS',
314 'options' => 'user_status_dom',
315 'importable' => 'required',
318 'address_street' => array(
319 'name' => 'address_street',
320 'vname' => 'LBL_ADDRESS_STREET',
324 'address_city' => array(
325 'name' => 'address_city',
326 'vname' => 'LBL_ADDRESS_CITY',
330 'address_state' => array(
331 'name' => 'address_state',
332 'vname' => 'LBL_ADDRESS_STATE',
336 'address_country' => array(
337 'name' => 'address_country',
338 'vname' => 'LBL_ADDRESS_COUNTRY',
342 'address_postalcode' => array(
343 'name' => 'address_postalcode',
344 'vname' => 'LBL_ADDRESS_POSTALCODE',
348 // This is a fake field for the edit view
350 'name' => 'UserType',
351 'vname' => 'LBL_USER_TYPE',
354 'options' => 'user_type_dom',
355 'source' => 'non-db',
357 'reportable' => false,
358 'studio' => array('formula' => false),
362 'vname' => 'LBL_DELETED',
365 'reportable' => false,
367 'portal_only' => array(
368 'name' => 'portal_only',
369 'vname' => 'LBL_PORTAL_ONLY_USER',
371 'massupdate' => false,
373 'studio' => array('listview' => false, 'searchview'=>false, 'formula' => false),
375 'show_on_employees' => array(
376 'name' => 'show_on_employees',
377 'vname' => 'LBL_SHOW_ON_EMPLOYEES',
379 'massupdate' => true,
380 'importable' => true,
382 'studio' => array('formula' => false),
384 'employee_status' => array(
385 'name' => 'employee_status',
386 'vname' => 'LBL_EMPLOYEE_STATUS',
389 'name' => 'getEmployeeStatusOptions',
391 'include' => 'modules/Employees/EmployeeStatus.php'
395 'messenger_id' => array(
396 'name' => 'messenger_id',
397 'vname' => 'LBL_MESSENGER_ID',
401 'messenger_type' => array(
402 'name' => 'messenger_type',
403 'vname' => 'LBL_MESSENGER_TYPE',
405 'options' => 'messenger_type_dom',
411 'relationship' => 'calls_users',
412 'source' => 'non-db',
413 'vname' => 'LBL_CALLS'
416 'name' => 'meetings',
418 'relationship' => 'meetings_users',
419 'source' => 'non-db',
420 'vname' => 'LBL_MEETINGS'
422 'contacts_sync' => array(
423 'name' => 'contacts_sync',
425 'relationship' => 'contacts_users',
426 'source' => 'non-db',
427 'vname' => 'LBL_CONTACTS_SYNC',
428 'reportable' => false,
430 'reports_to_id' => array(
431 'name' => 'reports_to_id',
432 'vname' => 'LBL_REPORTS_TO_ID',
436 'reports_to_name' => array(
437 'name' => 'reports_to_name',
438 'rname' => 'last_name',
439 'id_name' => 'reports_to_id',
440 'vname' => 'LBL_REPORTS_TO_NAME',
445 'link' => 'reports_to_link',
446 'reportable' => false,
447 'source' => 'non-db',
448 'duplicate_merge' => 'disabled',
451 'reports_to_link' => array(
452 'name' => 'reports_to_link',
454 'relationship' => 'user_direct_reports',
455 'link_type' => 'one',
457 'source' => 'non-db',
458 'vname' => 'LBL_REPORTS_TO',
460 'reportees' => array(
461 'name' => 'reportees',
463 'relationship' => 'user_direct_reports',
464 'link_type' => 'many',
466 'source' => 'non-db',
467 'vname' => 'LBL_REPORTS_TO',
468 'reportable' => false,
472 'vname' => 'LBL_EMAIL',
475 'name' => 'getEmailAddressWidget',
478 'source' => 'non-db',
480 'merge_filter' => 'enabled',
483 'email_addresses' => array(
484 'name' => 'email_addresses',
486 'relationship' => 'users_email_addresses',
487 'module' => 'EmailAddress',
488 'bean_name' => 'EmailAddress',
489 'source' => 'non-db',
490 'vname' => 'LBL_EMAIL_ADDRESSES',
491 'reportable' => false,
494 'email_addresses_primary' => array(
495 'name' => 'email_addresses_primary',
497 'relationship' => 'users_email_addresses_primary',
498 'source' => 'non-db',
499 'vname' => 'LBL_EMAIL_ADDRESS_PRIMARY',
500 'duplicate_merge' => 'disabled',
503 /* Virtual email fields so they will display on the main user page */
504 'email_link_type' => array(
505 'name' => 'email_link_type',
506 'vname' => 'LBL_EMAIL_LINK_TYPE',
508 'options' => 'dom_email_link_type',
509 'importable' => false,
510 'reportable' => false,
511 'source' => 'non-db',
516 'name' => 'aclroles',
518 'relationship' => 'acl_roles_users',
519 'source' => 'non-db',
521 'vname' => 'LBL_ROLES',
524 'name' => 'is_group',
525 'vname' => 'LBL_GROUP_USER',
527 'massupdate' => false,
528 'studio' => array('listview' => false, 'searchview'=>false, 'formula' => false),
530 /* to support Meetings SubPanels */
531 'c_accept_status_fields' => array(
532 'name' => 'c_accept_status_fields',
534 'relationship_fields' => array(
535 'id' => 'accept_status_id',
536 'accept_status' => 'accept_status_name'
538 'vname' => 'LBL_LIST_ACCEPT_STATUS',
541 'link_type' => 'relationship_info',
542 'source' => 'non-db',
543 'importable' => 'false',
544 'studio' => array('listview' => false, 'searchview'=>false, 'formula' => false),
546 'm_accept_status_fields' => array(
547 'name' => 'm_accept_status_fields',
549 'relationship_fields' => array(
550 'id' => 'accept_status_id',
551 'accept_status' => 'accept_status_name'
553 'vname' => 'LBL_LIST_ACCEPT_STATUS',
555 'link' => 'meetings',
556 'link_type' => 'relationship_info',
557 'source' => 'non-db',
558 'importable' => 'false',
559 'studio' => array('listview' => false, 'searchview'=>false, 'formula' => false),
561 'accept_status_id' => array(
562 'name' => 'accept_status_id',
564 'source' => 'non-db',
565 'vname' => 'LBL_LIST_ACCEPT_STATUS',
566 'importable' => 'false',
567 'studio' => array('listview' => false, 'searchview'=>false, 'formula' => false),
569 'accept_status_name' => array(
570 'name' => 'accept_status_name',
572 'source' => 'non-db',
573 'vname' => 'LBL_LIST_ACCEPT_STATUS',
574 'options' => 'dom_meeting_accept_status',
575 'massupdate' => false,
576 'studio' => array('listview' => false, 'searchview'=>false, 'formula' => false),
578 'prospect_lists' => array(
579 'name' => 'prospect_lists',
581 'relationship' => 'prospect_list_users',
582 'module' => 'ProspectLists',
583 'source' => 'non-db',
584 'vname' => 'LBL_PROSPECT_LIST',
586 'emails_users' => array(
587 'name' => 'emails_users',
589 'relationship' => 'emails_users_rel',
590 'module' => 'Emails',
591 'source' => 'non-db',
592 'vname' => 'LBL_EMAILS'
595 'name' => 'holidays',
597 'relationship' => 'users_holidays',
598 'source' => 'non-db',
600 'vname' => 'LBL_HOLIDAYS',
606 'relationship' => 'eapm_assigned_user',
607 'vname' => 'LBL_ASSIGNED_TO_USER',
612 'name' => 'oauth_tokens',
614 'relationship' => 'oauthtokens_assigned_user',
615 'vname' => 'LBL_OAUTH_TOKENS',
616 'link_type' => 'one',
617 'module'=>'OAuthTokens',
618 'bean_name'=>'OAuthToken',
624 'name' => 'project_resource',
626 'relationship' => 'projects_users_resources',
627 'source' => 'non-db',
628 'vname' => 'LBL_PROJECTS',
640 'name' => 'idx_user_name',
652 'relationships' => array (
653 'user_direct_reports' => array('lhs_module'=> 'Users', 'lhs_table'=> 'users', 'lhs_key' => 'id', 'rhs_module'=> 'Users', 'rhs_table'=> 'users', 'rhs_key' => 'reports_to_id', 'relationship_type'=>'one-to-many'),
654 'users_users_signatures' =>
656 'lhs_module'=> 'Users',
657 'lhs_table'=> 'users',
659 'rhs_module'=> 'UserSignature',
660 'rhs_table'=> 'users_signatures',
661 'rhs_key' => 'user_id',
662 'relationship_type'=>'one-to-many'
664 'users_email_addresses' =>
666 'lhs_module'=> "Users", 'lhs_table'=> 'users', 'lhs_key' => 'id',
667 'rhs_module'=> 'EmailAddresses', 'rhs_table'=> 'email_addresses', 'rhs_key' => 'id',
668 'relationship_type'=>'many-to-many',
669 'join_table'=> 'email_addr_bean_rel', 'join_key_lhs'=>'bean_id', 'join_key_rhs'=>'email_address_id',
670 'relationship_role_column'=>'bean_module',
671 'relationship_role_column_value'=>"Users"
673 'users_email_addresses_primary' =>
674 array('lhs_module'=> "Users", 'lhs_table'=> 'users', 'lhs_key' => 'id',
675 'rhs_module'=> 'EmailAddresses', 'rhs_table'=> 'email_addresses', 'rhs_key' => 'id',
676 'relationship_type'=>'many-to-many',
677 'join_table'=> 'email_addr_bean_rel', 'join_key_lhs'=>'bean_id', 'join_key_rhs'=>'email_address_id',
678 'relationship_role_column'=>'primary_address',
679 'relationship_role_column_value'=>'1'