# Copyright (C) 2014 Simo Sorce # # see file 'COPYING' for use and warranty information # # 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 3 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, see . from ipsilon.login.common import LoginFormBase, LoginManagerBase, \ LoginManagerInstaller from ipsilon.util.plugin import PluginObject from ipsilon.util import config as pconfig import cherrypy class TestAuth(LoginFormBase): def POST(self, *args, **kwargs): username = kwargs.get("login_name") password = kwargs.get("login_password") error = None if username and password: if password == 'ipsilon': cherrypy.log("User %s successfully authenticated." % username) testdata = {'fullname': 'Test User %s' % username} return self.lm.auth_successful(self.trans, username, 'password', testdata) else: cherrypy.log("User %s failed authentication." % username) error = "Authentication failed" else: error = "Username or password is missing" cherrypy.log.error("Error: " + error) context = self.create_tmpl_context( username=username, error=error, error_password=not password, error_username=not username ) # pylint: disable=star-args return self._template('login/form.html', **context) class LoginManager(LoginManagerBase): def __init__(self, *args, **kwargs): super(LoginManager, self).__init__(*args, **kwargs) self.name = 'testauth' self.service_name = 'testauth' self.path = 'testauth' self.page = None self.description = """ Form based TEST login Manager, DO NOT EVER ACTIVATE IN PRODUCTION """ self.new_config( self.name, pconfig.String( 'username text', 'Text used to ask for the username at login time.', 'Username'), pconfig.String( 'password text', 'Text used to ask for the password at login time.', 'Password'), pconfig.String( 'help text', 'Text used to guide the user at login time.', 'DISABLE IN PRODUCTION, USE ONLY FOR TEST ' + 'Use any username they are all valid, "admin" gives ' + 'administrative powers. ' + 'Use the fixed password "ipsilon" for any user') ) @property def help_text(self): return self.get_config_value('help text') @property def username_text(self): return self.get_config_value('username text') @property def password_text(self): return self.get_config_value('password text') def get_tree(self, site): self.page = TestAuth(site, self, 'login/testauth') return self.page class Installer(LoginManagerInstaller): def __init__(self, *pargs): super(Installer, self).__init__() self.name = 'testauth' self.pargs = pargs def install_args(self, group): group.add_argument('--testauth', choices=['yes', 'no'], default='no', help='Configure PAM authentication') def configure(self, opts): if opts['testauth'] != 'yes': return print self.pargs # Add configuration data to database po = PluginObject(*self.pargs) po.name = 'testauth' po.wipe_data() # Update global config to add login plugin po.is_enabled = True po.save_enabled_state() r'>committer
blob: aab9ce2dcf71a74f0f6450488b6f79c6108a763c (plain)
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
# fedpkg bash completion

have fedpkg &&
_fedpkg()
{
    COMPREPLY=()

    in_array()
    {
        local i
        for i in $2; do
            [[ $i = $1 ]] && return 0
        done
        return 1
    }

    _filedir_exclude_paths()
    {
        _filedir "$@"
        for ((i=0; i<=${#COMPREPLY[@]}; i++)); do
            [[ ${COMPREPLY[$i]} =~ /?\.git/? ]] && unset COMPREPLY[$i]
        done
    }

    local cur prev
    # _get_comp_words_by_ref is in bash-completion >= 1.2, which EL-5 lacks.
    if type _get_comp_words_by_ref &>/dev/null; then
        _get_comp_words_by_ref cur prev
    else
        cur="${COMP_WORDS[COMP_CWORD]}"
        prev="${COMP_WORDS[COMP_CWORD-1]}"
    fi
    
    # global options

    local options="-h --help -v -q"
    local options_value="-u --user --path"
    local commands="build chain-build ci clean clog clone co commit compile diff gimmespec giturl help \
    import install lint local mockbuild new new-sources patch prep push scratch-build sources srpm \
    switch-branch tag-request unused-patches update upload verrel"

    # parse main options and get command

    local command=
    local command_first=
    local path=