~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/smart/bzrdir.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2007-11-04 18:51:39 UTC
  • mfrom: (2961.1.1 trunk)
  • Revision ID: pqm@pqm.ubuntu.com-20071104185139-kaio3sneodg2kp71
Authentication ring implementation (read-only)

Show diffs side-by-side

added added

removed removed

Lines of Context:
30
30
 
31
31
    def do(self, path):
32
32
        from bzrlib.bzrdir import BzrDirFormat
 
33
        t = self._backing_transport.clone(path)
 
34
        default_format = BzrDirFormat.get_default_format()
 
35
        real_bzrdir = default_format.open(t, _found=True)
33
36
        try:
34
 
            t = self.transport_from_client_path(path)
35
 
        except errors.PathNotChild:
36
 
            # The client is trying to ask about a path that they have no access
37
 
            # to.
38
 
            # Ideally we'd return a FailedSmartServerResponse here rather than
39
 
            # a "successful" negative, but we want to be compatibile with
40
 
            # clients that don't anticipate errors from this method.
 
37
            real_bzrdir._format.probe_transport(t)
 
38
        except (errors.NotBranchError, errors.UnknownFormatError):
41
39
            answer = 'no'
42
40
        else:
43
 
            default_format = BzrDirFormat.get_default_format()
44
 
            real_bzrdir = default_format.open(t, _found=True)
45
 
            try:
46
 
                real_bzrdir._format.probe_transport(t)
47
 
            except (errors.NotBranchError, errors.UnknownFormatError):
48
 
                answer = 'no'
49
 
            else:
50
 
                answer = 'yes'
 
41
            answer = 'yes'
51
42
        return SuccessfulSmartServerResponse((answer,))
52
43
 
53
44
 
54
45
class SmartServerRequestFindRepository(SmartServerRequest):
55
46
 
56
 
    def _boolean_to_yes_no(self, a_boolean):
57
 
        if a_boolean:
58
 
            return 'yes'
59
 
        else:
60
 
            return 'no'
61
 
 
62
 
    def _find(self, path):
63
 
        """try to find a repository from path upwards
64
 
        
65
 
        This operates precisely like 'bzrdir.find_repository'.
66
 
        
67
 
        :return: (relpath, rich_root, tree_ref, external_lookup) flags. All are
68
 
            strings, relpath is a / prefixed path, and the other three are
69
 
            either 'yes' or 'no'.
70
 
        :raises errors.NoRepositoryPresent: When there is no repository
71
 
            present.
72
 
        """
73
 
        bzrdir = BzrDir.open_from_transport(
74
 
            self.transport_from_client_path(path))
75
 
        repository = bzrdir.find_repository()
76
 
        # the relpath of the bzrdir in the found repository gives us the 
77
 
        # path segments to pop-out.
78
 
        relpath = repository.bzrdir.root_transport.relpath(
79
 
            bzrdir.root_transport.base)
80
 
        if len(relpath):
81
 
            segments = ['..'] * len(relpath.split('/'))
82
 
        else:
83
 
            segments = []
84
 
        rich_root = self._boolean_to_yes_no(repository.supports_rich_root())
85
 
        tree_ref = self._boolean_to_yes_no(
86
 
            repository._format.supports_tree_reference)
87
 
        external_lookup = self._boolean_to_yes_no(
88
 
            repository._format.supports_external_lookups)
89
 
        return '/'.join(segments), rich_root, tree_ref, external_lookup
90
 
 
91
 
 
92
 
class SmartServerRequestFindRepositoryV1(SmartServerRequestFindRepository):
93
 
 
94
 
    def do(self, path):
95
 
        """try to find a repository from path upwards
96
 
        
97
 
        This operates precisely like 'bzrdir.find_repository'.
98
 
        
99
 
        If a bzrdir is not present, an exception is propogated
100
 
        rather than 'no branch' because these are different conditions.
101
 
 
102
 
        This is the initial version of this method introduced with the smart
103
 
        server. Modern clients will try the V2 method that adds support for the
104
 
        supports_external_lookups attribute.
105
 
 
106
 
        :return: norepository or ok, relpath.
107
 
        """
108
 
        try:
109
 
            path, rich_root, tree_ref, external_lookup = self._find(path)
110
 
            return SuccessfulSmartServerResponse(('ok', path, rich_root, tree_ref))
111
 
        except errors.NoRepositoryPresent:
112
 
            return FailedSmartServerResponse(('norepository', ))
113
 
 
114
 
 
115
 
class SmartServerRequestFindRepositoryV2(SmartServerRequestFindRepository):
116
 
 
117
 
    def do(self, path):
118
 
        """try to find a repository from path upwards
119
 
        
120
 
        This operates precisely like 'bzrdir.find_repository'.
121
 
        
122
 
        If a bzrdir is not present, an exception is propogated
123
 
        rather than 'no branch' because these are different conditions.
124
 
 
125
 
        This is the second edition of this method introduced in bzr 1.3, which
126
 
        returns information about the supports_external_lookups format
127
 
        attribute too.
128
 
 
129
 
        :return: norepository or ok, relpath.
130
 
        """
131
 
        try:
132
 
            path, rich_root, tree_ref, external_lookup = self._find(path)
133
 
            return SuccessfulSmartServerResponse(
134
 
                ('ok', path, rich_root, tree_ref, external_lookup))
 
47
    def do(self, path):
 
48
        """try to find a repository from path upwards
 
49
        
 
50
        This operates precisely like 'bzrdir.find_repository'.
 
51
        
 
52
        If a bzrdir is not present, an exception is propogated
 
53
        rather than 'no branch' because these are different conditions.
 
54
 
 
55
        :return: norepository or ok, relpath.
 
56
        """
 
57
        bzrdir = BzrDir.open_from_transport(self._backing_transport.clone(path))
 
58
        try:
 
59
            repository = bzrdir.find_repository()
 
60
            # the relpath of the bzrdir in the found repository gives us the 
 
61
            # path segments to pop-out.
 
62
            relpath = repository.bzrdir.root_transport.relpath(bzrdir.root_transport.base)
 
63
            if len(relpath):
 
64
                segments = ['..'] * len(relpath.split('/'))
 
65
            else:
 
66
                segments = []
 
67
            if repository.supports_rich_root():
 
68
                rich_root = 'yes'
 
69
            else:
 
70
                rich_root = 'no'
 
71
            if repository._format.supports_tree_reference:
 
72
                tree_ref = 'yes'
 
73
            else:
 
74
                tree_ref = 'no'
 
75
            return SuccessfulSmartServerResponse(('ok', '/'.join(segments), rich_root, tree_ref))
135
76
        except errors.NoRepositoryPresent:
136
77
            return FailedSmartServerResponse(('norepository', ))
137
78
 
144
85
        The default format of the server is used.
145
86
        :return: SmartServerResponse(('ok', ))
146
87
        """
147
 
        target_transport = self.transport_from_client_path(path)
 
88
        target_transport = self._backing_transport.clone(path)
148
89
        BzrDirFormat.get_default_format().initialize_on_transport(target_transport)
149
90
        return SuccessfulSmartServerResponse(('ok', ))
150
91
 
157
98
        If a bzrdir is not present, an exception is propogated
158
99
        rather than 'no branch' because these are different conditions.
159
100
        """
160
 
        bzrdir = BzrDir.open_from_transport(
161
 
            self.transport_from_client_path(path))
 
101
        bzrdir = BzrDir.open_from_transport(self._backing_transport.clone(path))
162
102
        try:
163
103
            reference_url = bzrdir.get_branch_reference()
164
104
            if reference_url is None: