Files
Umbraco-CMS/src/Umbraco.Core/Services/PublicAccessServiceExtensions.cs

83 lines
3.4 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.Security;
namespace Umbraco.Core.Services
{
/// <summary>
/// Extension methods for the IPublicAccessService
/// </summary>
public static class PublicAccessServiceExtensions
{
public static bool RenameMemberGroupRoleRules(this IPublicAccessService publicAccessService, string oldRolename, string newRolename)
{
var hasChange = false;
if (oldRolename == newRolename) return false;
var allEntries = publicAccessService.GetAll();
foreach (var entry in allEntries)
{
//get rules that match
var roleRules = entry.Rules
.Where(x => x.RuleType == Constants.Conventions.PublicAccess.MemberRoleRuleType)
.Where(x => x.RuleValue == oldRolename);
var save = false;
foreach (var roleRule in roleRules)
{
//a rule is being updated so flag this entry to be saved
roleRule.RuleValue = newRolename;
save = true;
}
if (save)
{
hasChange = true;
publicAccessService.Save(entry);
}
}
return hasChange;
}
public static bool HasAccess(this IPublicAccessService publicAccessService, int documentId, IContentService contentService, IEnumerable<string> currentMemberRoles)
{
var content = contentService.GetById(documentId);
if (content == null) return true;
var entry = publicAccessService.GetEntryForContent(content);
if (entry == null) return true;
return entry.Rules.Any(x => x.RuleType == Constants.Conventions.PublicAccess.MemberRoleRuleType
&& currentMemberRoles.Contains(x.RuleValue));
}
[Obsolete("this is only used for backward compat")]
internal static bool HasAccess(this IPublicAccessService publicAccessService, int documentId, object providerUserKey, IContentService contentService, MembershipProvider membershipProvider, RoleProvider roleProvider)
{
var content = contentService.GetById(documentId);
if (content == null) return true;
var entry = publicAccessService.GetEntryForContent(content);
if (entry == null) return true;
var member = membershipProvider.GetUser(providerUserKey, false);
if (member == null) return false;
var roles = roleProvider.GetRolesForUser(member.UserName);
return entry.Rules.Any(x => x.RuleType == Constants.Conventions.PublicAccess.MemberRoleRuleType
&& roles.Contains(x.RuleValue));
}
public static bool HasAccess(this IPublicAccessService publicAccessService, string path, MembershipUser member, RoleProvider roleProvider)
{
var entry = publicAccessService.GetEntryForContent(path.EnsureEndsWith(path));
if (entry == null) return true;
var roles = roleProvider.GetRolesForUser(member.UserName);
return entry.Rules.Any(x => x.RuleType == Constants.Conventions.PublicAccess.MemberRoleRuleType
&& roles.Contains(x.RuleValue));
}
}
}