~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/smtp_connection.py

  • Committer: Vincent Ladeuil
  • Date: 2010-02-10 15:46:03 UTC
  • mfrom: (4985.3.21 update)
  • mto: This revision was merged to the branch mainline in revision 5021.
  • Revision ID: v.ladeuil+lp@free.fr-20100210154603-k4no1gvfuqpzrw7p
Update performs two merges in a more logical order but stop on conflicts

Show diffs side-by-side

added added

removed removed

Lines of Context:
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
"""A convenience class around smtplib."""
18
18
 
23
23
 
24
24
from bzrlib import (
25
25
    config,
26
 
    ui,
 
26
    osutils,
27
27
    )
28
28
from bzrlib.errors import (
29
29
    NoDestinationAddress,
64
64
            return
65
65
 
66
66
        self._create_connection()
 
67
        # FIXME: _authenticate() should only be called when the server has
 
68
        # refused unauthenticated access, so it can safely try to authenticate 
 
69
        # with the default username. JRV20090407
67
70
        self._authenticate()
68
71
 
69
72
    def _create_connection(self):
103
106
        """If necessary authenticate yourself to the server."""
104
107
        auth = config.AuthenticationConfig()
105
108
        if self._smtp_username is None:
 
109
            # FIXME: Since _authenticate gets called even when no authentication
 
110
            # is necessary, it's not possible to use the default username 
 
111
            # here yet.
106
112
            self._smtp_username = auth.get_user('smtp', self._smtp_server)
107
113
            if self._smtp_username is None:
108
114
                return
111
117
            self._smtp_password = auth.get_password(
112
118
                'smtp', self._smtp_server, self._smtp_username)
113
119
 
114
 
        self._connection.login(self._smtp_username, self._smtp_password)
 
120
        # smtplib requires that the username and password be byte
 
121
        # strings.  The CRAM-MD5 spec doesn't give any guidance on
 
122
        # encodings, but the SASL PLAIN spec says UTF-8, so that's
 
123
        # what we'll use.
 
124
        username = osutils.safe_utf8(self._smtp_username)
 
125
        password = osutils.safe_utf8(self._smtp_password)
 
126
 
 
127
        self._connection.login(username, password)
115
128
 
116
129
    @staticmethod
117
130
    def get_message_addresses(message):