dolibarr 20.0.2
User Class Reference

Class to manage Dolibarr users. More...

Inheritance diagram for User:
Collaboration diagram for User:

Public Member Functions

 __construct ($db)
 Constructor of the class.
 
 fetch ($id=0, $login='', $sid='', $loadpersonalconf=0, $entity=-1, $email='', $fk_socpeople=0, $use_email_oauth2=0)
 Load a user from database with its id or ref (login).
 
 loadPersonalConf ()
 Load const values from database table user_param and set it into user->conf->XXX.
 
 loadDefaultValues ()
 Load default values from database table into property ->default_values.
 
 hasRight ($module, $permlevel1, $permlevel2='')
 Return if a user has a permission.
 
 addrights ($rid, $allmodule='', $allperms='', $entity=0, $notrigger=0)
 Add a right to the user.
 
 delrights ($rid, $allmodule='', $allperms='', $entity=0, $notrigger=0)
 Remove a right to the user.
 
 clearrights ()
 Clear all permissions array of user.
 
 loadRights ($moduletag='', $forcereload=0)
 Load permissions granted to a user->id into object user->rights.
 
 getrights ($moduletag='', $forcereload=0)
 Load permissions granted to a user->id into object user->rights TODO Remove this method.
 
 setstatus ($status)
 Change status of a user.
 
 setCategories ($categories)
 Sets object to supplied categories.
 
 delete (User $user)
 Delete the user.
 
 create ($user, $notrigger=0)
 Create a user into database.
 
 create_from_contact ($contact, $login='', $password='')
 Create a user from a contact object.
 
 create_from_member ($member, $login='')
 Create a user into database from a member object.
 
 set_default_rights ()
 Assign rights by default.
 
 update ($user, $notrigger=0, $nosyncmember=0, $nosyncmemberpass=0, $nosynccontact=0)
 Update a user into database (and also password if this->pass is defined)
 
 update_last_login_date ()
 Update the user's last login date in the database.
 
 setPassword ($user, $password='', $changelater=0, $notrigger=0, $nosyncmember=0, $passwordalreadycrypted=0, $flagdelsessionsbefore=1)
 Change password of a user.
 
 send_password ($user, $password='', $changelater=0)
 Send a new password (or instructions to reset it) by email.
 
 error ()
 Renvoie la derniere erreur fonctionnelle de manipulation de l'objet.
 
 fetch_clicktodial ()
 Read clicktodial information for user.
 
 update_clicktodial ()
 Update clicktodial info.
 
 SetInGroup ($group, $entity, $notrigger=0)
 Add user into a group.
 
 RemoveFromGroup ($group, $entity, $notrigger=0)
 Remove a user from a group.
 
 isNotIntoValidityDateRange ()
 Return a link with photo Use this->id,this->photo.
 
 getPhotoUrl ($width, $height, $cssclass='', $imagesize='')
 Return a link with photo Use this->id,this->photo.
 
 getTooltipContentArray ($params)
 Return array of data to show into tooltips.
 
 getNomUrl ($withpictoimg=0, $option='', $infologin=0, $notooltip=0, $maxlen=24, $hidethirdpartylogo=0, $mode='', $morecss='', $save_lastsearch_value=-1)
 Return a HTML link to the user card (with optionally the picto) Use this->id,this->lastname, this->firstname.
 
 getLoginUrl ($withpictoimg=0, $option='', $notooltip=0, $morecss='')
 Return clickable link of login (optionally with picto)
 
 getLibStatut ($mode=0)
 Return the label of the status of user (active, inactive)
 
 LibStatut ($status, $mode=0)
 Return the label of a status of user (active, inactive)
 
 getKanbanView ($option='', $arraydata=null)
 Return clicable link of object (optionally with picto)
 
 _load_ldap_dn ($info, $mode=0)
 Retourne chaine DN complete dans l'annuaire LDAP pour l'objet.
 
 _load_ldap_info ()
 Initialize the info array (array of LDAP values) that will be used to call LDAP functions.
 
 initAsSpecimen ()
 Initialise an instance with random values.
 
 info ($id)
 Load info of user object.
 
 getNbOfEMailings ()
 Return number of mass Emailing received by this contacts with its email.
 
 getNbOfUsers ($limitTo, $option='', $admin=-1)
 Return number of existing users.
 
 update_ldap2dolibarr (&$ldapuser)
 Update user using data from the LDAP.
 
 get_children ()
 Return and array with all instantiated first level children users of current user.
 
 get_full_tree ($deleteafterid=0, $filter='')
 Build the hierarchy/tree of users into an array.
 
 getAllChildIds ($addcurrentuser=0)
 Return list of all child user ids in hierarchy (all sublevels).
 
 build_path_from_id_user ($id_user, $protection=0)
 For user id_user and its children available in this->users, define property fullpath and fullname.
 
 loadStateBoard ()
 Load metrics this->nb for dashboard.
 
 generateDocument ($modele, $outputlangs, $hidedetails=0, $hidedesc=0, $hideref=0, $moreparams=null)
 Create a document onto disk according to template module.
 
 user_get_property ($rowid, $mode)
 Return property of user from its id.
 
 getOnlineVirtualCardUrl ($mode='', $typeofurl='external')
 Return string with full Url to virtual card.
 
 fetchAll ($sortorder='', $sortfield='', $limit=0, $offset=0, $filter='', $filtermode='AND', $entityfilter=false)
 Load all objects into $this->users.
 
 findUserIdByEmail ($email)
 Find a user by the given e-mail and return it's user id when found.
 
- Public Member Functions inherited from CommonObject
 isEmpty ()
 isEmpty We consider CommonObject isEmpty if this->id is empty
 
 setErrorsFromObject ($object)
 setErrorsFromObject
 
 getTooltipContent ($params)
 getTooltipContent
 
 errorsToString ()
 Method to output saved errors.
 
 getFormatedCustomerRef ($objref)
 Return customer ref for screen output.
 
 getFormatedSupplierRef ($objref)
 Return supplier ref for screen output.
 
 getFullAddress ($withcountry=0, $sep="\n", $withregion=0, $extralangcode='')
 Return full address of contact.
 
 getLastMainDocLink ($modulepart, $initsharekey=0, $relativelink=0)
 Return the link of last main doc file for direct public download.
 
 add_contact ($fk_socpeople, $type_contact, $source='external', $notrigger=0)
 Add a link between element $this->element and a contact.
 
 copy_linked_contact ($objFrom, $source='internal')
 Copy contact from one element to current.
 
 update_contact ($rowid, $statut, $type_contact_id=0, $fk_socpeople=0)
 Update a link to contact line.
 
 delete_contact ($rowid, $notrigger=0)
 Delete a link to contact line.
 
 delete_linked_contact ($source='', $code='')
 Delete all links between an object $this and all its contacts in llx_element_contact.
 
 liste_contact ($statusoflink=-1, $source='external', $list=0, $code='', $status=-1, $arrayoftcids=array())
 Get array of all contacts for an object.
 
 swapContactStatus ($rowid)
 Update status of a contact linked to object.
 
 liste_type_contact ($source='internal', $order='position', $option=0, $activeonly=0, $code='')
 Return array with list of possible values for type of contacts.
 
 listeTypeContacts ($source='internal', $option=0, $activeonly=0, $code='', $element='', $excludeelement='')
 Return array with list of possible values for type of contacts.
 
 getIdContact ($source, $code, $status=0)
 Return id of contacts for a source and a contact code.
 
 fetch_contact ($contactid=null)
 Load object contact with id=$this->contact_id into $this->contact.
 
 fetch_thirdparty ($force_thirdparty_id=0)
 Load the third party of object, from id $this->socid or $this->fk_soc, into this->thirdparty.
 
 fetchOneLike ($ref)
 Looks for an object with ref matching the wildcard provided It does only work when $this->table_ref_field is set.
 
 fetch_barcode ()
 Load data for barcode into properties ->barcode_type* Properties ->barcode_type that is id of barcode.
 
 fetch_project ()
 Load the project with id $this->fk_project into this->project.
 
 fetch_projet ()
 Load the project with id $this->fk_project into this->project.
 
 fetch_product ()
 Load the product with id $this->fk_product into this->product.
 
 fetch_user ($userid)
 Load the user with id $userid into this->user.
 
 fetch_origin ()
 Read linked origin object.
 
 fetchObjectFrom ($table, $field, $key, $element=null)
 Load object from specific field.
 
 getValueFrom ($table, $id, $field)
 Getter generic.
 
 setValueFrom ($field, $value, $table='', $id=null, $format='', $id_field='', $fuser=null, $trigkey='', $fk_user_field='fk_user_modif')
 Setter generic.
 
 load_previous_next_ref ($filter, $fieldid, $nodbprefix=0)
 Load properties id_previous and id_next by comparing $fieldid with $this->ref.
 
 getListContactId ($source='external')
 Return list of id of contacts of object.
 
 setProject ($projectid, $notrigger=0)
 Link element with a project.
 
 setPaymentMethods ($id)
 Change the payments methods.
 
 setMulticurrencyCode ($code)
 Change the multicurrency code.
 
 setPaymentTerms ($id, $deposit_percent=null)
 Change the payments terms.
 
 setTransportMode ($id)
 Change the transport mode methods.
 
 setRetainedWarrantyPaymentTerms ($id)
 Change the retained warranty payments terms.
 
 setDeliveryAddress ($id)
 Define delivery address.
 
 setShippingMethod ($shipping_method_id, $notrigger=0, $userused=null)
 Change the shipping method.
 
 setWarehouse ($warehouse_id)
 Change the warehouse.
 
 setDocModel ($user, $modelpdf)
 Set last model used by doc generator.
 
 setBankAccount ($fk_account, $notrigger=0, $userused=null)
 Change the bank account.
 
 line_order ($renum=false, $rowidorder='ASC', $fk_parent_line=true)
 Save a new position (field rang) for details lines.
 
 getChildrenOfLine ($id, $includealltree=0)
 Get children of line.
 
 line_up ($rowid, $fk_parent_line=true)
 Update a line to have a lower rank.
 
 line_down ($rowid, $fk_parent_line=true)
 Update a line to have a higher rank.
 
 updateRangOfLine ($rowid, $rang)
 Update position of line (rang)
 
 line_ajaxorder ($rows)
 Update position of line with ajax (rang)
 
 updateLineUp ($rowid, $rang)
 Update position of line up (rang)
 
 updateLineDown ($rowid, $rang, $max)
 Update position of line down (rang)
 
 getRangOfLine ($rowid)
 Get position of line (rang)
 
 getIdOfLine ($rang)
 Get rowid of the line relative to its position.
 
 line_max ($fk_parent_line=0)
 Get max value used for position of line (rang)
 
 update_ref_ext ($ref_ext)
 Update external ref of element.
 
 update_note ($note, $suffix='', $notrigger=0)
 Update note of element.
 
 update_note_public ($note)
 Update public note (kept for backward compatibility)
 
 update_price ($exclspec=0, $roundingadjust='auto', $nodatabaseupdate=0, $seller=null)
 Update total_ht, total_ttc, total_vat, total_localtax1, total_localtax2 for an object (sum of lines).
 
 add_object_linked ($origin=null, $origin_id=null, $f_user=null, $notrigger=0)
 Add an object link into llx_element_element.
 
 getElementType ()
 Return an element type string formatted like element_element target_type and source_type.
 
 fetchObjectLinked ($sourceid=null, $sourcetype='', $targetid=null, $targettype='', $clause='OR', $alsosametype=1, $orderby='sourcetype', $loadalsoobjects=1)
 Fetch array of objects linked to current object (object of enabled modules only).
 
 clearObjectLinkedCache ()
 Clear the cache saying that all linked object were already loaded.
 
 updateObjectLinked ($sourceid=null, $sourcetype='', $targetid=null, $targettype='', $f_user=null, $notrigger=0)
 Update object linked of a current object.
 
 deleteObjectLinked ($sourceid=null, $sourcetype='', $targetid=null, $targettype='', $rowid=0, $f_user=null, $notrigger=0)
 Delete all links between an object $this.
 
 setStatut ($status, $elementId=null, $elementType='', $trigkey='', $fieldstatus='fk_statut')
 Set status of an object.
 
 getCanvas ($id=0, $ref='')
 Load type of canvas of an object if it exists.
 
 getSpecialCode ($lineid)
 Get special code of a line.
 
 isObjectUsed ($id=0, $entity=0)
 Function to check if an object is used by others (by children).
 
 hasProductsOrServices ($predefined=-1)
 Function to say how many lines object contains.
 
 getTotalDiscount ()
 Function that returns the total amount HT of discounts applied for all lines.
 
 getTotalWeightVolume ()
 Return into unit=0, the calculated total of weight and volume of all lines * qty Calculate by adding weight and volume of each product line, so properties ->volume/volume_units/weight/weight_units must be loaded on line.
 
 setExtraParameters ()
 Set extra parameters.
 
 formAddObjectLine ($dateSelector, $seller, $buyer, $defaulttpldir='/core/tpl')
 Show add free and predefined products/services form.
 
 printObjectLines ($action, $seller, $buyer, $selected=0, $dateSelector=0, $defaulttpldir='/core/tpl')
 Return HTML table for object lines TODO Move this into an output class file (htmlline.class.php) If lines are into a template, title must also be into a template But for the moment we don't know if it's possible as we keep a method available on overloaded objects.
 
 printObjectLine ($action, $line, $var, $num, $i, $dateSelector, $seller, $buyer, $selected=0, $extrafields=null, $defaulttpldir='/core/tpl')
 Return HTML content of a detail line TODO Move this into an output class file (htmlline.class.php)
 
 printOriginLinesList ($restrictlist='', $selectedLines=array())
 Return HTML table table of source object lines TODO Move this and previous function into output html class file (htmlline.class.php).
 
 printOriginLine ($line, $var, $restrictlist='', $defaulttpldir='/core/tpl', $selectedLines=array())
 Return HTML with a line of table array of source object lines TODO Move this and previous function into output html class file (htmlline.class.php).
 
 add_element_resource ($resource_id, $resource_type, $busy=0, $mandatory=0)
 Add resources to the current object : add entry into llx_element_resources Need $this->element & $this->id.
 
 delete_resource ($rowid, $element, $notrigger=0)
 Delete a link to resource line.
 
 __clone ()
 Overwrite magic function to solve problem of cloning object that are kept as references.
 
 indexFile ($destfull, $update_main_doc_field)
 Index a file into the ECM database.
 
 addThumbs ($file)
 Build thumb.
 
 delThumbs ($file)
 Delete thumbs.
 
 getDefaultCreateValueFor ($fieldname, $alternatevalue=null, $type='alphanohtml')
 Return the default value to use for a field when showing the create form of object.
 
 call_trigger ($triggerName, $user)
 Call trigger based on this instance.
 
 fetchValuesForExtraLanguages ()
 Function to get alternative languages of a data into $this->array_languages This method is NOT called by method fetch of objects but must be called separately.
 
 setValuesForExtraLanguages ($onlykey='')
 Fill array_options property of object by extrafields value (using for data sent by forms)
 
 fetchNoCompute ($id)
 Function to make a fetch but set environment to avoid to load computed values before.
 
 fetch_optionals ($rowid=null, $optionsArray=null)
 Function to get extra fields of an object into $this->array_options This method is in most cases called by method fetch of objects but you can call it separately.
 
 deleteExtraFields ()
 Delete all extra fields values for the current object.
 
 insertExtraFields ($trigger='', $userused=null)
 Add/Update all extra fields values for the current object.
 
 insertExtraLanguages ($trigger='', $userused=null)
 Add/Update all extra fields values for the current object.
 
 updateExtraField ($key, $trigger=null, $userused=null)
 Update 1 extra field value for the current object.
 
 getExtraField ($key)
 Convenience method for retrieving the value of an extrafield without actually fetching it from the database.
 
 setExtraField ($key, $value)
 Convenience method for setting the value of an extrafield without actually updating it in the database.
 
 updateExtraLanguages ($key, $trigger=null, $userused=null)
 Update an extra language value for the current object.
 
 showInputField ($val, $key, $value, $moreparam='', $keysuffix='', $keyprefix='', $morecss=0, $nonewbutton=0)
 Return HTML string to put an input field into a page Code very similar with showInputField of extra fields.
 
 clearFieldError ($fieldKey)
 clear validation message result for a field
 
 setFieldError ($fieldKey, $msg='')
 set validation error message a field
 
 getFieldError ($fieldKey)
 get field error message
 
 validateField ($fields, $fieldKey, $fieldValue)
 Return validation test result for a field.
 
 showOptionals ($extrafields, $mode='view', $params=null, $keysuffix='', $keyprefix='', $onetrtd='', $display_type='card')
 Function to show lines of extrafields with output data.
 
 getJSListDependancies ($type='_extra')
 
 getRights ()
 Returns the rights used for this class.
 
 defineBuyPrice ($unitPrice=0.0, $discountPercent=0.0, $fk_product=0)
 Get buy price to use for margin calculation.
 
 getDataToShowPhoto ($modulepart, $imagesize)
 Function used to get the logos or photos of an object.
 
 show_photos ($modulepart, $sdir, $size=0, $nbmax=0, $nbbyrow=5, $showfilename=0, $showaction=0, $maxHeight=120, $maxWidth=160, $nolink=0, $overwritetitle=0, $usesharelink=0, $cache='', $addphotorefcss='photoref')
 Show photos of an object (nbmax maximum), into several columns.
 
 isDate ($info)
 Function test if type is date.
 
 isDuration ($info)
 Function test if type is duration.
 
 isInt ($info)
 Function test if type is integer.
 
 isFloat ($info)
 Function test if type is float.
 
 isText ($info)
 Function test if type is text.
 
 setVarsFromFetchObj (&$obj)
 Function to load data from a SQL pointer into properties of current object $this.
 
 emtpyObjectVars ()
 Sets all object fields to null.
 
 getFieldList ($alias='', $excludefields=array())
 Function to concat keys of fields.
 
 createCommon (User $user, $notrigger=0)
 Create object in the database.
 
 fetchCommon ($id, $ref=null, $morewhere='', $noextrafields=0)
 Load object in memory from the database.
 
 fetchLinesCommon ($morewhere='', $noextrafields=0)
 Load object in memory from the database.
 
 updateCommon (User $user, $notrigger=0)
 Update object into database.
 
 deleteCommon (User $user, $notrigger=0, $forcechilddeletion=0)
 Delete object in database.
 
 deleteByParentField ($parentId=0, $parentField='', $filter='', $filtermode="AND")
 Delete all child object from a parent ID.
 
 deleteLineCommon (User $user, $idline, $notrigger=0)
 Delete a line of object in database.
 
 setStatusCommon ($user, $status, $notrigger=0, $triggercode='')
 Set to a status.
 
 setSignedStatusCommon ($user, $status, $notrigger=0, $triggercode='')
 Set to a signed status.
 
 initAsSpecimenCommon ()
 Initialise object with example values Id must be 0 if object instance is a specimen.
 
 fetchComments ()
 Load comments linked with current task.
 
 getNbComments ()
 Return nb comments already posted.
 
 trimParameters ($parameters)
 Trim object parameters.
 
 getCategoriesCommon ($type_categ)
 Sets object to given categories.
 
 setCategoriesCommon ($categories, $type_categ='', $remove_existing=true)
 Sets object to given categories.
 
 cloneCategories ($fromId, $toId, $type='')
 Copy related categories to another object.
 
 deleteEcmFiles ($mode=0)
 Delete related files of object in database.
 

Static Public Member Functions

static replaceThirdparty (DoliDB $dbs, $origin_id, $dest_id)
 Function used to replace a thirdparty id with another one.
 
- Static Public Member Functions inherited from CommonObject
static isExistingObject ($element, $id, $ref='', $ref_ext='')
 Check if an object id or ref exists If you don't need or want to instantiate the object and just need to know if the object exists, use this method instead of fetch.
 
static getAllItemsLinkedByObjectID ($fk_object_where, $field_select, $field_where, $table_element)
 Function used to get an array with all items linked to an object id in association table.
 
static getCountOfItemsLinkedByObjectID ($fk_object_where, $field_where, $table_element)
 Count items linked to an object id in association table.
 
static deleteAllItemsLinkedByObjectID ($fk_object_where, $field_where, $table_element)
 Function used to remove all items linked to an object id in association table.
 
static commonReplaceThirdparty (DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
 Function used to replace a thirdparty id with another one.
 
static commonReplaceProduct (DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
 Function used to replace a product id with another one.
 

Public Attributes

 $clicktodial_url
 @string clicktodial url
 
- Public Attributes inherited from CommonObject
 $origin_object
 

Private Member Functions

 loadParentOf ()
 Load this->parentof that is array(id_son=>id_parent, ...)
 

Additional Inherited Members

- Protected Member Functions inherited from CommonObject
 deprecatedProperties ()
 Provide list of deprecated properties and replacements.
 
 commonGenerateDocument ($modelspath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams=null)
 Common function for all objects extending CommonObject for generating documents.
 
 isArray ($info)
 Function test if type is array.
 
 canBeNull ($info)
 Function test if field can be null.
 
 isForcedToNullIfZero ($info)
 Function test if field is forced to null if zero or empty.
 
 isIndex ($info)
 Function test if is indexed.
 
 setSaveQuery ()
 Function to return the array of data key-value from the ->fields and all the ->properties of an object.
 
 quote ($value, $fieldsentry)
 Add quote to field value if necessary.
 

Detailed Description

Class to manage Dolibarr users.

Definition at line 49 of file user.class.php.

Constructor & Destructor Documentation

◆ __construct()

User::__construct ( $db)

Constructor of the class.

Parameters
DoliDB$dbDatabase handler

Definition at line 409 of file user.class.php.

References conf().

Member Function Documentation

◆ _load_ldap_dn()

User::_load_ldap_dn ( $info,
$mode = 0 )

Retourne chaine DN complete dans l'annuaire LDAP pour l'objet.

Parameters
array$infoInfo array loaded by _load_ldap_info
int$mode0=Return full DN (uid=qqq,ou=xxx,dc=aaa,dc=bbb) 1=Return parent (ou=xxx,dc=aaa,dc=bbb) 2=Return key only (RDN) (uid=qqq)
Returns
string DN

Definition at line 3297 of file user.class.php.

References getDolGlobalString().

◆ _load_ldap_info()

User::_load_ldap_info ( )

Initialize the info array (array of LDAP values) that will be used to call LDAP functions.

Returns
array Table with attribute information

Definition at line 3319 of file user.class.php.

References dol_hash(), dol_string_nohtmltag(), dolGetLdapPasswordHash(), getArrayOfSocialNetworks(), getDolGlobalString(), and getFullName().

◆ addrights()

User::addrights ( $rid,
$allmodule = '',
$allperms = '',
$entity = 0,
$notrigger = 0 )

Add a right to the user.

Parameters
int$ridId of permission to add or 0 to add several permissions
string$allmoduleAdd all permissions of module $allmodule or 'allmodules' to include all modules.
string$allpermsAdd all permissions of module $allmodule, subperms $allperms only or '' to include all permissions.
int$entityEntity to use
int$notrigger1=Does not execute triggers, 0=Execute triggers
Returns
int > 0 if OK, < 0 if KO
See also
clearrights(), delrights(), getrights(), hasRight()

Definition at line 927 of file user.class.php.

References CommonObject\call_trigger(), dol_print_error(), dol_syslog(), and error().

◆ build_path_from_id_user()

User::build_path_from_id_user ( $id_user,
$protection = 0 )

For user id_user and its children available in this->users, define property fullpath and fullname.

Function called by get_full_tree().

Parameters
int$id_userid_user entry to update
int$protectionDeep counter to avoid infinite loop (no more required, a protection is added with array useridfound)
Returns
int<-1,1> Return integer < 0 if KO (infinite loop), >= 0 if OK

Definition at line 3893 of file user.class.php.

References dol_strlen(), and dol_syslog().

Referenced by get_full_tree().

◆ clearrights()

User::clearrights ( )

Clear all permissions array of user.

Returns
void
See also
getrights(), hasRight()

Definition at line 1188 of file user.class.php.

References dol_syslog().

◆ create()

User::create ( $user,
$notrigger = 0 )

Create a user into database.

Parameters
User$userObject user doing creation
int$notrigger1=do not execute triggers, 0 otherwise
Returns
int Return integer <0 if KO, id of created user if OK

Definition at line 1632 of file user.class.php.

References CommonObject\call_trigger(), dol_now(), dol_syslog(), error(), getDolGlobalString(), getFullName(), isValidEmail(), set_default_rights(), setUpperOrLowerCase(), and update().

Referenced by create_from_contact(), and create_from_member().

◆ create_from_contact()

User::create_from_contact ( $contact,
$login = '',
$password = '' )

Create a user from a contact object.

User will be internal but if contact is linked to a third party, user will be external

Parameters
Contact$contactObject for source contact
string$loginLogin to force
string$passwordPassword to force
Returns
int Return integer <0 if error, if OK returns id of created user

Definition at line 1777 of file user.class.php.

References CommonObject\call_trigger(), create(), dol_buildlogin(), dol_syslog(), error(), and setUpperOrLowerCase().

◆ create_from_member()

User::create_from_member ( $member,
$login = '' )

Create a user into database from a member object.

If $member->fk_soc is set, it will be an external user.

Parameters
Adherent$memberObject member source
string$loginLogin to force
Returns
int Return integer <0 if KO, if OK, return id of created account

Definition at line 1863 of file user.class.php.

References create(), dol_buildlogin(), dol_syslog(), error(), setPassword(), and setUpperOrLowerCase().

◆ delete()

User::delete ( User $user)

Delete the user.

Parameters
User$userUser than delete
Returns
int Return integer <0 if KO, >0 if OK

Definition at line 1545 of file user.class.php.

References CommonObject\call_trigger(), CommonObject\deleteExtraFields(), dol_syslog(), error(), and fetch().

◆ delrights()

User::delrights ( $rid,
$allmodule = '',
$allperms = '',
$entity = 0,
$notrigger = 0 )

Remove a right to the user.

Parameters
int$ridId of permission to remove (or 0 when using the other filters)
string$allmoduleRetirer tous les droits du module allmodule
string$allpermsRetirer tous les droits du module allmodule, perms allperms
int | string$entityEntity to use. Example: '1', or '0,1', or '2,3'
int$notrigger1=Does not execute triggers, 0=Execute triggers
Returns
int > 0 if OK, < 0 if OK
See also
clearrights(), addrights(), getrights(), hasRight()

Definition at line 1070 of file user.class.php.

References CommonObject\call_trigger(), and dol_print_error().

◆ error()

◆ fetch()

User::fetch ( $id = 0,
$login = '',
$sid = '',
$loadpersonalconf = 0,
$entity = -1,
$email = '',
$fk_socpeople = 0,
$use_email_oauth2 = 0 )

Load a user from database with its id or ref (login).

This function does not load permissions, only user properties. Use getrights() for this just after the fetch.

Parameters
int$idIf defined, id to used for search
string$loginIf defined, login to used for search
string$sidIf defined, sid to used for search
int$loadpersonalconf1=also load personal conf of user (in $user->conf->xxx), 0=do not load personal conf.
int$entityIf a value is >= 0, we force the search on a specific entity. If -1, means search depens on default setup.
string$emailIf defined, email to used for search
int$fk_socpeopleIf defined, id of contact for search
int$use_email_oauth21=Use also email_oauth2 to fetch on email
Returns
int Return integer <0 if KO, 0 not found, >0 if OK

Definition at line 450 of file user.class.php.

References dol_syslog(), dolDecrypt(), error(), CommonObject\fetch_optionals(), getDolGlobalString(), loadDefaultValues(), loadPersonalConf(), ref, status, and statut.

Referenced by delete().

◆ fetch_clicktodial()

User::fetch_clicktodial ( )

Read clicktodial information for user.

Returns
int Return integer <0 if KO, >0 if OK

Definition at line 2659 of file user.class.php.

References error().

◆ fetchAll()

User::fetchAll ( $sortorder = '',
$sortfield = '',
$limit = 0,
$offset = 0,
$filter = '',
$filtermode = 'AND',
$entityfilter = false )

Load all objects into $this->users.

Parameters
string$sortordersort order
string$sortfieldsort field
int$limitlimit page
int$offsetpage
string$filterFilter as an Universal Search string. Example: '((client:=:1) OR ((client:>=:2) AND (client:<=:3))) AND (client:!=:8) AND (nom:like:'a')'
string$filtermodeNo more used
bool$entityfilterActivate entity filter
Returns
int Return integer <0 if KO, >0 if OK

Definition at line 4102 of file user.class.php.

References dol_syslog(), forgeSQLFromUniversalSearchCriteria(), and getDolGlobalString().

◆ findUserIdByEmail()

User::findUserIdByEmail ( $email)

Find a user by the given e-mail and return it's user id when found.

NOTE: Use AGENDA_DISABLE_EXACT_USER_EMAIL_COMPARE_FOR_EXTERNAL_CALENDAR to disable exact e-mail search

Parameters
string$emailThe full e-mail (or a part of a e-mail)
Returns
int Return integer <0 = user was not found, >0 = The id of the user

Definition at line 4182 of file user.class.php.

References getDolGlobalString().

◆ generateDocument()

User::generateDocument ( $modele,
$outputlangs,
$hidedetails = 0,
$hidedesc = 0,
$hideref = 0,
$moreparams = null )

Create a document onto disk according to template module.

Parameters
string$modeleForce model to use ('' to not force)
Translate$outputlangsObject langs to use for output
int$hidedetailsHide details of lines
int$hidedescHide description
int$hiderefHide ref
null | array$moreparamsArray to provide more information
Returns
int 0 if KO, 1 if OK

Definition at line 3995 of file user.class.php.

References CommonObject\commonGenerateDocument(), dol_strlen(), and getDolGlobalString().

◆ get_children()

User::get_children ( )

Return and array with all instantiated first level children users of current user.

Returns
User[]|int<-1,-1>
See also
getAllChildIds()

Definition at line 3688 of file user.class.php.

References dol_print_error(), and dol_syslog().

◆ get_full_tree()

User::get_full_tree ( $deleteafterid = 0,
$filter = '' )

Build the hierarchy/tree of users into an array.

Set and return this->users that is an array sorted according to tree with arrays of: id = id user lastname firstname fullname = Name with full path to user fullpath = Full path composed of the ids: "_grandparentid_parentid_id"

Parameters
int$deleteafteridRemoved all users including the leaf $deleteafterid (and all its child) in user tree.
string$filterSQL filter on users. This parameter must not come from user input.
Returns
int<-1,-1>|array<int,array{rowid:int,id:int,fk_user:int,fk_soc:int,firstname:string,lastname:string,login:string,statut:int,entity:int,email:string,gender:string|int<-1,-1>,admin:int<0,1>,photo:string,fullpath:string,fullname:string,level:int}> Array of user information (also: $this->users). Note: $this->parentof is also set.

Definition at line 3755 of file user.class.php.

References build_path_from_id_user(), dol_print_error(), dol_sort_array(), dol_syslog(), error(), and loadParentOf().

Referenced by getAllChildIds().

◆ getAllChildIds()

User::getAllChildIds ( $addcurrentuser = 0)

Return list of all child user ids in hierarchy (all sublevels).

Note: Calling this function also reset full list of users into $this->users.

Parameters
int$addcurrentuser1=Add also current user id to the list.
Returns
array Array of user id lower than user (all levels under user). This overwrite this->users.
See also
get_children()

Definition at line 3855 of file user.class.php.

References dol_syslog(), and get_full_tree().

◆ getKanbanView()

User::getKanbanView ( $option = '',
$arraydata = null )

Return clicable link of object (optionally with picto)

Parameters
string$optionWhere point the link (0=> main card, 1,2 => shipment, 'nolink'=>No link)
array$arraydataArray of data
Returns
string HTML Code for Kanban thumb.

Definition at line 3235 of file user.class.php.

References getNomUrl(), img_picto(), and Form\showphoto().

◆ getLibStatut()

User::getLibStatut ( $mode = 0)

Return the label of the status of user (active, inactive)

Parameters
int$mode0=long label, 1=short label, 2=Picto + short label, 3=Picto, 4=Picto + long label, 5=Short label + Picto, 6=Long label + Picto
Returns
string Label of status

Definition at line 3179 of file user.class.php.

References LibStatut(), status, and statut.

Referenced by getTooltipContentArray().

◆ getLoginUrl()

User::getLoginUrl ( $withpictoimg = 0,
$option = '',
$notooltip = 0,
$morecss = '' )

Return clickable link of login (optionally with picto)

Parameters
int$withpictoimgInclude picto into link (1=picto, -1=photo)
string$optionOn what the link point to ('leave', 'accountancy', 'nolink', )
integer$notooltip1=Disable tooltip on picto and name
string$morecssAdd more css on link
Returns
string String with URL

Definition at line 3128 of file user.class.php.

References img_object(), and Form\showphoto().

◆ getNbOfEMailings()

User::getNbOfEMailings ( )

Return number of mass Emailing received by this contacts with its email.

Returns
int Number of EMailings

Definition at line 3568 of file user.class.php.

References error().

◆ getNbOfUsers()

User::getNbOfUsers ( $limitTo,
$option = '',
$admin = -1 )

Return number of existing users.

Parameters
string$limitToLimit to '' or 'active'
string$option'superadmin' = return for entity 0 only
int$adminFilter on admin tag
Returns
int Number of users

Definition at line 3596 of file user.class.php.

References error().

◆ getNomUrl()

User::getNomUrl ( $withpictoimg = 0,
$option = '',
$infologin = 0,
$notooltip = 0,
$maxlen = 24,
$hidethirdpartylogo = 0,
$mode = '',
$morecss = '',
$save_lastsearch_value = -1 )

Return a HTML link to the user card (with optionally the picto) Use this->id,this->lastname, this->firstname.

Parameters
int$withpictoimgInclude picto in link (0=No picto, 1=Include picto into link, 2=Only picto, -1=Include photo into link, -2=Only picto photo, -3=Only photo very small)
string$optionOn what the link point to ('leave', 'accountancy', 'nolink', )
integer$infologin0=Add default info tooltip, 1=Add complete info tooltip, -1=No info tooltip
integer$notooltip1=Disable tooltip on picto and name
int$maxlenMax length of visible user name
int$hidethirdpartylogoHide logo of thirdparty if user is external user
string$mode''=Show firstname and lastname, 'firstname'=Show only firstname, 'firstelselast'=Show firstname or lastname if not defined, 'login'=Show login
string$morecssAdd more css on link
int$save_lastsearch_value-1=Auto, 0=No save of lastsearch_values when clicking, 1=Save lastsearch_values whenclicking
Returns
string String with URL

Definition at line 2996 of file user.class.php.

References dol_string_nohtmltag(), dol_trunc(), getDolGlobalInt(), getDolGlobalString(), getFullName(), getTooltipContentArray(), img_object(), Form\showphoto(), and status.

Referenced by getKanbanView().

◆ getOnlineVirtualCardUrl()

User::getOnlineVirtualCardUrl ( $mode = '',
$typeofurl = 'external' )

Return string with full Url to virtual card.

Parameters
string$modeMode for link
string$typeofurl'external' or 'internal'
Returns
string Url string link

Definition at line 4066 of file user.class.php.

References dol_hash().

◆ getPhotoUrl()

User::getPhotoUrl ( $width,
$height,
$cssclass = '',
$imagesize = '' )

Return a link with photo Use this->id,this->photo.

Parameters
int$widthWidth of image
int$heightHeight of image
string$cssclassForce a css class
string$imagesize'mini', 'small' or '' (original)
Returns
string String with URL link
See also
getImagePublicURLOfObject()

Definition at line 2875 of file user.class.php.

References Form\showphoto().

◆ getrights()

User::getrights ( $moduletag = '',
$forcereload = 0 )

Load permissions granted to a user->id into object user->rights TODO Remove this method.

It has a name conflict with getRights() in CommonObject.

Parameters
string$moduletagLimit permission for a particular module ('' by default means load all permissions)
int$forcereloadForce reload of permissions even if they were already loaded (ignore cache)
Returns
void
See also
clearrights(), delrights(), addrights(), hasRight() @phpstan-ignore-next-line

Definition at line 1463 of file user.class.php.

References loadRights().

◆ getTooltipContentArray()

User::getTooltipContentArray ( $params)

Return array of data to show into tooltips.

Parameters
array$paramsArray with options, infologin
Since
v18
Returns
array

Reimplemented from CommonObject.

Definition at line 2891 of file user.class.php.

References dol_print_date(), dol_print_phone(), dol_string_nohtmltag(), getDolGlobalString(), getFullName(), getLibStatut(), getUserRemoteIP(), img_picto(), picto_from_langcode(), Form\showphoto(), and yn().

Referenced by getNomUrl().

◆ hasRight()

User::hasRight ( $module,
$permlevel1,
$permlevel2 = '' )

Return if a user has a permission.

You can use it like this: if ($user->hasRight('module', 'level11')). It replaces old syntax: if ($user->rights->module->level1)

Parameters
string$moduleModule of permission to check
string$permlevel1Permission level1 (Example: 'read', 'write', 'delete')
string$permlevel2Permission level2
Returns
int 1 if user has permission, 0 if not.
See also
clearrights(), delrights(), getrights(), hasRight()

Definition at line 772 of file user.class.php.

Referenced by Product\delete(), and Facture\validate().

◆ info()

User::info ( $id)

Load info of user object.

Parameters
int$idId of user to load
Returns
void

Definition at line 3536 of file user.class.php.

References dol_print_error(), and ref.

◆ initAsSpecimen()

User::initAsSpecimen ( )

Initialise an instance with random values.

Used to build previews or test instances. id must be 0 if object instance is a specimen.

Returns
int

Definition at line 3482 of file user.class.php.

References dol_now(), ref, status, and statut.

◆ isNotIntoValidityDateRange()

User::isNotIntoValidityDateRange ( )

Return a link with photo Use this->id,this->photo.

Returns
int 0=Valid, >0 if not valid

Definition at line 2843 of file user.class.php.

References dol_get_first_hour(), dol_get_last_hour(), and dol_now().

◆ LibStatut()

User::LibStatut ( $status,
$mode = 0 )

Return the label of a status of user (active, inactive)

Parameters
int$statusId status
int$mode0=long label, 1=short label, 2=Picto + short label, 3=Picto, 4=Picto + long label, 5=Short label + Picto, 6=Long label + Picto
Returns
string Label of status

Definition at line 3192 of file user.class.php.

References dol_now().

Referenced by getLibStatut().

◆ loadDefaultValues()

User::loadDefaultValues ( )

Load default values from database table into property ->default_values.

Returns
int > 0 if OK, < 0 if KO

Definition at line 720 of file user.class.php.

References dol_print_error(), getDolGlobalString(), and setEventMessages().

Referenced by fetch().

◆ loadParentOf()

User::loadParentOf ( )
private

Load this->parentof that is array(id_son=>id_parent, ...)

Returns
int<-1,1> Return integer <0 if KO, >0 if OK

Definition at line 3716 of file user.class.php.

References dol_print_error(), and dol_syslog().

Referenced by get_full_tree().

◆ loadPersonalConf()

User::loadPersonalConf ( )

Load const values from database table user_param and set it into user->conf->XXX.

Returns
int >= 0 if OK, < 0 if KO

Definition at line 684 of file user.class.php.

References conf(), and error().

Referenced by fetch().

◆ loadRights()

User::loadRights ( $moduletag = '',
$forcereload = 0 )

Load permissions granted to a user->id into object user->rights.

Parameters
string$moduletagLimit permission for a particular module ('' by default means load all permissions)
int$forcereloadForce reload of permissions even if they were already loaded (ignore cache)
Returns
void
See also
clearrights(), delrights(), addrights(), hasRight()

Definition at line 1206 of file user.class.php.

References getDolGlobalString().

Referenced by getrights().

◆ loadStateBoard()

User::loadStateBoard ( )

Load metrics this->nb for dashboard.

Returns
int Return integer <0 if KO, >0 if OK

Definition at line 3952 of file user.class.php.

References dol_print_error(), error(), and getDolGlobalString().

◆ RemoveFromGroup()

User::RemoveFromGroup ( $group,
$entity,
$notrigger = 0 )

Remove a user from a group.

Parameters
int$groupId of group
int$entityEntity
int$notriggerDisable triggers
Returns
int Return integer <0 if KO, >0 if OK

Definition at line 2790 of file user.class.php.

References CommonObject\call_trigger(), dol_syslog(), and error().

◆ replaceThirdparty()

static User::replaceThirdparty ( DoliDB $dbs,
$origin_id,
$dest_id )
static

Function used to replace a thirdparty id with another one.

Parameters
DoliDB$dbsDatabase handler, because function is static we name it $dbs not $db to avoid breaking coding test
int$origin_idOld thirdparty id
int$dest_idNew thirdparty id
Returns
bool

Definition at line 3937 of file user.class.php.

References CommonObject\commonReplaceThirdparty().

◆ send_password()

User::send_password ( $user,
$password = '',
$changelater = 0 )

Send a new password (or instructions to reset it) by email.

Parameters
User$userObject user that send the email (not the user we send to)
string$passwordNew password
int$changelater0=Send clear passwod into email, 1=Change password only after clicking on confirm email.
Returns
int Return integer < 0 si erreur, > 0 si ok

Definition at line 2535 of file user.class.php.

References conf(), dol_hash(), dol_syslog(), error(), and getDolGlobalString().

◆ set_default_rights()

User::set_default_rights ( )

Assign rights by default.

Returns
integer erreur <0, si ok renvoi le nbre de droits par default positions

Definition at line 1949 of file user.class.php.

Referenced by create().

◆ setCategories()

User::setCategories ( $categories)

Sets object to supplied categories.

Deletes object from existing categories not supplied. Adds it to non existing supplied categories. Existing categories are left untouch.

Parameters
int[] | int$categoriesCategory or categories IDs
Returns
int Return integer <0 if KO, >0 if OK

Definition at line 1533 of file user.class.php.

◆ SetInGroup()

User::SetInGroup ( $group,
$entity,
$notrigger = 0 )

Add user into a group.

Parameters
int$groupId of group
int$entityEntity
int$notriggerDisable triggers
Returns
int Return integer <0 if KO, >0 if OK

Definition at line 2734 of file user.class.php.

References CommonObject\call_trigger(), dol_syslog(), and error().

◆ setPassword()

User::setPassword ( $user,
$password = '',
$changelater = 0,
$notrigger = 0,
$nosyncmember = 0,
$passwordalreadycrypted = 0,
$flagdelsessionsbefore = 1 )

Change password of a user.

Parameters
User$userObject user of user requesting the change (not the user for who we change the password). May be unknown.
string$passwordNew password, in clear text or already encrypted (to generate if not provided)
int$changelater0=Default, 1=Save password into pass_temp to change password only after clicking on confirm email
int$notrigger1=Does not launch triggers
int$nosyncmemberDo not synchronize linked member
int$passwordalreadycrypted0=Value is cleartext password, 1=Value is encrypted value.
int$flagdelsessionsbefore1=Save also the current date to ask to invalidate all other session before this date.
Returns
int|string If OK return clear password, 0 if no change (warning, you may retrieve 1 instead of 0 even if password was same), < 0 if error

Definition at line 2393 of file user.class.php.

References CommonObject\call_trigger(), dol_hash(), dol_now(), dol_print_error(), dol_syslog(), error(), getDolGlobalString(), and getRandomPassword().

Referenced by create_from_member(), and update().

◆ setstatus()

User::setstatus ( $status)

Change status of a user.

Parameters
int$statusStatus to set
Returns
int Return integer <0 if KO, 0 if nothing is done, >0 if OK

Definition at line 1474 of file user.class.php.

References CommonObject\call_trigger(), dol_syslog(), status, and statut.

◆ update()

User::update ( $user,
$notrigger = 0,
$nosyncmember = 0,
$nosyncmemberpass = 0,
$nosynccontact = 0 )

Update a user into database (and also password if this->pass is defined)

Parameters
User$userUser making update
int$notrigger1=do not execute triggers, 0 by default
int$nosyncmember0=Synchronize linked member (standard info), 1=Do not synchronize linked member
int$nosyncmemberpass0=Synchronize linked member (password), 1=Do not synchronize linked member
int$nosynccontact0=Synchronize linked contact, 1=Do not synchronize linked contact
Returns
int Return integer <0 if KO, >=0 if OK

Definition at line 1997 of file user.class.php.

References CommonObject\call_trigger(), dol_syslog(), dol_verifyHash(), dolEncrypt(), error(), getDolGlobalString(), CommonObject\insertExtraFields(), isValidEmail(), setPassword(), and setUpperOrLowerCase().

Referenced by create(), and update_ldap2dolibarr().

◆ update_clicktodial()

User::update_clicktodial ( )

Update clicktodial info.

Returns
int Return integer <0 if KO, >0 if OK

Definition at line 2693 of file user.class.php.

References dol_syslog(), and error().

◆ update_last_login_date()

User::update_last_login_date ( )

Update the user's last login date in the database.

Function called when a new connection is made by the user

Returns
int Return integer <0 si echec, >=0 si ok

Definition at line 2351 of file user.class.php.

References dol_now(), dol_syslog(), error(), and getUserRemoteIP().

◆ update_ldap2dolibarr()

User::update_ldap2dolibarr ( & $ldapuser)

Update user using data from the LDAP.

Parameters
Object$ldapuserLadp User
Returns
int Return integer <0 if KO, >0 if OK

Definition at line 3634 of file user.class.php.

References dol_syslog(), getArrayOfSocialNetworks(), getDolGlobalString(), and update().

◆ user_get_property()

User::user_get_property ( $rowid,
$mode )

Return property of user from its id.

Parameters
int$rowidid of contact
string$mode'email', 'mobile', or 'name'
Returns
string Email of user with format: "Full name <email>"

Definition at line 4023 of file user.class.php.

References dol_print_error(), and dolGetFirstLastname().


The documentation for this class was generated from the following file: