本文整理汇总了C#中Session.startChannel方法的典型用法代码示例。如果您正苦于以下问题:C# Session.startChannel方法的具体用法?C# Session.startChannel怎么用?C# Session.startChannel使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Session
的用法示例。
在下文中一共展示了Session.startChannel方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: AuthenticateSASLOTPWithInit
/*
* Method AuthenticateSASLOTPWithInit is like the others, except
* that is actually forces the server (if authentication succeeds)
* to update the OTP db for this user.
*
* If you want to do that (I recommend it, then use the NEXT one).
*
* @param Session session is the session the user is authenticating on,
* in other words, represents the peer we want to authenticate to.
* @param String authorizeId is the identity this peer wants to be
* authorized to act as.
* @param String authenticateId is the identity this peer will
* authenticate as
* @param String pwd is the passphrase to authenticate with (it isn't
* stored or kept around very long at all, it's only used in computation).
*
* @param String newSequence String representation of the new Sequence
* integer
* @param String newAlgorithm name of the algorithm in the new OTP DB
* @param String newSeed value of the seed in the new OTP DB
* @param String newHas value of the lastHash in the new OTP DB
*
*
* @throws SASLException if any issue is encountered (usually
* rejection by the other peer).
*/
public static Session AuthenticateSASLOTPWithInit(Session session, System.String authorizeId, System.String authenticateId, System.String pwd, System.String newAlgorithm, System.String newHash, System.String newSeed, System.String newSequence)
{
bool success = false;
// Test the values
convertHexToBytes(newHash);
newSeed = newSeed.ToLower();
if (!OTPGenerator.validateSeed(newSeed) || !OTPGenerator.validatePassphrase(pwd) || !OTPGenerator.validateSequence(newSequence))
throw new SASLException("Unsuitable values for the parameters to init-hex");
// @todo bad toad - clean this up with tuning move
clearCredential(session, null);
OTPAuthenticator auth = SASLOTPProfile.instance().startAuthentication(authorizeId, authenticateId, pwd, newAlgorithm, newHash, newSeed, newSequence);
Channel ch = null;
System.String startData = null;
try
{
ch = session.startChannel(SASLOTPProfile.URI, auth);
startData = ch.StartData;
}
catch (BEEPException x)
{
//UPGRADE_TODO: The equivalent in .NET for method 'java.lang.Throwable.getMessage' may return a different value. 'ms-help://MS.VSCC.2003/commoner/redir/redirect.htm?keyword="jlca1043"'
auth.abort(x.Message);
}
// @todo EITHER use the Session Event Mechanism once it's detached from
// the session I/O thread via the Channel Message (EVENT) Queues...
// OR
// Embed some tuning profile logic in ChannelZero (hacky) to address stuff.
// For now, this is ok, the only thread blocked is the users, and it waits
// until the Authentication succeeds or fails.
Blob blob = null;
if ((System.Object) startData != null)
{
blob = new Blob(startData);
if (blob.Status.Equals(SASL_STATUS_ABORT))
throw new SASLException(ERR_REJECTED);
}
auth.started(ch);
auth.sendIdentity(authorizeId, authenticateId);
// We'll get notified when either
// (a) An Error Occurs
// (b) The authentication succeeds
// Everything else from here on out is basically on autopilot
try
{
lock (auth)
{
System.Threading.Monitor.Wait(auth);
SessionCredential cred = session.getLocalCredential();
if (cred == null)
{
auth.abort("Authentication Failed");
}
else
{
success = true;
}
}
}
catch (System.Exception x)
{
//UPGRADE_TODO: The equivalent in .NET for method 'java.lang.Throwable.getMessage' may return a different value. 'ms-help://MS.VSCC.2003/commoner/redir/redirect.htm?keyword="jlca1043"'
auth.abort(x.Message);
}
//.........这里部分代码省略.........
示例2: AuthenticateSASLAnonymousPiggyback
/// <summary> Method authencitateSASLAnonymousPiggyback is an Initiator
/// routine designed to allow a peer to authenticate to another
/// one. It is distinct in that it piggybacks the data for the
/// authentication request on the startChannel request.
///
/// </summary>
/// <param name="session">Session the current session
/// </param>
/// <param name="id">The identity of the peer withing to authenticate
///
/// @throws SASLException if any failure occurs.
/// </param>
public static Session AuthenticateSASLAnonymousPiggyback(Session session, System.String id)
{
if ((System.Object) id == null)
{
id = ANONYMOUS;
}
clearCredential(session, null);
//UPGRADE_TODO: The equivalent in .NET for method 'java.lang.Object.toString' may return a different value. 'ms-help://MS.VSCC.2003/commoner/redir/redirect.htm?keyword="jlca1043"'
Channel ch = session.startChannel(SASLAnonymousProfile.uri, false, new Blob(Blob.STATUS_NONE, id).ToString());
if (((System.Object) ch.StartData != null) && (ch.StartData.IndexOf("<error ") != - 1))
{
throw new BEEPException(ch.StartData);
}
System.String goo = ch.StartData;
if ((System.Object) goo != null)
{
Blob blob = new Blob(goo);
if (blob.Status.Equals(Blob.COMPLETE))
{
Instance.finishInitiatorAuthentication(generateCredential(id), ch.Session);
return session;
}
}
// @todo allow non-piggybacked
throw new BEEPException("Auth failed.");
}
示例3: AuthenticateSASLOTP
/// <summary> Method AuthenticateSASLOTP starts SASL OTP Authentication
/// between two peers. This is the NON-Piggybacking version
/// (it doesn't send the initial identity information on the
/// startChannelRequest).
///
/// If you want to do that (I recommend it, then use the NEXT one).
///
/// </summary>
/// <param name="session">Session is the session the user is authenticating on,
/// in other words, represents the peer we want to
/// authenticate to.
/// </param>
/// <param name="authorizeId">The identity this peer wants to be
/// authorized to act as.
/// </param>
/// <param name="authenticateId">The identity this peer will
/// authenticate as
/// </param>
/// <param name="pwd">The passphrase to authenticate with (it isn't stored or
/// kept around very long at all, it's only used in computation).
/// @throws SASLException if any issue is encountered (usually
/// rejection by the other peer).
/// </param>
public static Session AuthenticateSASLOTP(Session session, System.String authorizeId, System.String authenticateId, System.String pwd)
{
bool success = false;
if ((System.Object) authenticateId == null || session == null || (System.Object) pwd == null)
{
throw new InvalidParameterException(ERR_INVALID_ID + authenticateId);
}
// @todo bad toad - clean this up with tuning move
clearCredential(session, null);
OTPAuthenticator auth = SASLOTPProfile.instance().startAuthentication(authorizeId, authenticateId, pwd);
Channel ch = null;
System.String startData = null;
try
{
ch = session.startChannel(SASLOTPProfile.URI, auth);
startData = ch.StartData;
}
catch (BEEPException x)
{
//UPGRADE_TODO: The equivalent in .NET for method 'java.lang.Throwable.getMessage' may return a different value. 'ms-help://MS.VSCC.2003/commoner/redir/redirect.htm?keyword="jlca1043"'
auth.abort(x.Message);
}
// @todo EITHER use the Session Event Mechanism once it's
// detached from the session I/O thread via the Channel
// Message (EVENT) Queues...
// OR
// Embed some tuning profile logic in ChannelZero (hacky) to
// address stuff. For now, this is ok, the only thread
// blocked is the users, and it waits until the Authentication
// succeeds or fails.
Blob blob = null;
if ((System.Object) startData != null)
{
blob = new Blob(startData);
if (blob.Status.Equals(SASL_STATUS_ABORT))
throw new SASLException(ERR_REJECTED);
}
auth.started(ch);
auth.sendIdentity(authorizeId, authenticateId);
// We'll get notified when either
// (a) An Error Occurs
// (b) The authentication succeeds
// Everything else from here on out is basically on autopilot
try
{
lock (auth)
{
System.Threading.Monitor.Wait(auth);
}
}
catch (System.Exception x)
{
//UPGRADE_TODO: The equivalent in .NET for method 'java.lang.Throwable.getMessage' may return a different value. 'ms-help://MS.VSCC.2003/commoner/redir/redirect.htm?keyword="jlca1043"'
auth.abort(x.Message);
}
SessionCredential cred = session.getLocalCredential();
if (cred == null)
{
auth.abort("Authentication Failed");
}
else
{
success = true;
}
return session;
}
示例4: AuthenticateSASLAnonymous
/// <summary> Method authencitateSASLAnonymous is an Initiator routine designed
/// to allow a peer to authenticate to another one.
///
/// </summary>
/// <param name="session">Session the current session
/// </param>
/// <param name="id">The identity of the peer withing to authenticate
///
/// @throws SASLException if any failure occurs.
/// </param>
public static Session AuthenticateSASLAnonymous(Session session, System.String id)
{
if ((System.Object) id == null)
{
id = ANONYMOUS;
}
clearCredential(session, null);
AnonymousAuthenticator auth = new AnonymousAuthenticator(Instance);
Channel ch = session.startChannel(SASLAnonymousProfile.uri, auth);
auth.started(ch);
auth.sendIdentity(id);
lock (auth)
{
try
{
System.Threading.Monitor.Wait(auth);
//FIX for bug 469725, if authentication fails no local Cred is
//set and a AuthenticationFailureException is thrown
if (ch.Session.getLocalCredential() == null)
{
throw new AuthenticationFailureException("Could not authenticate with SASL/ANON");
}
return ch.Session;
}
catch (System.Threading.ThreadInterruptedException x)
{
}
}
return null;
}