[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This chapter describes the usage of EUDC. Most functions and customization options are available through the `Directory Search' submenu of the `Tools' submenu.
3.1 Querying Servers | How queries are performed and handled | |
3.2 Query Form | How to use and customize the query form | |
3.3 Display of Query Results | Controlling how query results are presented | |
3.4 Inline Query Expansion | How to use and customize inline queries | |
3.5 The Server Hotlist | How to use and manage the server hotlist | |
3.6 Multi-server Queries | How to query multiple servers successively | |
3.7 Creating BBDB Records | How to insert query results into your BBDB | |
3.8 Server/Protocol Locals | Customizing on a per server/protocol basis |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
EUDC's basic functionality is to let you query a directory server and return the results back to you. There are several things you may want to customize in this process.
3.1.1 Selecting a Server | The first thing to do | |
3.1.2 Return Attributes | Configuring what the server should return | |
3.1.3 Duplicate Attributes | What to do when records have duplicate attributes |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Before doing any query you will need to set the directory server. You need to specify the name of the host machine running the server software and the protocol to use. If you do not set the server in any fashion, EUDC will ask you for one when you make your first query.
You can set the server by selecting one from your hotlist of servers (see section 3.5 The Server Hotlist) available in the `Server' submenu or by selecting `New Server' in that same menu.
LDAP servers generally require some configuration before you can perform queries on them. In particular, the search base must be configured. If the server you select has no configured search base then EUDC will propose you to configure it at this point. A customization buffer will be displayed where you can edit the search base and other parameters for the server.
ph
, ldap
and bbdb
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Directory servers may be configured to return a default set of
attributes for each record matching a query if the query specifies none.
The variable eudc-default-return-attributes
controls the return
attributes you want to see, if different from the server defaults.
all
then all available attributes are
returned. A value of nil
, the default, means to return the
default attributes as configured in the server.
The server may return several matching records to a query. Some of the records may however not contain all the attributes you requested. You can discard those records.
nil
, entries that do not contain all the requested return
attributes are ignored. Default is t
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Directory standards may authorize different instances of the same attribute in a record. For instance the record of a person may contain several email fields containing different email addresses. When using a QI directory server this is difficult to distinguish from attributes having multi-line values such as the postal address that may contain a line for the street and another one for the zip code and city name. In both cases, EUDC will consider the attribute duplicated.
EUDC has several methods to deal with duplicated attributes. The available methods are:
list
first
concat
duplicate
select
as the method to handle multiple matches in inline expansion queries
(see section 3.4 Inline Query Expansion) because you are presented with the 3
addresses in a selection buffer
Because a method may not be applicable to all fields, the variable
eudc-duplicate-attribute-handling-method
lets you specify either a
default method for all fields or a method for each individual field.
(attr . method)
or a symbol
method. The alist form of the variable associates a method to an
individual attribute name, the second form specifies a method applicable
to all attribute names. Available methods are: list
,
first
, concat
, duplicate
(see above). Defaults to
list
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The simplest way to query your directory server is to use the query
form. You display the query form with the `Query with Form' menu
item or by invoking the command M-x eudc-query-form. The attribute
names presented in this form are defined by the
eudc-query-form-attributes
variable (unless a non-nil
argument is supplied to eudc-query-form
).
Since the different directory protocols to which EUDC interfaces may
use different names for equivalent attributes, EUDC defines its own set
of attribute names and a mapping between these names and their
protocol-specific equivalent through the variable
eudc-protocol-attributes-translation-alist
. Names currently
defined by EUDC are name
, firstname
, email
and
phone
.
name
,
email
and phone
.
nil
argument the function first queries the server for the existing fields
and displays a corresponding form. Not all protocols may support a
non-nil
argument here.
Since the names of the fields may not be explicit enough or adapted to
be directly displayed as prompt strings in the form, the variable
eudc-user-attribute-names-alist
lets you define more explicit
names for directory attribute names. This variable is ignored if
eudc-use-raw-directory-names
is non-nil
.
nil
, use attributes names as defined in the directory.
Otherwise, directory query/response forms display the user attribute
names defined in eudc-user-attribute-names-alist
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Upon successful completion of a form query, EUDC will display a buffer containing the results of the query.
The fields that are returned for each record
are controlled by eudc-default-return-attributes
(see section 3.1.2 Return Attributes).
The display of each individual field can be performed by an arbitrary function which allows specific processing for binary values like images or audio samples as well as values with computer semantics like URLs.
(name . func)
where
name is a lowercased string naming a directory attribute
(translated according to eudc-user-attribute-names-alist
if
eudc-use-raw-directory-names
is non-nil
) and func a
function that will be passed the corresponding attribute values for
display.
This variable has protocol-local definitions (see see section 3.8 Server/Protocol Locals). For instance, it is defined as follows for LDAP:
(eudc-protocol-set 'eudc-attribute-display-method-alist '(("jpegphoto" . eudc-display-jpeg-inline) ("labeledurl" . eudc-display-url) ("audio" . eudc-display-sound) ("labeledurl" . eudc-display-url) ("url" . eudc-display-url)) 'ldap) |
EUDC provides a set of built-in functions to display binary value types:
Right-clicking on a binary value button pops up a contextual menu with
options to process the value. Among these are saving the attribute
value to a file or sending it to an external viewer command. External
viewers should expect the value on their standard input and should
display it or perform arbitrary processing on it. Messages sent to
standard output are discarded. External viewers are listed in the
variable eudc-external-viewers
which you can customize.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Inline query expansion is a powerful method to get completion from your
directory server. The most common usage is for expanding names to email
addresses in mail message buffers. The expansion is performed by the
command M-x eudc-expand-inline which is available from the
`Directory Search' menu but can also be conveniently bound to a key
shortcut (see section 2. Installation) The operation is controlled by the
variables eudc-inline-expansion-format
,
eudc-inline-query-format
,
eudc-expanding-overwrites-query
and
eudc-multiple-match-handling-method
.
If the query fails for a server, other servers may be tried successively until one of them finds a match (see section 3.6 Multi-server Queries).
eudc-inline-query-format
controls how individual words
are mapped onto directory attribute names. After querying the server
for the given string, the expansion specified by
eudc-inline-expansion-format
is inserted in the buffer at
point. If replace-p is t
then this expansion replaces the
query string in the buffer. If eudc-expanding-overwrites-query
is non-nil
then the meaning of replace-p is negated.
nil
all the words will be mapped onto the default
server/protocol attribute name (generally name
).
For instance, use the following
(setq eudc-inline-query-format '((name) (firstname) (firstname name))) |
formats are in fact not limited to EUDC attribute names, you can
use server or protocol specific names in them. If you do so it is
highly recommended to set the variable eudc-inline-query-format
in a protocol or server local fashion (see see section 3.8 Server/Protocol Locals).
For instance you could use the following to match up to three words
against the cn
attribute of LDAP servers:
(eudc-protocol-set 'eudc-inline-query-format '((cn) (cn cn) (cn cn cn)) 'ldap) |
format
. Remaining elements are symbols
corresponding to directory attribute names. The corresponding attribute
values are passed as additional arguments to format
. Default is
("%s" email)
but you may want to consider a value like ("%s
<%s>" name email)
first
select
all
abort
Defaults to select
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
EUDC lets you maintain a list of frequently used servers so that you
can easily switch from one to another. This hotlist appears in the
`Server' submenu. You select a server in this list by clicking on
its name. You can add the current server to the list with the command
M-x eudc-bookmark-current-server. The list is contained in the variable
eudc-server-hotlist
which is stored in and retrieved from the file
designated by eudc-options-file
. EUDC also provides a facility to
edit the hotlist interactively (see section 3.5.1 The Hotlist Edit Buffer).
The hotlist is also used to make queries on multiple servers successively (see section 3.6 Multi-server Queries). The order in which the servers are tried is the order they appear in the hotlist, therefore it is important to sort the hotlist appropriately.
3.5.1 The Hotlist Edit Buffer | An interactive hotlist editing facility |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The hotlist edit buffer offers a means to manage a list of frequently used servers. Commands are available in the context pop-up menu generally bound to the right mouse button. Those commands also have equivalent keybindings.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
When performing inline or form queries, EUDC can try to contact a
sequence of directory servers. When performing form queries EUDC tries
all the servers specified by the variable eudc-multi-query-policy
and displays all the matching records. When performing inline expansion
queries however, EUDC stops trying different servers as soon as a match
has been found on one of them.
current-server
hotlist
eudc-max-servers-to-query
servers in the hotlist are tried
in order
server-then-hotlist
eudc-max-servers-to-query
-1 servers
in the hotlist are tried. This is the default.
nil
, indicates
that all available servers should be tried.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
With EUDC, you can automatically create BBDB records (see section `BBDB' in BBDB Manual) from records you get from a directory server. You do this by moving point to the appropriate record in a query result display buffer and invoking the command M-x eudc-insert-record-at-point-into-bbdb with the keyboard binding b (1), or with the menu. EUDC cannot update an existing BBDB record and will signal an error if you try to insert a record matching an existing one.
It is also possible to export to BBDB the whole batch of records contained in the directory query result with the command M-x eudc-batch-export-records-to-bbdb.
Because directory systems may not enforce a strict record format, local server installations may use different attribute names and have different ways to organize the information. Furthermore BBDB has its own record structure. For these reasons converting a record from its external directory format to the BBDB format is a highly customizable process.
(bbdb-field . spec-or-list)
.
bbdb-field is the name of a field
that must be defined in your BBDB environment (standard field names are
name
, company
, net
, phone
, address
and notes
).
spec-or-list is either a single mapping specification or a list of
mapping specifications. Lists of mapping specifications are valid for
the phone
and address
BBDB fields only. specs are
actually s-expressions which are evaluated as follows:
bbdb-create-internal
).
eudc-bbdbify-phone
and eudc-bbdbify-address
are provided as
convenience functions to parse phones and addresses.
The default value of the PH-specific value of that variable is
eudc-ph-bbdb-conversion-alist
:
((name . name) (net . email) (address . (eudc-bbdbify-address address "Address")) (phone . ((eudc-bbdbify-phone phone "Phone") (eudc-bbdbify-phone office_phone "Office Phone")))) |
This means that:
name
field of the BBDB record gets its value
from the name
attribute of the directory record
net
field of the BBDB record gets its value
from the email
attribute of the directory record
address
field of the BBDB record is obtained by parsing the
address
attribute of the directory record with the function
eudc-bbdbify-address
phone
fields are created (when possible) in the BBDB record.
The first one has Phone for location and its value is obtained by
parsing the phone
attribute of the PH/QI record with the function
eudc-bbdbify-phone
. The second one has Office Phone for location
its value is obtained by parsing the office_phone
attribute of the
PH/QI record with the function eudc-bbdbify-phone
.
eudc-bbdb-conversion-alist
. It parses phone into a vector
compatible with bbdb-create-internal
. phone is either a string
supposedly containing a phone number or a list of such strings which are
concatenated. location is used as the phone location for BBDB.
eudc-bbdb-conversion-alist
. It parses addr into a vector
compatible with bbdb-create-internal
. addr should be an
address string of no more than four lines or a list of lines. The last
line is searched for the zip code, city and state name. location
is used as the phone location for BBDB.
Note that only a subset of the attributes you selected with
eudc-default-return-attributes
and that are actually displayed may
actually be inserted as part of the newly created BBDB record.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
EUDC can be customized independently for each server or directory protocol. All variables can be given local bindings that are activated when a particular server and/or protocol becomes active. This is much like buffer-local bindings but on a per server or per protocol basis.
3.8.1 Manipulating local bindings | Functions to set and query local bindings |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
EUDC offers functions that let you set and query variables on a per server or per protocol basis.
The following predicates allow you to test the existence of server/protocol local bindings for a particular variable.
nil
if var has server-local bindings
nil
if var has protocol-local bindings
The following functions allow you to set the value of a variable with various degrees of localness.
eudc-protocol
. The current binding of var is changed only
if protocol is omitted.
eudc-server
. The current binding of var is changed only if
server is omitted.
The following variables allow you to query the various bindings of a variable (local or non-local).
unbound
if var has no EUDC default value.
unbound
if var has no value local to protocol.
protocol defaults to eudc-protocol
.
unbound
if var has no value local to server.
server defaults to eudc-server
.
Changing a protocol-local or server-local value of a variable has no
effect on its current value. The following command is used to
synchronize the current values of variables with their local values
given the current eudc-server
and eudc-protocol
:
[ << ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |