前のブログ記事のコメントに、MailKitの「SaslMechanism(OAuth2)は使い回しができないようだ。」と書いたけど、Resetメソッドを使うと、問題無く動きました。このメソッドが何をやっているかというと、IsAuthenticateプロパティをfalseに設定しているだけなんだけどね。(ベースクラスで実装されてた)
var cred = new UsernamePasswordCredential(PopUser,PopPass,Authority,AppID,options);
// Scopesは["https://outlook.office365.com/POP.AccessAsUser.All","https://outlook.office365.com/SMTP.Send"]
var req = new TokenRequestContext(scopes);
var token = await cred.GetTokenAsync(req);
var oauth2 = new SaslMechanismOAuth2(PopUser, token.Token);
using (Pop3Client cli = new Pop3Client()){
await cli.ConnectAsync("outlook.office365.com", 995, SecureSocketOptions.SslOnConnect);
// AccessTokenで認証
await cli.AuthenticateAsync(oauth2);
int cnt = await cli.GetMessageCountAsync();
・・・
}
using (SmtpClient scli = new SmtpClient()) {
MimeMessage msg = new MimeMessage();
・・・
// SASLの認証済みフラグを落とす
oauth2.Reset();
await scli.ConnectAsync("outlook.office365.com", 587, SecureSocketOptions.StartTls);
await scli.AuthenticateAsync(oauth2);
await scli.SendAsync(msg);
await scli.DisconnectAsync(true);
}
もちろん、長時間使用していない場合は、AccessTokenがExpireしてしまうので、その場合はAcessTokenの取得から行なわなければならないけど・・・