Courseware:IT Connect - 09.0 Contacts
		
		
		
		Jump to navigation
		Jump to search
		
Book on Contacts App
The Contacts App
The Contacts App allows you to upload your contacts and provide them to other Apps and phones:
- the PBX will augment incoming and outgoing call information with a name-id by looking up the calling/called party-id in Contacts (and add them to the CDR information)
- the phone App will use Contacts to lookup names for outgoing calls as well as retrieve detail information for incoming calls
- the IP phones will use Contacts (via LDAP) to do name resolution for incoming and outgoing calls which have no name information yet (e.g. supplied by the PBX)
Create contact entries manually
Before Contacts can provide your contact information to Apps and phones, you have to create them. The easiest way to generate entries is to create them manually. 
In the upper part of the new window you will see a drop-down menu. In this drop-down menu you can  select the directory for which you want to create a contact. At the moment there is no directory other than your own personal directory. So we will use this for now.
 select the directory for which you want to create a contact. At the moment there is no directory other than your own personal directory. So we will use this for now.
 select the directory for which you want to create a contact. At the moment there is no directory other than your own personal directory. So we will use this for now.
 select the directory for which you want to create a contact. At the moment there is no directory other than your own personal directory. So we will use this for now. In the Numbers section of this window you can assign different numbers, SIP URIs or email addresses to this contact. You can assign different attributes like Work, Private or Mobile to this numbers in order to distinguish them from each other. To add more properties to a user, you can click
 In the Numbers section of this window you can assign different numbers, SIP URIs or email addresses to this contact. You can assign different attributes like Work, Private or Mobile to this numbers in order to distinguish them from each other. To add more properties to a user, you can click  the +Property icon and select an attribute to add.
 the +Property icon and select an attribute to add.  In the Common section of this window you can set the basic settings of this contact such as Name, Surname, Company name and Display Name. Underneath you can
 In the Common section of this window you can set the basic settings of this contact such as Name, Surname, Company name and Display Name. Underneath you can  set an optional address of this contact.
 set an optional address of this contact.If you click  on +Field you can set
 on +Field you can set  even more parameters for this contact like a private address or
 even more parameters for this contact like a private address or  further details.
 further details.
 on +Field you can set
 on +Field you can set  even more parameters for this contact like a private address or
 even more parameters for this contact like a private address or  further details.
 further details. Please create a entry with the following properties
 Please create a entry with the following properties- Work: +1-632-555-0105 
- Mobile: +1-917-987654 
- Email: clark.kent@dailyplanet.net 
- Name: Clark 
- Surname: Kent 
- Company: Daily Planet 
- Display name: Superman 
- Street: 2525 Broadway 
- ZIP Code: 10025 
- City: Metropolis 
- State: NY 
- Country: USA 
- Details->Department: Newsroom 
- Details->Info: He is Superman 
- Details->URL: www.dailyplanet.net 
The search index
You can use most fields to search.
 For example, you can search for both
 For example, you can search for both Clark  and Planet  to find  Superman.
 Superman.
The list of contact entry properties you can use for full-text search is given in the List of Text-Indexable Attributes of the concept article in our wiki.
 List of Text-Indexable Attributes of the concept article in our wiki. 
As you'd expect, the search is case-insensitive. So it doesn't matter if you search for Clark or clark.
However, the search always does a headmatch. That is, you can search for clark but not for lark to find Clark Kent. While this is generally convenient, it can sometimes be surprising. Even though Clark's email address is clark.kent@dailyplanet.net, you won't find him if you search for dailyplanet.net (because of the headmatch).
 For example, you can search for both
 For example, you can search for both  Superman.
 Superman.The list of contact entry properties you can use for full-text search is given in the
 List of Text-Indexable Attributes of the concept article in our wiki.
 List of Text-Indexable Attributes of the concept article in our wiki. As you'd expect, the search is case-insensitive. So it doesn't matter if you search for Clark or clark.
However, the search always does a headmatch. That is, you can search for clark but not for lark to find Clark Kent. While this is generally convenient, it can sometimes be surprising. Even though Clark's email address is clark.kent@dailyplanet.net, you won't find him if you search for dailyplanet.net (because of the headmatch).
Although you can enter phone numbers in a contact with or without decorations (e.g., +1-632-555-0105 versus +16325550105), you can only search for the undecorated version. That is, even though you may have defined a contact with +1-632-555-0105 as a number, you would only find it if you searched for +16325550105.
Multi-word strings (as in clark daily) are split into words and the search results need to match all of those words (logical and).
To be even more precise, also the attribute values are split into words so that e.g. "Daily Planet" is split into 2 words "daily" and "planet". This why you found Clark in the first place when you searched for Planet, despite of the headmatch.
Create entries per vCard
If you have a digital business card as a vCard, there is an easy way to import it into your Contacts app database. Just drag and drop it into the app and save the contact in the correct directory.
 To test it you can
 To test it you can  download a VCF from moodle and then drag and drop it to contacts.
 download a VCF from moodle and then drag and drop it to contacts.  Select the directory you want to save the contact to, add any additional information and
 Select the directory you want to save the contact to, add any additional information and  click save.
 click save.
 To test it you can
 To test it you can  download a VCF from moodle and then drag and drop it to contacts.
 download a VCF from moodle and then drag and drop it to contacts.  Select the directory you want to save the contact to, add any additional information and
 Select the directory you want to save the contact to, add any additional information and  click save.
 click save.To export a vCard from contacts, you have to open the contacts, click on Share and then click  download as VCard.
 download as VCard.
 download as VCard.
 download as VCard.Uploading contact information
Another possibility to enter contacts to your Contacts App is uploading a CSV file. Please note that the CSV file upload feature is only part of your Contacts Admin app. This App should be available to administrators only and is therefore enabled  in the list of Apps in the Config Admin template.
 in the list of Apps in the Config Admin template.
 in the list of Apps in the Config Admin template.
 in the list of Apps in the Config Admin template.As we have seen before with other Apps, Contacts also has an API that allows other Apps to access contact information. This is known as Contacts-SearchApi in the list of Apps and it is ticked in the Config User template so that all users have access to it. 
  
 Add the Contacts-Admin App to your home screen and start it.
 Add the Contacts-Admin App to your home screen and start it. Searching for names does not make sense yet, as only your manually created name can be found.
 But you can
 But you can  import a sample CSV file which we have prepared (download
 import a sample CSV file which we have prepared (download  contact-sample.utf8 and save it to your computer):
 contact-sample.utf8 and save it to your computer):- in myApps, start Contacts Admin (you may want to open it in a separate window if you're using the native myApps)
- click on the hamburger menu on the upper right
- click on + Import Contacts
- select contact-sample.utf8 from your computer
- confirm the All existing data will be overwritten ... question
- 4 records are imported
- type an e in to the search field
- and eh voilà, you get  the result the result
Note that the shown entry shows its source as contacts-sample.utf8, whereas when you search for c the result (Superman) is marked as being from source Personal directory: ckl.
 When you use the Import Contacts feature, a new directory is created when you upload another CSV file, unless you upload a file with the same filename you uploaded before. In this case, the directory is updated.
 When you use the Import Contacts feature, a new directory is created when you upload another CSV file, unless you upload a file with the same filename you uploaded before. In this case, the directory is updated.Phone number format
You need to maintain the phone numbers in your directory in a proper format so that both dialing them from the directory (forward lookup) and resolving incoming numbers to names (reverse lookup) work well. This is true for both the manually created entries and numbers from the CSV file. Please keep that in mind when you instruct users.
Fortunately, the rules are not that difficult:
- numbers must be full international numbers including country code, area code (if you have them in your country) and subscriber number
- it must start with a plus sign (+)
- all sort of decoration (such as parentheses (), dashes -, white space etc.) are allowed
- an extra 0 preceding the area code is ok
- there must be no international (00) or national (0) access codes
For example, all of these examples
  
- +49 (7031) 73009-0
- +49(7031)73009-0
- +497031730090
- +49/7031/730090
- +49 (07031) 73009-0
- +49 07031 73009 0
- +49 (0) 703173009-0
However  
- +0049 (7031) 73009-0 (bad international access code 00)
- 0049 (7031) 73009-0 (no +)
- 07031 73009-0 (missing country code)
- +49 7031 73009#0 (# and * are not valid decoration)
Note that some of these formats can still be dialed but reverse lookup will not work. 
 
Maintaining a Contacts File
An input file for Contacts is basically a semicolon (;) separated CSV file. 
The first line of this file must contain predefined column headers as follows:
givenname;sn;company;displayname;email;telephonenumber;mobile;...;url;sip
The following lines contain the contact data and must have the same column order as the first line has. The order of the columns does not matter as long as all lines follow the same order. Also, you can remove entire columns (from both the header and the data lines).
This is a quite familiar file structure known as comma separated values (CSV) file. However, one thing makes it a bit difficult: its content must be encoded as UTF8. This is why our sample file uses file extension .utf8.
 If you can handle this, it is the format to go with. However, if you think you could easily open and edit this with Excel, then the answer "is No, unfortunately not". The reason for this is that Excel expects the file to be encoded differently. If you try to open it with Excel anyway, you will see that the  names look strange in parts. Newer Excel versions (2016 and up) can handle UTF8, but it is less than obvious how to work with this.
 names look strange in parts. Newer Excel versions (2016 and up) can handle UTF8, but it is less than obvious how to work with this.
 names look strange in parts. Newer Excel versions (2016 and up) can handle UTF8, but it is less than obvious how to work with this.
 names look strange in parts. Newer Excel versions (2016 and up) can handle UTF8, but it is less than obvious how to work with this.Using Excel
 Many people do prefer using Excel however. This can be done using a real Excel file where the contact data is maintained. We provide it as  contacts.sample.xls. You can download it to your computer.
 contacts.sample.xls. You can download it to your computer. 
 contacts.sample.xls. You can download it to your computer.
 contacts.sample.xls. You can download it to your computer. This file (should be compatible down to Excel 97, we tested it down to Excel 2010) can be edited as usual with Excel  without any encoding hassle.
 without any encoding hassle.
 without any encoding hassle.
 without any encoding hassle.However, you can't upload the file to Contacts. Instead, when you're done editing in Excel, you would click on the Save as UTF8 button which creates an UTF8 CSV file version of your excel file. You can then upload this file.
There is also a version of this file that uses the newer .xslm file type ( contacts.sample.xlsm) if you have problems opening the old .xsl file type.
 contacts.sample.xlsm) if you have problems opening the old .xsl file type.
 contacts.sample.xlsm) if you have problems opening the old .xsl file type.
 contacts.sample.xlsm) if you have problems opening the old .xsl file type.Maintaining the column headers
The first lines (before the empty line) are considered column headers. You can use Excel's hide row function to hide the header rows in the languages you are not interested in (and also the first line that contains the technical column headers we talked about before). You could even remove these lines, except for the first line and the empty line that follows the header lines. We therefore recommend to rather hide the lines so you do not run the risk of accidentally deleting the wrong ones.
If you do not need a column, you can either hide or delete it (except for the extAnchor column which can be hidden but not deleted, see below).
You can even re-order the columns to better suit your needs. 
Using the extAnchor column
When you have a closer look at the provided Excel file, you will notice that the first column (A) is hidden. If you un-hide it, you will see that it has extAnchor as column header. 
This column (as described in  
 Concept App Service Contacts ) serves to identify a specific entry so that Contacts can relate the line to its internal database entries. Fortunately, you do not need to maintain it yourself. Instead, the Save as UTF8 button will do it for you. The only thing you need to understand is that this column needs to be present in your Excel file. So best just hide it again and forget about it then  .
.
 
  .
.Importing contacts from Outlook
Outlook can export contact data to a .csv file. However, it also does not use UTF8 and besides that, the export process is tedious and slow.
But you can simply copy and paste your contact data to Excel. The way to go is as follows:
- open your contacts in Outlook
- switch to the List view
- open your contacts XLS file
- arrange the columns so that they match the column order in your Outlook view
- copy the desired contacts
- paste them in to Excel
Managing directories
You can see all directories  by clicking the Burger Menu and then Directories in your Contacts Admin app.
 by clicking the Burger Menu and then Directories in your Contacts Admin app.  A list of all personal and CSV file directories is displayed.
 A list of all personal and CSV file directories is displayed.
   by clicking the Burger Menu and then Directories in your Contacts Admin app.
 by clicking the Burger Menu and then Directories in your Contacts Admin app.  A list of all personal and CSV file directories is displayed.
 A list of all personal and CSV file directories is displayed.If you click on the  +Directory icon, you can create a directory. You just need to gibe it a name. We can create a directory per department and import a .csv file into that directory. Using the access control feature, we can allow certain users or groups to access this directory.
 +Directory icon, you can create a directory. You just need to gibe it a name. We can create a directory per department and import a .csv file into that directory. Using the access control feature, we can allow certain users or groups to access this directory.
 +Directory icon, you can create a directory. You just need to gibe it a name. We can create a directory per department and import a .csv file into that directory. Using the access control feature, we can allow certain users or groups to access this directory.
 +Directory icon, you can create a directory. You just need to gibe it a name. We can create a directory per department and import a .csv file into that directory. Using the access control feature, we can allow certain users or groups to access this directory.If you want to  add new contacts to this directory, you can export the contacts of the directory, add the contact to the .csv file and then upload it again. To import contacts to an already existing directory, the .csv file can be named as you like.
 add new contacts to this directory, you can export the contacts of the directory, add the contact to the .csv file and then upload it again. To import contacts to an already existing directory, the .csv file can be named as you like.
 add new contacts to this directory, you can export the contacts of the directory, add the contact to the .csv file and then upload it again. To import contacts to an already existing directory, the .csv file can be named as you like.
 add new contacts to this directory, you can export the contacts of the directory, add the contact to the .csv file and then upload it again. To import contacts to an already existing directory, the .csv file can be named as you like. Please create a directory named
 Please create a directory named  by clicking the +Contact icon and
 by clicking the +Contact icon and  select the soccer club directory from the drop down menu. For simplicity, just
 select the soccer club directory from the drop down menu. For simplicity, just  add the name and number of a contact you like.
 add the name and number of a contact you like.As a next step, we want to share this phone-book with Mario Rossi, as he wants to see all contacts of the soccer club as well.
 To do this, let's go back to our directories and
 To do this, let's go back to our directories and  add a rule for our soccer club.
 add a rule for our soccer club.  Select the Type User and add
 Select the Type User and add If you log in to Mario's myApps you can open his Contacts App and search for the newly created entry. This will be successful. To log into Mario's myApps please use a different browser than you already use. Browse to http://hq.dvl-ckl2.training.innovaphone.com  and use the Username (mro ) and Password you configured for Mario in the Users Admin App. Afterwards you need to confirm your login attempt for the two factor authentication. Therefore, go to  
 training-mail.innovaphone.com: owa  and use the following credentials to log in and click the confirm link in your received mail:
 
 Email username: mario.rossi.dvl-ckl2@class.local 
  Email password: ckl-pw 
  If you want to add a contact from Mario's Contacts app to the Soccer club directory, you will not be successful. Mario does not have sufficient rights to do this. 
   In order to give Mario rights to add contacts to your soccer club directory, you need to enable
 In order to give Mario rights to add contacts to your soccer club directory, you need to enable  the Admin checkmark in his rule. Once you activated it, you will see a
 the Admin checkmark in his rule. Once you activated it, you will see a  shield icon as it is the case with your user. Any user with this icon can add, edit or delete contacts in this directory.
 shield icon as it is the case with your user. Any user with this icon can add, edit or delete contacts in this directory. You can also add and modify directories using the Contacts App (as opposed to the Contacts Admin App). However, you can only modify such directories where a rule for yourself with the Admin check-mark ticked exists.
 You can also add and modify directories using the Contacts App (as opposed to the Contacts Admin App). However, you can only modify such directories where a rule for yourself with the Admin check-mark ticked exists.Sharing a directory with a group
You can also share a directory with a PBX group. This is not that difficult but we first need to create this group in the PBX so we can use it for this purpose.
 
  Please open the Groups plugin in the Settings app and create a group called
 Please open the Groups plugin in the Settings app and create a group called soccer .  Add Lisa and Jean as active members to this group. The active membership is important in this case.
 Add Lisa and Jean as active members to this group. The active membership is important in this case.
 Going back to our soccer club directory in our Contacts Admin app (Burger Menu/Directories),we can now create a new rule. This rule should allow every member of the PBX group access to the soccer club directory. Therefore please click on +Rule and select the Type Group. Select the group
 Going back to our soccer club directory in our Contacts Admin app (Burger Menu/Directories),we can now create a new rule. This rule should allow every member of the PBX group access to the soccer club directory. Therefore please click on +Rule and select the Type Group. Select the group soccer  from the dropdown menu.  Afterwards please save this rule.
 Afterwards please save this rule.
  
  
  
 
  Please open the Groups plugin in the Settings app and create a group called
 Please open the Groups plugin in the Settings app and create a group called  Add Lisa and Jean as active members to this group. The active membership is important in this case.
 Add Lisa and Jean as active members to this group. The active membership is important in this case. Going back to our soccer club directory in our Contacts Admin app (Burger Menu/Directories),we can now create a new rule. This rule should allow every member of the PBX group access to the soccer club directory. Therefore please click on +Rule and select the Type Group. Select the group
 Going back to our soccer club directory in our Contacts Admin app (Burger Menu/Directories),we can now create a new rule. This rule should allow every member of the PBX group access to the soccer club directory. Therefore please click on +Rule and select the Type Group. Select the group  Afterwards please save this rule.
 Afterwards please save this rule.To see if this configuration is working you have to log in to Lisa's or Jean's myApps. We recommend to use another browser for this. Browse to http://hq.dvl-ckl2.training.innovaphone.com  and use the Username(lsv , jdu  and Password you configured for Lisa or Jean in the Users Admin App. Afterwards you need to confirm your login attempt for the two factor authentication. Therefore, go to  
 training-mail.innovaphone.com: owa  and use the following credentials to log in and click the confirm link in your received mail:
 
 Email username: jean.dupont.dvl-ckl2@class.local 
  Email password: ckl-pw 
or
Email username: lisa.svensson.dvl-ckl2@class.local 
  Email password: ckl-pw 
If you search for the contact entry you created for the soccer club, you will be successful.
Personal directories versus imported files
 If you compare the  access rights for an imported CSV such as contacts-sample.utf8 to the
 access rights for an imported CSV such as contacts-sample.utf8 to the  access rights for a personal directory, you will notice that the imported CSV directory simply has defined no access right at all. In contrast to that, the personal only has a single rule, which is
 access rights for a personal directory, you will notice that the imported CSV directory simply has defined no access right at all. In contrast to that, the personal only has a single rule, which is  yourself as a user with Admin rights.
 yourself as a user with Admin rights. 
 access rights for an imported CSV such as contacts-sample.utf8 to the
 access rights for an imported CSV such as contacts-sample.utf8 to the  access rights for a personal directory, you will notice that the imported CSV directory simply has defined no access right at all. In contrast to that, the personal only has a single rule, which is
 access rights for a personal directory, you will notice that the imported CSV directory simply has defined no access right at all. In contrast to that, the personal only has a single rule, which is  yourself as a user with Admin rights.
 yourself as a user with Admin rights.  A directory with no access rules at all is available to anyone. An imported CSV is created this way.
 A directory with no access rules at all is available to anyone. An imported CSV is created this way. A personal directory is an ordinary directory with only a single access rule specifying yourself with Admin rights. It is created implicitly for each user (that is, you do not need to create it explicitly).
 A personal directory is an ordinary directory with only a single access rule specifying yourself with Admin rights. It is created implicitly for each user (that is, you do not need to create it explicitly).Directories and PBX reverse lookup
When the PBX performs a reverse lookup to find a name id for an incoming CDPN or CGPN, it will send the user information to the Contacts LDAP server along with the search request. 
 In other words, the name resolution in the PBX takes into account all directories that are available to the user.
 In other words, the name resolution in the PBX takes into account all directories that are available to the user.  . A brief summary of all Contacts App features is displayed.
. A brief summary of all Contacts App features is displayed.

 for which you want to create a contact. At the moment there is no directory other than your own personal directory. So we will use this for now.
 for which you want to create a contact. At the moment there is no directory other than your own personal directory. So we will use this for now. of this window you can assign different numbers, SIP URIs or email addresses to this contact. You can assign different attributes like Work, Private or Mobile to this numbers in order to distinguish them from each other. To add more properties to a user, you can click
 of this window you can assign different numbers, SIP URIs or email addresses to this contact. You can assign different attributes like Work, Private or Mobile to this numbers in order to distinguish them from each other. To add more properties to a user, you can click  and select an attribute to add.
 and select an attribute to add.  of this window you can set the basic settings of this contact such as Name, Surname, Company name and Display Name. Underneath you can
 of this window you can set the basic settings of this contact such as Name, Surname, Company name and Display Name. Underneath you can 
 you can set
 you can set  like a private address or
 like a private address or 
 .
. you want to save the contact to, add any additional information and
 you want to save the contact to, add any additional information and  .
.
 in the Config Admin template.
 in the Config Admin template.
 in parts. Newer Excel versions (2016 and up) can handle UTF8, but it is less than obvious how to work with this.
 in parts. Newer Excel versions (2016 and up) can handle UTF8, but it is less than obvious how to work with this. .
. is displayed.
 is displayed. you can create a directory. You just need to gibe it a name. We can create a directory per department and import a .csv file into that directory. Using the access control feature, we can allow certain users or groups to access this directory.
 you can create a directory. You just need to gibe it a name. We can create a directory per department and import a .csv file into that directory. Using the access control feature, we can allow certain users or groups to access this directory. , you can export the contacts of the directory, add the contact to the .csv file and then upload it again. To import contacts to an already existing directory, the .csv file can be named as you like.
, you can export the contacts of the directory, add the contact to the .csv file and then upload it again. To import contacts to an already existing directory, the .csv file can be named as you like. For simplicity, just
 For simplicity, just  you like.
 you like. 
  and add
 and add  in his rule. Once you activated it, you will see a
 in his rule. Once you activated it, you will see a  as it is the case with your user. Any user with this icon can add, edit or delete contacts in this directory.
 as it is the case with your user. Any user with this icon can add, edit or delete contacts in this directory. and create a group called
 and create a group called  The active membership is important in this case.
 The active membership is important in this case.
 such as contacts-sample.utf8 to the
 such as contacts-sample.utf8 to the  , you will notice that the imported CSV directory simply has defined no access right at all. In contrast to that, the personal only has a single rule, which is
, you will notice that the imported CSV directory simply has defined no access right at all. In contrast to that, the personal only has a single rule, which is  .
.