~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to ivle/svn.py

  • Committer: matt.giuca
  • Date: 2009-01-14 10:10:12 UTC
  • mto: This revision was merged to the branch mainline in revision 1090.
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:branches%2Fstorm:1132
The new ivle.database.User class is now used in Request and usrmgt, which
    means it is now almost universally used in favour of ivle.user.User (now
    deprecated).

Noticeable change: The minor bug where the change to a user object in the
    database is not reflected in the user's session (eg. changing nick doesn't
    update title until log out).

ivle.dispatch:
    Session now contains 'login' (username string) rather than 'user' (full
        ivle.user.User object). This is a unicode string now.

    req.user is now a ivle.database.User object rather than an ivle.user.User
        object. This makes for a whole lot of really subtle differences, but
        largely conforms to the same interface. Note that strings must now all
        be unicode.

    login: Removed use of ivle.db. Now uses User object.

    html: Now handles unicode login and config options.

ivle.db: Removed update_user. Now replaced with Storm model.

ivle.database: Renamed has_cap back to hasCap (saved for later). Fixed small
    unicode bug.

ivle.makeuser.make_svn_auth now takes a store object.

usrmgt-server: Use new User class.

userservice: Now uses User class internally.
    get_user action now returns ISO 8601 date format, rather than a
        time tuple. (Wasn't being used).
    get_user action no longer transmits local_password (small security risk;
        note that it wasn't possible to see this for any user other than
        yourself unless admin).

ivle.util - added function object_to_dict.

Show diffs side-by-side

added added

removed removed

Lines of Context:
23
23
 
24
24
import pysvn
25
25
 
26
 
def create_auth_svn_client_autopass(username, save_credentials=False):
27
 
    """Create a new pysvn client which is set up to automatically authenticate
28
 
    with the supplied user. The user's Subversion password is automatically
29
 
    looked up in the database.
30
 
    (Requires database access -- can't be used inside the jail.)
31
 
    @param username: IVLE/Subversion username.
32
 
    @param save_credentials: Save the user's credentials. Should be False when
33
 
        outside the jail.
34
 
    """
35
 
    # Note: Must do this inside the function, since this file may be used in
36
 
    # the jail, and importing ivle.database crashes in the jail.
37
 
    from ivle.config import Config
38
 
    import ivle.database
39
 
    from ivle.database import User
40
 
    store = ivle.database.get_store(Config())
41
 
    user = store.find(User, User.login==unicode(username)).one()
42
 
    return create_auth_svn_client(username, user.svn_pass, save_credentials)
43
 
 
44
 
def create_auth_svn_client(username, password, save_credentials=True):
45
 
    """Create a new pysvn client which is set up to automatically authenticate
46
 
    with the supplied credentials.
47
 
    @param username: IVLE/Subversion username.
48
 
    @param password: Subversion password.
49
 
    @param save_credentials: Save the user's credentials. Should be False when
50
 
        outside the jail.
51
 
    """
52
 
    username = str(username)
53
 
    password = str(password)
54
 
    def get_login(_realm, existing_login, _may_save):
55
 
        """Callback function used by pysvn for authentication.
56
 
        realm, existing_login, _may_save: The 3 arguments passed by pysvn to
57
 
            callback_get_login.
58
 
            The following has been determined empirically, not from docs:
59
 
            existing_login will be the name of the user who owns the process on
60
 
            the first attempt, "" on subsequent attempts. We use this fact.
61
 
        """
62
 
        # Only provide credentials on the _first_ attempt.
63
 
        # If we're being asked again, then it means the credentials failed for
64
 
        # some reason and we should just fail. (This is not desirable, but it's
65
 
        # better than being asked an infinite number of times).
66
 
        return (existing_login != "", username, password, save_credentials)
67
 
 
68
 
    svnclient = pysvn.Client()
69
 
    svnclient.callback_get_login = get_login
70
 
    return svnclient
71
 
 
72
26
def revision_from_string(r_str):
73
27
    if r_str is None:
74
28
        pass
94
48
    except pysvn.ClientError:
95
49
        return False
96
50
 
97
 
def revision_is_dir(client, path, revision):
98
 
    """Returns True if the given path+revision is a directory.
99
 
    @raises a pysvn.ClientError if it does not exist.
100
 
    """
101
 
    # XXX I *think* the first element of the list is the requested object, and
102
 
    # subsequent items are its possible children (so ignore them).
103
 
    list_object, _ = client.list(path, revision=revision)[0]
104
 
    # list_object is a PySvnList object
105
 
    return list_object.kind == pysvn.node_kind.dir
106
 
 
107
51
class PysvnListStatWrapper:
108
52
    '''Wrap a pysvn listing object to look somewhat like a result of
109
53
       os.stat.