-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathlbdbq.man.in
427 lines (427 loc) · 11.5 KB
/
lbdbq.man.in
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
.\" -*- nroff -*-
.\" Copyright (c) 1998-2024 Roland Rosenfeld <[email protected]>
.\"
.\" This program is free software; you can redistribute it and/or modify
.\" it under the terms of the GNU General Public License as published by
.\" the Free Software Foundation; either version 2 of the License, or
.\" (at your option) any later version.
.\"
.\" This program is distributed in the hope that it will be useful,
.\" but WITHOUT ANY WARRANTY; without even the implied warranty of
.\" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
.\" GNU General Public License for more details.
.\"
.\" You should have received a copy of the GNU General Public License
.\" along with this program; if not, write to the Free Software Foundation,
.\" Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301,, USA.
.\"
.TH LBDBQ 1 "July 2024" "Unix" "User Manuals"
.SH NAME
lbdbq \- query program for the little brother's database
.SH SYNOPSIS
.B lbdbq
.I something
.br
.B lbdbq
.RB [ -v | --version | -h | --help ]
.SH DESCRIPTION
.B lbdbq
is the client program for the little brother's database. It will
attempt to invoke various modules to gather information about persons
matching
.IR something .
E.g., it may look at a list of addresses from which you have received
mail, it may look at YP maps, or it may try to finger
.IR something @ "<various hosts>" .
.PP
The behavior is configurable: Upon startup,
.B lbdbq
will source the shell scripts:
.RS
.I @sysconfdir@/lbdb.rc
.br
.I $XDG_CONFIG_HOME/lbdb/config
.br
.I $HOME/.lbdbrc
.br
.I $HOME/.lbdb/lbdbrc
.br
.I $HOME/.lbdb/rc
.RE
if they exist.
.PP
They can be used to set the following global variables:
.TP
.B MODULES_PATH
a space separated list of directories, where
.B lbdbq
should look for modules.
.TP
.B METHODS
a space separated list of the modules to use.
.TP
.B SORT_OUTPUT
If you set this to
.I false
or
.IR no ,
lbdbq won't sort the addresses but returns them in reverse order
(which means that the most recent address in m_inmail database is
first). If you set this to
.IR name ,
lbdbq sorts the output by real name. If you set this to
.IR comment ,
it sort the output by the comment (for example the date in
.BR m_inmail ).
.I reverse_comment
realizes the same as
.IR comment ,
but in reverse order, so the most recent timestamp of m_inmail may be
on top. If you set SORT_OUTPUT to
.IR address ,
lbdbq sorts the output by addresses (that's the default).
.TP
.B KEEP_DUPES
If you set this to
.I true
or
.IR yes ,
lbdbq won't remove duplicate addresses with different real name
comment fields.
.PP
Note that there
.I are
defaults, so you should most
probably modify these variables using constructs like this:
.nf
MODULES_PATH="$MODULES_PATH $HOME/lbdb_modules"
.fi
.PP
Additionally, modules may have configuration variables of
their own.
.SH MODULES
Currently, the following modules are supplied with lbdb:
.TP
.B m_finger
This module will use finger to find out something more about a person.
The list of hosts do be asked is configurable; use the
.B M_FINGER_HOSTS
variable. Note that "localhost" will mean an invocation of your local
.BR finger (1)
binary, and should thus work even if you don't provide the finger
service to the network.
.B m_finger
tries to find out the machines mail domain name in
.IR /etc/mailname ,
by parsing a
.I sendmail.cf
file (if it finds one) and by reading
.I /etc/hostname
and
.IR /etc/HOSTNAME .
If you know that this fails on your machine, or you want to force lbdbq
to consider some other name to be the local mail domain name (misconfigured
SUNs come to mind here), you can specify a name using the
.B MAIL_DOMAIN_NAME
variable. If this variable is set by you, no probing will be done by
.BR lbdbq .
.TP
.B m_inmail
This module will look up user name fragments in a list of mail
addresses created by
.BR lbdb-fetchaddr (1).
By default this uses
.IR $XDG_DATA_HOME/lbdb/m_inmail.db ,
which is overridden, if
.I $HOME/.lbdb/m_inmail.utf-8
exists (the old default) as its database file, but this can be changed
using
.B INMAIL_DB
variable (but do not forget to change this in the
.BR lbdb-fetchaddr (1)
call using option \-f, too).
.TP
.B m_passwd
This module searches for matching entries in your local /etc/passwd
file. It evaluates the local machine mail domain in the same way
.B m_finger
does. If you set
.BR PASSWD_IGNORESYS=true ,
this module ignores all system accounts and only finds UIDs between
1000 and 29999 (all other UIDs are reserved on a Debian system).
.TP
.B m_yppasswd
This module searches for matching entries in the NIS password database
using the command ``ypcat passwd''.
.TP
.B m_nispasswd
This module searches for matching entries in the NIS+ password database
using the command ``niscat passwd.org_dir''.
.TP
.B m_getent
This module searches for matching entries in whatever password
database is configured using the command ``getent passwd''.
.TP
.BR m_pgp2 ", " m_pgp5 ", " m_gpg
These modules scan your PGP 2.*, PGP 5.* or GnuPG public key ring for
data. They use the programs
.BR pgp (1),
.BR pgpk (1),
or
.BR gpg (1)
to get the data.
.TP
.B m_fido
This module searches your Fido nodelist, stored in
.I $HOME/.lbdb/nodelist
created by
.BR nodelist2lbdb (1).
.TP
.B m_abook
This module uses the program
.BR abook (1),
a text based address book application to search for addresses. You
can define multiple abook address books by setting the variable
.B ABOOK_FILES
to a space separated list.
.TP
.B m_goobook
This module uses the program
.BR goobook (1),
a tool to access Google contacts via command line.
.TP
.B m_addr_email
This module uses the program
.BR addr-email (1),
a text based frontend to the Tk
.BR addressbook (1)
application.
.TP
.B m_muttalias
This module searches the variable
.B MUTTALIAS_FILES
(a space separated list) of files in
.B MUTT_DIRECTORY
that contain mutt aliases. File names without leading slash will have
.B MUTT_DIRECTORY
(defaults to
.BI $HOME /.mutt
or
.BR $HOME ,
if
.BI $HOME /.mutt
does not exist) prepended before the file name. Absolute file names
(beginning with
.IR / )
will be taken direct.
.TP
.B m_pine
This module searches
.BR pine (1)
addressbook files for aliases. To realize this it first inspects the
variable
.BR PINERC .
If it isn't set, the default
.RI ` "/etc/pine.conf /etc/pine.conf.fixed .pinerc" '
is used. To suppress inspecting the
.B PINERC
variable, set it to
.IR no .
It than takes all
.B address-book
and
.B global-address-book
entries from these pinerc files and adds the contents of the variable
.B PINE_ADDRESSBOOKS
to the list, which defaults to
.RI ` "/etc/addressbook .addressbook" '.
Then these addressbooks are searched for aliases. All filenames
without leading slash are searched in
.BR $HOME .
.TP
.B m_palm
This module searches the Palm address database using the
.BR Palm::PDB (3pm)
and
.BR Palm::Address (3pm)
Perl modules from CPAN.
It searches in the variable
.B PALM_ADDRESS_DATABASE
or if this isn't set in
.IR $HOME/.jpilot/AddressDB.pdb .
.TP
.B m_gnomecard
This module searches for addresses in your GnomeCard database files.
The variable
.B GNOMECARD_FILES
is a whitespace separated list of GnomeCard data files. If this
variable isn't defined, the module searches in
.BI $HOME /.gnome/GnomeCard
for the GnomeCard database or at least falls back to
.BI $HOME /.gnome/GnomeCard.gcrd\fR.
If a filename does not start with a slash, it is prefixed with
.BR $HOME/ .
.TP
.B m_bbdb
This module searches for addresses in your (X)Emacs BBDB (big brother
database). It doesn't access ~/.bbdb directly (yet) but calls
.BR emacs (1)
or
.BR xemacs (1)
with a special mode to get the information (so don't expect too much
performance in this module). You can configure the
.B EMACS
variable to tell this module which emacsen to use. Otherwise it will
fall back to
.B emacs
or
.BR xemacs.
.TP
.B m_ldap
This module queries an LDAP server using the
.BR Net::LDAP (3pm)
Perl modules from CPAN. It can be configured using an external
resource file
.I @sysconfdir@/lbdb_ldap.rc
or
.I $XDG_CONFIG_HOME/lbdb/ldap.rc
or
.I $HOME/.lbdb/ldap.rc
or
.IR $HOME/.mutt_ldap_query.rc .
You can explicitly define a LDAP query in this file or you can use one
or more of the predefined queries from the
.B %ldap_server_db
in this file. For this you have to define a space separated list of
nicknames from entries in the variable
.BR LDAP_NICKS .
.TP
.B m_wanderlust
This module searches for addresses stored in your
.I $WANDERLUST_ADDRESSES
(or by default in
.IR $HOME/.addresses )
file, an addressbook of
.BR WanderLust .
.TP
.B m_osx_addressbook
This module queries the OS X AddressBook. It is only available on OS
X systems.
.TP
.B m_evolution
This module queries the Ximian Evolution address book. It depends on
the program
.BR evolution-addressbook-export ,
which is shipped with evolution.
.TP
.B m_vcf
This module uses a bundled little perl program named vcquery to search
for addresses from the space\-separated set of vCard files defined in
.IR $VCF_FILES .
.TP
.B m_khard
This module searches a CardDAV address book via
.BR khard (1).
.TP
.B m_mu
This module uses the program
.BR mu-cfind (1),
which searches in the index file generated by the mu tool.
You can filter the results with the variables
.B MU_AFTER
(the number of seconds since 1970-01-01 UTC) and
.B MU_PERSONAL
(set to
.I true
or
.IR yes ,
remember to invoke
.BR mu-index (1)
with
.IR --my-address )
.PP
Feel free to create your own modules to query other database resources,
YP maps, and the like.
.B m_finger
should be a good example of how to do it.
.PP
If you create your own modules or have other changes and feel that
they could be helpful for others, don't hesitate to submit them to the
author for inclusion in later releases.
.PP
Finally, to use
.B lbdbq
from mutt, add the following line to your
.I $HOME/.muttrc:
.nf
set query_command="lbdbq %s"
.fi
.SH OPTIONS
.IP "-v | --version"
Print version number of lbdbq.
.IP "-h | --help"
Print short help of lbdbq.
.SH FILES
.I @sysconfdir@/lbdb.rc
.br
.I $XDG_CONFIG_HOME/lbdb/config
.br
.I $HOME/.lbdbrc
.br
.I $HOME/.lbdb/lbdbrc
.br
.I $HOME/.lbdb/rc
.br
.I @libdir@/*
.br
.I $XDG_DATA_HOME/lbdb/m_inmail.db
.br
.I $HOME/.lbdb/m_inmail.utf-8
.br
.I $HOME/.lbdb/nodelist
.SH "SEE ALSO"
.BR finger (1),
.BR ypcat (1),
.BR niscat (1),
.BR getent (1),
.BR pgp (1),
.BR pgpk (1),
.BR gpg (1),
.BR lbdb-fetchaddr (1),
.BR nodelist2lbdb (1),
.BR mutt_ldap_query (1),
.BR abook (1),
.BR goobook (1),
.BR addr-email (1),
.BR addressbook (1),
.BR mutt (1),
.BR pine (1),
.BR emacs (1),
.BR xemacs (1),
.BR Palm::PDB (3pm),
.BR Palm::Address (3pm),
.BR Net::LDAP (3pm).
.SH CREDITS
Most of the really interesting code of this program (namely, the RFC
822 address parser used by lbdb-fetchaddr) was stolen from Michael
Elkins' mutt mail user agent. Additional credits go to Brandon Long
for putting the query functionality into mutt.
.PP
Many thanks to the authors of the several modules and extensions:
Ross Campbell <[email protected]> (m_abook, m_yppasswd),
Marc de Courville <[email protected]> (m_ldap, mutt_ldap_query),
Brendan Cully <[email protected]> (m_osx_addressbook, m_vcf),
Gabor Fleischer <[email protected]> (m_pine),
Rick Frankel <[email protected]> (m_gnomecard),
Utz-Uwe Haus <[email protected]> (m_bbdb, m_nispasswd),
Torsten Jerzembeck <[email protected]> (m_addr_email),
Adrian Likins <[email protected]> (m_getent),
Gergely Nagy <[email protected]> (m_wanderlust),
Dave Pearson <[email protected]> (m_palm, lbdb.el),
Brian Salter-Duke <[email protected]> (m_muttalias),
François Charlier <[email protected]> (m_goobook), and
Colin Watson <[email protected]> (m_khard)
.SH AUTHOR
The lbdb package was initially written by Thomas Roessler
<[email protected]> and is now maintained and heavily extended by
Roland Rosenfeld <[email protected]>.