/[smecontribs]/rpms/ejabberd/contribs7/ejabberd_auth_ad.erl
ViewVC logotype

Annotation of /rpms/ejabberd/contribs7/ejabberd_auth_ad.erl

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.3 - (hide annotations) (download)
Tue Nov 25 16:20:11 2008 UTC (15 years, 11 months ago) by slords
Branch: MAIN
CVS Tags: ejabberd-2_0_5-2_el4_sme, HEAD
Changes since 1.2: +0 -0 lines
Restore

1 slords 1.1 %%%----------------------------------------------------------------------
2     %%% File : ejabberd_auth_ad.erl
3     %%% Author : Alexey Shchepin <alexey@sevcom.net>
4     %%% Author : Alex Gorbachenko <agent_007@immo.ru>
5     %%% Author : Stanislav Bogatyrev <realloc@realloc.spb.ru>
6     %%% Purpose : Authentification via Active Directory
7     %%% Created : 12 Dec 2004 by Alexey Shchepin <alexey@sevcom.net>
8     %%% Id : $Id: ejabberd_auth_ad.erl 386 2005-12-20 10:06:37Z agent_007 $
9     %%%----------------------------------------------------------------------
10    
11     -module(ejabberd_auth_ad).
12     -author('alexey@sevcom.net').
13     -author('agent_007@immo.ru').
14     -author('realloc@realloc.spb.ru').
15     -vsn('$Revision: 386 $ ').
16    
17     %% External exports
18     -export([start/1,
19     set_password/3,
20     check_password/3,
21     check_password/5,
22     try_register/3,
23     dirty_get_registered_users/0,
24     get_vh_registered_users/1,
25     get_password/2,
26     get_password_s/2,
27     is_user_exists/2,
28     remove_user/2,
29     remove_user/3,
30     plain_password_required/0
31     ]).
32    
33     -include("ejabberd.hrl").
34     -include("eldap/eldap.hrl").
35    
36     %%%----------------------------------------------------------------------
37     %%% API
38     %%%----------------------------------------------------------------------
39     start(Host) ->
40     LDAPServers = ejabberd_config:get_local_option({ad_servers, Host}),
41     RootDN = ejabberd_config:get_local_option({ad_rootdn, Host}),
42     Password = ejabberd_config:get_local_option({ad_password, Host}),
43     eldap:start_link(get_eldap_id(Host, ejabberd),
44     LDAPServers, 389, RootDN, Password),
45     eldap:start_link(get_eldap_id(Host, ejabberd_bind),
46     LDAPServers, 389, RootDN, Password),
47     ok.
48    
49     plain_password_required() ->
50     true.
51    
52     check_password(User, Server, Password) ->
53     case find_user_dn(User, Server) of
54     false ->
55     false;
56     DN ->
57     LServer = jlib:nameprep(Server),
58     case eldap:bind(get_eldap_id(LServer, ejabberd_bind),
59     DN, Password) of
60     ok ->
61     true;
62     _ ->
63     false
64     end
65     end.
66    
67     check_password(User, Server, Password, _StreamID, _Digest) ->
68     check_password(User, Server, Password).
69    
70     set_password(_User, _Server, _Password) ->
71     {error, not_allowed}.
72    
73     try_register(_User, _Server, _Password) ->
74     {error, not_allowed}.
75    
76     dirty_get_registered_users() ->
77     get_vh_registered_users(?MYNAME).
78    
79     get_vh_registered_users(Server) ->
80     LServer = jlib:nameprep(Server),
81     Attr = ejabberd_config:get_local_option({ad_uidattr, LServer}),
82     % AdGroup = ejabberd_config:get_local_option({ad_group, LServer}),
83     FilterPerson = eldap:equalityMatch("objectCategory", "person"),
84     FilterComp = eldap:equalityMatch("objectClass", "computer"),
85     FilterHidden = eldap:equalityMatch("description", "hidden"),
86     % FilterGroup = eldap:equalityMatch("memberOf", AdGroup),
87     FilterLive = eldap:equalityMatch("userAccountControl", "66050"),
88     FilterDef = eldap:present(Attr),
89     Filter = eldap:'and'([
90     FilterDef,
91     FilterPerson,
92     % FilterGroup,
93     eldap:'not'(FilterComp),
94     eldap:'not'(FilterHidden),
95     eldap:'not'(FilterLive)]),
96     Base = ejabberd_config:get_local_option({ad_base, LServer}),
97     case eldap:search(get_eldap_id(LServer, ejabberd),
98     [{base, Base},
99     {filter, Filter},
100     {attributes, [Attr]}]) of
101     #eldap_search_result{entries = Es} ->
102     lists:flatmap(
103     fun(E) ->
104     case lists:keysearch(Attr, 1, E#eldap_entry.attributes) of
105     {value, {_, [U]}} ->
106     case jlib:nodeprep(U) of
107     error ->
108     [];
109     LU ->
110     [{LU, LServer}]
111     end;
112     _ ->
113     []
114     end
115     end, Es);
116     _ ->
117     []
118     end.
119    
120     get_password(_User, _Server) ->
121     false.
122    
123     get_password_s(_User, _Server) ->
124     "".
125    
126     is_user_exists(User, Server) ->
127     case find_user_dn(User, Server) of
128     false ->
129     false;
130     _DN ->
131     true
132     end.
133    
134     remove_user(_User, _Server) ->
135     {error, not_allowed}.
136    
137     remove_user(_User, _Server, _Password) ->
138     not_allowed.
139    
140    
141     %%%----------------------------------------------------------------------
142     %%% Internal functions
143     %%%----------------------------------------------------------------------
144    
145     find_user_dn(User, Server) ->
146     LServer = jlib:nameprep(Server),
147     AdGroup = ejabberd_config:get_local_option({ad_group, LServer}),
148     Attr = ejabberd_config:get_local_option({ad_uidattr, LServer}),
149     FilterAttr = eldap:equalityMatch(Attr, User),
150     FilterGroup = eldap:equalityMatch("memberOf", AdGroup),
151     Filter = eldap:'and'([
152     FilterAttr,
153     FilterGroup
154     ]),
155     Base = ejabberd_config:get_local_option({ad_base, LServer}),
156     case eldap:search(get_eldap_id(LServer, ejabberd),
157     [{base, Base},
158     {filter, Filter},
159     {attributes, []}]) of
160     #eldap_search_result{entries = [E | _]} ->
161     E#eldap_entry.object_name;
162     _ ->
163     false
164     end.
165    
166     get_eldap_id(Host, Name) ->
167     atom_to_list(gen_mod:get_module_proc(Host, Name)).

admin@koozali.org
ViewVC Help
Powered by ViewVC 1.2.1 RSS 2.0 feed