本文整理汇总了C#中Nancy.NancyContext.Ensure方法的典型用法代码示例。如果您正苦于以下问题:C# NancyContext.Ensure方法的具体用法?C# NancyContext.Ensure怎么用?C# NancyContext.Ensure使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Nancy.NancyContext
的用法示例。
在下文中一共展示了NancyContext.Ensure方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetRoom
static object GetRoom(
NancyContext context,
IDocumentSession documentSession,
string slug)
{
context.Ensure("context");
documentSession.Ensure("documentSession");
if (string.IsNullOrEmpty(slug))
return 404;
if (!context.IsSignedUp())
return 403;
var room = documentSession.GetRoomBySlug(slug);
if (room == null)
return 404;
var currentMember = context.GetCurrentMember(documentSession);
Debug.Assert(currentMember != null, "`requireSignedUp()` should ensure a current member.");
var posts = documentSession.GetPostsByRoom(room.Id).ToArray();
return new RoomResponse(currentMember, room, posts);
}
示例2: GetSignInPage
public static object GetSignInPage(NancyContext context)
{
context.Ensure("context");
var returnUrl = context.Request.Query["return-url"] ?? String.Empty;
return new SignInPageResponse(HttpUtility.UrlEncode(returnUrl));
}
示例3: DeleteSession
static object DeleteSession(NancyContext context)
{
context.Ensure("context");
context.SetAlert("You successfully signed out.", type: AlertType.Success);
context.SignOutOfTwitter();
return context.Redirect(Paths.Home());
}
示例4: GetSignUpForm
static object GetSignUpForm(
NancyContext context,
IDocumentSession documentSession)
{
context.Ensure("context");
documentSession.Ensure("documentSession");
if (!context.IsSignedIn())
return 403;
var currentMember = context.GetCurrentMember(documentSession);
if (currentMember != null)
return 403;
return new SignUpFormResponse();
}
示例5: PostMember
public static object PostMember(
NancyContext context,
IDocumentSession documentSession,
string alias,
string emailAddress)
{
context.Ensure("context");
documentSession.Ensure("documentSession");
if (!context.IsSignedIn())
return 403;
var errors = new List<string>();
errors.AddRange(fn.ValidateRequired("Alias", alias));
errors.AddRange(fn.ValidateLength("Alias", alias, 32));
errors.AddRange(fn.ValidateFormat("Alias", alias, new Regex("[a-z][a-z0-9_-]+")));
errors.AddRange(fn.ValidateRequired("Email Address", emailAddress));
errors.AddRange(fn.ValidateLength("Email Address", emailAddress, 1024));
var member = documentSession.GetMemberByAlias(alias);
if (member != null)
errors.Add(Strings.AliasNotAvailable(alias));
if (errors.Count > 0)
return context.ModelWithStatus(new SignUpFormResponse(alias, emailAddress, errors), 400);
var authType = context.ReadSession<string>(Constants.AuthTypeSessionKey);
var authId = context.ReadSession<string>(Constants.AuthIdSessionKey);
if (String.IsNullOrEmpty(authType))
throw new InvalidOperationException(Strings.AuthTypeMissing());
if (String.IsNullOrEmpty(authId))
throw new InvalidOperationException(Strings.AuthIdMissing());
member = documentSession.CreateMember(authType, authId, alias, emailAddress);
var returnUrl = context.GetReturnUrl();
return context.Redirect(returnUrl ?? Paths.Member(member.Alias));
}
示例6: GetAcceptInvitationForm
public static object GetAcceptInvitationForm(
NancyContext context,
IDocumentSession documentSession,
string invitationCode)
{
context.Ensure("context");
documentSession.Ensure("documentSession");
if (!context.IsSignedUp())
return 403;
var playerInvitation = documentSession.GetPlayerInvitationByCode(invitationCode);
if (playerInvitation == null || playerInvitation.Used)
return 404;
var room = documentSession.GetRoomById(playerInvitation.RoomId);
if (room == null)
return 404;
return new AcceptInvitationFormResponse(room, invitationCode);
}
示例7: PostRoom
static object PostRoom(
NancyContext context,
IDocumentSession documentSession,
string title,
string slug,
string description)
{
context.Ensure("context");
documentSession.Ensure("documentSession");
if (!context.IsSignedUp())
return 403;
var errors = new List<string>();
errors.AddRange(fn.ValidateRequired("Title", title));
errors.AddRange(fn.ValidateLength("Title", title, 128));
errors.AddRange(fn.ValidateRequired("Slug", slug));
errors.AddRange(fn.ValidateLength("Slug", slug, 128));
errors.AddRange(fn.ValidateFormat("Slug", slug, new Regex("[a-z][a-z0-9_-]+")));
if (description != null)
errors.AddRange(fn.ValidateLength("Description", description, 1024));
var existingRoom =documentSession.GetRoomBySlug(slug);
if (existingRoom != null)
errors.Add(Strings.NotAvailable("slug", slug));
existingRoom = documentSession.GetRoomByTitle(title);
if (existingRoom != null)
errors.Add(Strings.NotAvailable("title", title));
if (errors.Count > 0)
return context.ModelWithStatus(new CreateRoomFormResponse(title, slug, description, errors), 400);
var currentMember = context.GetCurrentMember(documentSession);
Debug.Assert(currentMember != null, "`IsSignedUp` should ensure current member is not null.");
var room = documentSession.CreateRoom(currentMember.Id, slug, title, description);
return context.Redirect(Paths.Room(room.Slug));
}
示例8: PostPost
static object PostPost(
NancyContext context,
IDocumentSession documentSession,
IMailSender mailSender,
string slug,
string source)
{
context.Ensure("context");
documentSession.Ensure("documentSession");
if (String.IsNullOrEmpty(slug))
return 404;
if (!context.IsSignedUp())
return 403;
var room = documentSession.GetRoomBySlug(slug);
if (room == null)
return 404;
if (String.IsNullOrEmpty(source))
return 400;
var currentMember = context.GetCurrentMember(documentSession);
if (!room.CanPost(currentMember))
return 403;
var output = fn.HandlePost(documentSession, currentMember, room, source);
if (output == null)
output = new[] { InvalidPostHandlerOuput };
if (output.Length > 0)
return new SlashCommandOutputResponse(output);
return 204;
}
示例9: GetInitiator
static object GetInitiator(
NancyContext context,
IConfiguration configuration)
{
context.Ensure("context");
configuration.Ensure("configuration");
var returnUrl = context.Request.Query["return-url"].Value as string;
if (!String.IsNullOrEmpty(returnUrl))
context.SetReturnUrl(returnUrl);
var callbackUri = fn.MakeAbsoluteUri(Paths.TwitterAuthReceiver());
var oAuthRequest = OAuthRequest.ForRequestToken(
configuration.TwitterAuthConsumerKey,
configuration.TwitterAuthConsumerSecret,
callbackUri.ToString());
oAuthRequest.RequestUrl = Constants.TwitterAuth.RequestTokenUrl;
var response = fn.SendGet(
new Uri(oAuthRequest.RequestUrl),
addHeader => addHeader("Authorization", oAuthRequest.GetAuthorizationHeader()));
var @params = fn.ParseQueryString(response);
var token = @params[Constants.TwitterAuth.OAuthTokenParamName];
if (String.IsNullOrEmpty(token))
throw new InvalidOperationException(Strings.OAuthTokenMissing());
context.WriteSession(Constants.TwitterAuth.SessionKey, token);
return context.Redirect(string.Format(
CultureInfo.InvariantCulture,
Constants.TwitterAuth.AuthenticatehUrlFormat,
token));
}
示例10: PostPlayer
public static object PostPlayer(
NancyContext context,
IDocumentSession documentSession,
IMailSender mailSender,
string roomSlug,
string invitationCode,
string characterName,
string characterAvatarUrl)
{
context.Ensure("context");
documentSession.Ensure("documentSession");
mailSender.Ensure("mailSender");
if (string.IsNullOrEmpty(roomSlug))
return 404;
if (!context.IsSignedUp())
return 403;
var room = documentSession.GetRoomBySlug(roomSlug);
if (room == null)
return 404;
var currentMember = context.GetCurrentMember(documentSession);
Debug.Assert(currentMember != null, "`requireSignedUp()` should ensure a current member.");
var errors = new List<string>();
errors.AddRange(fn.ValidateRequired("Invitation code", invitationCode));
var playerInvitation = documentSession.GetPlayerInvitationByCode(invitationCode);
if (playerInvitation == null)
errors.Add("The invitation code is not valid.");
if (playerInvitation != null && playerInvitation.Used)
errors.Add("The invitation code has already been used.");
errors.AddRange(fn.ValidateRequired("Character Name", characterName));
errors.AddRange(fn.ValidateLength("Character Name", characterName, 64));
errors.AddRange(fn.ValidateFormat("Character Name", characterName, new Regex("^[a-z][a-z0-9 .'-]+$", RegexOptions.IgnoreCase)));
if (!string.IsNullOrEmpty(characterAvatarUrl))
errors.AddRange(fn.ValidateUrl("Avatar URL", characterAvatarUrl));
var existingPlayer = room.Players.FirstOrDefault(p => p.CharacterName.Equals(characterName, StringComparison.OrdinalIgnoreCase));
if (existingPlayer != null)
errors.Add(Strings.NotAvailable("character name", characterName));
if (errors.Count > 0)
return context.ModelWithStatus(new AcceptInvitationFormResponse(room, invitationCode, characterName, characterAvatarUrl, errors), 400);
var player = new Player
{
CharacterAvatarUrl = characterAvatarUrl,
CharacterName = characterName,
MemberAlias = currentMember.Alias,
MemberId = currentMember.Id,
MemberEmailAddress = currentMember.EmailAddress,
RoomId = room.Id
};
room.Players.Add(player);
documentSession.UpdatePlayerInvitation(playerInvitation.Id, used: true);
string text = Strings.Format("{0} joined the room as {1}.", player.MemberAlias, player.CharacterName);
documentSession.CreatePost(mailSender, room.Id, currentMember.Id, null, null, "system", text);
return context.Redirect(Paths.Room(room.Slug));
}