forked from kaleyroy/S22.Sasl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSaslMechanism.cs
93 lines (84 loc) · 2.94 KB
/
SaslMechanism.cs
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
using System.Collections.Generic;
using System;
namespace S22.Sasl {
/// <summary>
/// The abstract base class from which all classes implementing a Sasl
/// authentication mechanism must derive.
/// </summary>
public abstract class SaslMechanism {
/// <summary>
/// IANA name of the authentication mechanism.
/// </summary>
public abstract string Name {
get;
}
/// <summary>
/// True if the authentication exchange between client and server
/// has been completed.
/// </summary>
public abstract bool IsCompleted {
get;
}
/// <summary>
/// True if the mechanism requires initiation by the client.
/// </summary>
public abstract bool HasInitial {
get;
}
/// <summary>
/// A map of mechanism-specific properties which are needed by the
/// authentication mechanism to compute it's challenge-responses.
/// </summary>
public Dictionary<string, object> Properties {
get;
private set;
}
/// <summary>
/// Computes the client response to a challenge sent by the server.
/// </summary>
/// <param name="challenge"></param>
/// <returns>The client response to the specified challenge.</returns>
protected abstract byte[] ComputeResponse(byte[] challenge);
/// <summary>
/// </summary>
public SaslMechanism() {
Properties = new Dictionary<string, object>();
}
/// <summary>
/// Retrieves the base64-encoded client response for the specified
/// base64-encoded challenge sent by the server.
/// </summary>
/// <param name="challenge">A base64-encoded string representing a challenge
/// sent by the server.</param>
/// <returns>A base64-encoded string representing the client response to the
/// server challenge.</returns>
/// <remarks>The IMAP, POP3 and SMTP authentication commands expect challenges
/// and responses to be base64-encoded. This method automatically decodes the
/// server challenge before passing it to the Sasl implementation and
/// encodes the client response to a base64-string before returning it to the
/// caller.</remarks>
/// <exception cref="SaslException">The client response could not be retrieved.
/// Refer to the inner exception for error details.</exception>
public string GetResponse(string challenge) {
try {
byte[] data = String.IsNullOrEmpty(challenge) ? new byte[0] :
Convert.FromBase64String(challenge);
byte[] response = ComputeResponse(data);
return Convert.ToBase64String(response);
} catch (Exception e) {
throw new SaslException("The challenge-response could not be " +
"retrieved.", e);
}
}
/// <summary>
/// Retrieves the client response for the specified server challenge.
/// </summary>
/// <param name="challenge">A byte array containing the challenge sent by
/// the server.</param>
/// <returns>An array of bytes representing the client response to the
/// server challenge.</returns>
public byte[] GetResponse(byte[] challenge) {
return ComputeResponse(challenge);
}
}
}