本文整理汇总了C#中MindTouch.Deki.Data.UserBE类的典型用法代码示例。如果您正苦于以下问题:C# UserBE类的具体用法?C# UserBE怎么用?C# UserBE使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
UserBE类属于MindTouch.Deki.Data命名空间,在下文中一共展示了UserBE类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: CreateNewUser
public static UserBE CreateNewUser(UserBE newUser) {
if(newUser == null)
return null;
//throw exception if licensing does not allow creation of another user
LicenseBL.IsUserCreationAllowed(true);
if(newUser.RoleId == 0) {
RoleBE defaultRole = PermissionsBL.RetrieveDefaultRoleForNewAccounts();
if(defaultRole != null)
newUser.RoleId = defaultRole.ID;
}
ValidateUser(newUser);
newUser.CreateTimestamp = DateTime.UtcNow;
uint userId = DbUtils.CurrentSession.Users_Insert(newUser);
if(userId == 0) {
return null;
}
newUser.ID = userId;
PageBE userHomepage = null;
try {
// User homepages are created upon user creation (an attempt to create user homepages may also be done upon login)
userHomepage = PageBL.CreateUserHomePage(newUser);
} catch { }
RecentChangeBL.AddUserCreatedRecentChange(DateTime.UtcNow, userHomepage, DekiContext.Current.User ?? newUser, String.Format(DekiResources.USER_ADDED, newUser.Name));
DekiContext.Current.Instance.EventSink.UserCreate(DreamContext.Current.StartTime, newUser);
return newUser;
}
示例2: UpdateUser
public static void UpdateUser(UserBE user) {
// Note (maxm): The user 'touched' timestamp is updated:
// * at authentication time
// * any user object changes (including group membership)
// It's exposed in the user xml as 'date.lastlogin'
user.Touched = DateTime.UtcNow;
ValidateUser(user);
DbUtils.CurrentSession.Users_Update(user);
DekiContext.Current.Instance.EventSink.UserUpdate(DreamContext.Current.StartTime, user);
}
示例3: PerformBanCheck
public static void PerformBanCheck(UserBE user, string[] clientIps, out ulong banMask, out List<string> banReasons) {
banMask = ulong.MinValue;
banReasons = new List<string>();
ulong? cachedBanMask = GetBanMaskFromCache(user.ID, clientIps);
if(cachedBanMask != null) {
//TODO MaxM: Ban reasons isn't currently cached (or used)
banMask = cachedBanMask.Value;
} else {
IList<BanBE> bans = DbUtils.CurrentSession.Bans_GetByRequest(user.ID, clientIps.ToList());
foreach(BanBE ban in bans) {
if(!ban.Expires.HasValue || (ban.Expires.Value >= DateTime.UtcNow)) {
banMask |= ban.RevokeMask;
banReasons.Add(ban.Reason);
}
}
CacheBanMask(user.ID, clientIps, banMask);
}
}
示例4: SetRating
//--- Methods ---
public static void SetRating(PageBE page, UserBE user, float? score) {
ThrowOnInvalidLicense();
RatingBE currentRating = DbUtils.CurrentSession.Rating_GetUserResourceRating(user.ID, page.ID, ResourceBE.Type.PAGE);
if(score == null) {
if(currentRating == null) {
// no rating exists currently: noop
return;
}
// reset a user ratings for a page
DbUtils.CurrentSession.Rating_ResetUserResourceRating(user.ID, page.ID, ResourceBE.Type.PAGE, DreamContext.Current.StartTime);
} else {
// set or update a page rating
// Valid score is limited to 0 and 1.
if(score != 0 && score != 1) {
throw new Exceptions.InvalidRatingScoreException();
}
if(currentRating != null && currentRating.Score == score) {
// an equal score already exists: noop
return;
}
RatingBE rating = new RatingBE();
rating.ResourceId = page.ID;
rating.ResourceType = ResourceBE.Type.PAGE;
rating.ResourceRevision = page.Revision;
rating.Timestamp = DreamContext.Current.StartTime;
rating.TimestampReset = null;
rating.UserId = user.ID;
rating.Score = score.Value;
// Set a new rating
DbUtils.CurrentSession.Rating_Insert(rating);
}
// Trigger a notification
DekiContext.Current.Instance.EventSink.PageRated(DreamContext.Current.StartTime, page, user);
}
示例5: UpdateUserFromXml
private static UserBE UpdateUserFromXml(UserBE userToUpdate, XDoc userDoc, string username, string email, string fullname, ServiceBE authservice, RoleBE role, bool? active, string externalusername, string externalpassword, string language, string timezone, out List<GroupBE> externalGroups) {
externalGroups = null;
if(userToUpdate.Name != username && !string.IsNullOrEmpty(username)) {
if(UserBL.IsAnonymous(userToUpdate)) {
throw new DreamBadRequestException(DekiResources.ANONYMOUS_USER_EDIT);
}
userToUpdate = RenameUser(userToUpdate, username);
}
//Modify a user's authentication service
if(authservice != null && authservice.Id != userToUpdate.ServiceId) {
if(UserBL.IsAnonymous(userToUpdate)) {
throw new DreamBadRequestException(DekiResources.ANONYMOUS_USER_EDIT);
}
if(ServiceBL.IsLocalAuthService(authservice)) {
//external to local
userToUpdate.ExternalName = null;
userToUpdate.ServiceId = authservice.Id;
} else {
//(local or external) to external
userToUpdate = ExternalServiceSA.BuildUserFromAuthService(authservice, userToUpdate, userToUpdate.Name, true, externalusername, externalpassword, out externalGroups);
if(userToUpdate == null) {
throw new DreamInternalErrorException(DekiResources.USER_AUTHSERVICE_CHANGE_FAIL);
}
//Does the external account already exist?
UserBE matchingExternalAccount = DbUtils.CurrentSession.Users_GetByExternalName(userToUpdate.ExternalName, userToUpdate.ServiceId);
if(matchingExternalAccount != null) {
throw new DreamAbortException(DreamMessage.Conflict(string.Format(DekiResources.USER_EXISTS_WITH_EXTERNAL_NAME, matchingExternalAccount.Name, matchingExternalAccount.ExternalName, matchingExternalAccount.ServiceId)));
}
}
}
if(email != null) {
if(UserBL.IsAnonymous(userToUpdate) && email != userToUpdate.Email) {
throw new DreamBadRequestException(DekiResources.ANONYMOUS_USER_EDIT);
}
userToUpdate.Email = email;
}
if(!string.IsNullOrEmpty(fullname))
userToUpdate.RealName = fullname;
if(active != null) {
if(UserBL.IsAnonymous(userToUpdate) && userToUpdate.UserActive && !active.Value) {
throw new DreamBadRequestException(DekiResources.DEACTIVATE_ANONYMOUS_NOT_ALLOWED);
}
//throw exception if licensing does not allow activating a user
if(!userToUpdate.UserActive && active.Value) {
LicenseBL.IsUserCreationAllowed(true);
}
userToUpdate.UserActive = active.Value;
}
if(role != null && role.ID != userToUpdate.RoleId) {
PermissionsBL.CheckUserAllowed(DekiContext.Current.User, Permissions.ADMIN);
userToUpdate.RoleId = role.ID;
}
if(language != null) {
userToUpdate.Language = language;
}
if(timezone != null) {
userToUpdate.Timezone = timezone;
}
return userToUpdate;
}
示例6: ReadUserXml
private static UserBE ReadUserXml(XDoc userDoc, string username, string email, string fullname, ServiceBE authService, RoleBE role, string language, string timezone) {
UserBE user = new UserBE();
if(string.IsNullOrEmpty(username))
throw new DreamBadRequestException(DekiResources.USERNAME_PARAM_INVALID);
//TODO (MaxM) Consider validation of fullname, email, username
//Retrieve default auth service for new user if authservice not given
if(authService == null) {
authService = ServiceBL.RetrieveLocalAuthService();
}
user.Name = username;
//Default role will be applied if one is not given
if(role != null)
user.RoleId = role.ID;
user.RealName = fullname ?? string.Empty;
user.ServiceId = authService.Id;
user.UserActive = true;
user.Email = email ?? string.Empty;
user.Language = language;
user.Timezone = timezone;
return user;
}
示例7: IsValidAuthenticationForLocalUser
public static bool IsValidAuthenticationForLocalUser(UserBE user, string password, out bool altPassword) {
bool isValid = false;
altPassword = false;
string encrypted = AuthBL.EncryptPassword(user, password);
if(string.CompareOrdinal(encrypted, user.Password) == 0) {
//On login if a user has a temp password but logs in with original password, clear out the temp password.
if(!string.IsNullOrEmpty(user.NewPassword)) {
user.NewPassword = string.Empty;
DbUtils.CurrentSession.Users_Update(user);
}
isValid = true;
} else if(!string.IsNullOrEmpty(user.NewPassword) && string.CompareOrdinal(encrypted, user.NewPassword) == 0) {
isValid = true;
altPassword = true;
}
return isValid;
}
示例8: EncryptPassword
public static string EncryptPassword(UserBE user, string pwd) {
string md5Pwd = GetMD5(pwd);
return GetMD5(user.ID + "-" + md5Pwd);
}
示例9: CreateAuthTokenForUser
private static string CreateAuthTokenForUser(UserBE user, DateTime timestamp) {
string ret = string.Empty;
string tokenContent = string.Format("{0}_{1}", user.ID.ToString(), timestamp.ToUniversalTime().Ticks);
//Include the users current password as part of validation to invalidate token upon pw change.
string contentToValidate = string.Format("{0}.{1}.{2}", tokenContent, user.Password ?? string.Empty, DekiContext.Current.Instance.AuthTokenSalt);
System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
string hash = new Guid(md5.ComputeHash(Encoding.Default.GetBytes(contentToValidate))).ToString("N");
ret = tokenContent + "_" + hash;
return ret;
}
示例10: ValidateGroupMemberList
private static void ValidateGroupMemberList(ServiceBE groupService, UserBE[] potentialMembers) {
//Groups belonging to built-in auth service are allowed to contain users from remote services
if(!ServiceBL.IsLocalAuthService(groupService)) {
foreach(UserBE u in potentialMembers) {
if(u.ServiceId != groupService.Id)
throw new GroupMembersRequireSameAuthInvalidOperationException();
}
}
}
示例11: CreateOrUpdateUser
public static UserBE CreateOrUpdateUser(UserBE user, string newPassword) {
if(user.ID > 0) {
UpdateUser(user);
} else {
//TODO consider logic here to confirm that the user does not yet exist.
user = CreateNewUser(user);
}
if(!string.IsNullOrEmpty(newPassword) && ServiceBL.IsLocalAuthService(user.ServiceId)) {
user = UserBL.SetPassword(user, newPassword, false);
DekiContext.Current.Instance.EventSink.UserChangePassword(DreamContext.Current.StartTime, user);
}
return user;
}
示例12: PostUserFromXml
public static UserBE PostUserFromXml(XDoc userDoc, UserBE userToProcess, string accountpassword, string externalusername, string externalpassword) {
List<GroupBE> externalGroups = null;
uint? id;
bool? active;
string username, fullname, email, language, timezone;
ServiceBE authService;
RoleBE role;
//Parse the standard user XML doc
ParseUserXml(userDoc, out id, out username, out email, out fullname, out authService, out role, out active, out language, out timezone);
//new user
if(userToProcess == null && (id == null || id == 0)) {
userToProcess = ReadUserXml(userDoc, username, email, fullname, authService, role, language, timezone);
//External accounts should be confirmed, username normalized, groups retrieved
if(authService != null && !ServiceBL.IsLocalAuthService(authService)) {
if(!string.IsNullOrEmpty(accountpassword))
throw new DreamBadRequestException(DekiResources.CANNOT_SET_EXTERNAL_ACCOUNT_PASSWORD);
//Only admins can create external accounts for others. Anyone can create their own external account
if(externalusername != userToProcess.Name || externalusername == string.Empty)
PermissionsBL.CheckUserAllowed(DekiContext.Current.User, Permissions.ADMIN);
//username+password from request query params are used here
userToProcess = ExternalServiceSA.BuildUserFromAuthService(authService, userToProcess, username, true, externalusername, externalpassword, out externalGroups);
if(userToProcess == null) {
throw new DreamAbortException(DreamMessage.NotFound(string.Format(DekiResources.EXTERNAL_USER_NOT_FOUND, username)));
}
//Does the external account already exist?
UserBE matchingExternalAccount = DbUtils.CurrentSession.Users_GetByExternalName(userToProcess.ExternalName, userToProcess.ServiceId);
if(matchingExternalAccount != null) {
throw new DreamAbortException(DreamMessage.Conflict(string.Format(DekiResources.USER_EXISTS_WITH_EXTERNAL_NAME, matchingExternalAccount.Name, userToProcess.ExternalName, userToProcess.ServiceId)));
}
} else { //Creating local account
//User creation requires admin rights unless the config flag allows it
//Anonymous users are not allowed to set role
if(!DekiContext.Current.Instance.AllowAnonymousLocalAccountCreation || role != null) {
PermissionsBL.CheckUserAllowed(DekiContext.Current.User, Permissions.ADMIN);
}
}
//Sanity check for already existing user
UserBE existingUser = DbUtils.CurrentSession.Users_GetByName(userToProcess.Name);
if(existingUser != null) {
throw new DreamAbortException(DreamMessage.Conflict(string.Format(DekiResources.USER_EXISTS_WITH_ID, existingUser.Name, existingUser.ID)));
}
//if (UserDA.RetrieveUserRegistrations(userToProcess.Name)) {
// throw new DreamAbortException(DreamMessage.Conflict(string.Format("User '{0}' has been reserved", userToProcess.Name)));
//}
userToProcess = UserBL.CreateOrUpdateUser(userToProcess, accountpassword);
if(null != externalGroups) {
UserBL.UpdateUsersGroups(userToProcess, externalGroups.ToArray());
}
}
//update existing user
else {
if(userToProcess == null) {
//Modifying a user with POST
if(id == null || id == 0) {
throw new DreamAbortException(DreamMessage.BadRequest(DekiResources.USER_ID_ATTR_INVALID));
}
userToProcess = UserBL.GetUserById(id.Value);
if(userToProcess == null) {
throw new DreamAbortException(DreamMessage.NotFound(string.Format(DekiResources.USER_ID_NOT_FOUND, id)));
}
}
if(!string.IsNullOrEmpty(accountpassword))
throw new DreamBadRequestException(DekiResources.USE_PUT_TO_CHANGE_PASSWORDS);
//Permission check if not modifying self
if(userToProcess.ID != DekiContext.Current.User.ID)
PermissionsBL.CheckUserAllowed(DekiContext.Current.User, Permissions.ADMIN);
userToProcess = UpdateUserFromXml(userToProcess, userDoc, username, email, fullname, authService, role, active, externalusername, externalpassword, language, timezone, out externalGroups);
userToProcess = CreateOrUpdateUser(userToProcess);
if(null != externalGroups) {
UserBL.UpdateUsersGroups(userToProcess, externalGroups.ToArray());
}
if(UserBL.IsAnonymous(userToProcess) && DekiContext.Current.Instance.CacheAnonymousOutput) {
DekiContext.Current.Deki.EmptyResponseCacheInternal();
}
}
return userToProcess;
}
示例13: GetUserXml
public static XDoc GetUserXml(UserBE user, string relation, bool showPrivateInfo) {
XDoc userXml = new XDoc(string.IsNullOrEmpty(relation) ? "user" : "user." + relation);
userXml.Attr("id", user.ID);
userXml.Attr("href", DekiContext.Current.ApiUri.At("users", user.ID.ToString()));
userXml.Elem("nick", user.Name);
userXml.Elem("username", user.Name);
userXml.Elem("fullname", user.RealName ?? String.Empty);
// check if we can add the email address
if(showPrivateInfo) {
userXml.Elem("email", user.Email);
} else {
userXml.Start("email").Attr("hidden", true).End();
}
// add gravatar
if(!IsAnonymous(user) && !string.IsNullOrEmpty(user.Email)) {
DekiContext context = DekiContext.CurrentOrNull;
XUri gravatar = new XUri("http://www.gravatar.com/avatar");
string hash = string.Empty;
if(context != null) {
DekiInstance deki = context.Instance;
string secure = context.Instance.GravatarSalt ?? string.Empty;
if(!secure.EqualsInvariantIgnoreCase("hidden")) {
hash = StringUtil.ComputeHashString(secure + (user.Email ?? string.Empty).Trim().ToLowerInvariant(), System.Text.Encoding.UTF8);
}
// add size, if any
string size = deki.GravatarSize;
if(size != null) {
gravatar = gravatar.With("s", size);
}
// add rating, if any
string rating = deki.GravatarRating;
if(rating != null) {
gravatar = gravatar.With("r", rating);
}
// add default icon, if any
string def = deki.GravatarDefault;
if(def != null) {
gravatar = gravatar.With("d", def);
}
}
if(!string.IsNullOrEmpty(hash)) {
userXml.Elem("hash.email", hash);
userXml.Elem("uri.gravatar", gravatar.At(hash + ".png"));
} else {
userXml.Elem("hash.email", string.Empty);
userXml.Elem("uri.gravatar", gravatar.At("no-email.png"));
}
}
return userXml;
}
示例14: UpdateUserTimestamp
/// <summary>
/// Updates the given user in the db with current timestamp
/// </summary>
/// <param name="user"></param>
public static UserBE UpdateUserTimestamp(UserBE user) {
if(user == null)
return null;
//Update user's last logged time column to now if it's more than a minute old.
if(user.Touched <= DateTime.UtcNow.AddMinutes(-1) && user.UserActive) {
// Note (maxm): This does not call UserBL.UserUpdate to avoid frequent reindexing.
user.Touched = DateTime.UtcNow;
DbUtils.CurrentSession.Users_Update(user);
}
return user;
}
示例15: ValidateUser
public static void ValidateUser(UserBE user) {
if(string.IsNullOrEmpty(user.Name) || user.Name.EndsWith(".", true, CultureInfo.InvariantCulture) || !Title.FromUIUsername(user.Name).IsValid)
throw new DreamBadRequestException(string.Format(DekiResources.USER_VALIDATION_FAILED, user.Name));
}