2 * $Id: ablookup.h 1266 2009-07-14 18:39:12Z hubert@u.washington.edu $
4 * ========================================================================
5 * Copyright 2013-2022 Eduardo Chappa
6 * Copyright 2006-2008 University of Washington
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * ========================================================================
17 #ifndef PITH_ABLOOKUP_INCLUDED
18 #define PITH_ABLOOKUP_INCLUDED
21 #include "../pith/state.h"
22 #include "../pith/pattern.h"
23 #include "../pith/adrbklib.h"
24 #include "../pith/bldaddr.h"
28 * Flags to adrbk_list_of_completions().
29 * ALC_INCLUDE_ADDRS means that the "addr" element
30 * should be included in the COMPLETE_S list. When
31 * this is not set the entries that match because
32 * of an addr match are still included in the list
33 * but the actual "addr" element itself is not filled
34 * in. That isn't needed by Web Alpine and it does
35 * have a cost, though rather small, to fill it in.
37 #define ALC_INCLUDE_ADDRS 0x1
38 #define ALC_INCLUDE_LDAP 0x2
41 * Values OR'd together in matches_bitmaps.
42 * These are not in the same namespace as the flags
43 * above, these are just bits for the matches_bitmaps member.
45 * If ALC_NICK is set that means there was a prefix match on the nickname.
46 * ALC_FULL is a match on the full address.
47 * ALC_ADDR is a match on the mailbox@host part of the address.
48 * ALC_REVFULL is a match on the Last, First Fullname if the user uses that.
49 * ALC_ABOOK means the entry came from an address book entry
50 * ALC_LDAP means the entry came from an LDAP lookup
51 * ALC_CURR means the entry came from the currently viewed message
52 * This is used in both ABOOK_ENTRY_S and COMPLETE_S structures.
56 #define ALC_REVFULL 0x04
58 #define ALC_ABOOK 0x10
64 typedef struct abook_entry_list
{
66 adrbk_cntr_t entrynum
;
67 unsigned matches_bitmap
;
68 struct abook_entry_list
*next
;
72 typedef struct completelist
{
73 char *nickname
; /* the nickname */
74 char *full_address
; /* Some Body <someb@there.org> */
75 char *addr
; /* someb@there.org (costs extra) */
76 char *rev_fullname
; /* optional Last, First version of fullname */
77 char *fcc
; /* optional fcc associated with address */
78 unsigned matches_bitmap
;
79 struct completelist
*next
;
83 /* exported prototypes */
84 char *get_nickname_from_addr(ADDRESS
*, char *, size_t);
85 char *get_fcc_from_addr(ADDRESS
*, char *, size_t);
86 int get_contactinfo_from_addr(ADDRESS
*, char **, char **, char **, char **);
87 void address_in_abook(MAILSTREAM
*, SEARCHSET
*, int, PATTERN_S
*);
88 ADDRESS
*abe_to_address(AdrBk_Entry
*, AddrScrn_Disp
*, AdrBk
*, int *);
89 char *abe_to_nick_or_addr_string(AdrBk_Entry
*, AddrScrn_Disp
*, int);
90 int address_is_us(ADDRESS
*, struct pine
*);
91 int address_is_same(ADDRESS
*, ADDRESS
*);
92 int abes_are_equal(AdrBk_Entry
*, AdrBk_Entry
*);
93 char *addr_lookup(char *, int *, int);
94 AdrBk_Entry
*adrbk_lookup_with_opens_by_nick(char *, int, int *, int);
95 AdrBk_Entry
*address_to_abe(ADDRESS
*);
96 int contains_regex_special_chars(char *str
);
97 COMPLETE_S
*adrbk_list_of_completions(char *, MAILSTREAM
*, imapuid_t
, int);
98 COMPLETE_S
*new_complete_s(char *, char *, char *, char *, char *, unsigned);
99 void free_complete_s(COMPLETE_S
**);
100 ABOOK_ENTRY_S
*new_abook_entry_s(AdrBk
*, a_c_arg_t
, unsigned);
101 void free_abook_entry_s(ABOOK_ENTRY_S
**);
102 void combine_abook_entry_lists(ABOOK_ENTRY_S
**, ABOOK_ENTRY_S
*);
103 ABOOK_ENTRY_S
*adrbk_list_of_possible_completions(AdrBk
*, char *);
106 #endif /* PITH_ABLOOKUP_INCLUDED */