using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.Security;
namespace Umbraco.Core.Services
{
///
/// Extension methods for the IPublicAccessService
///
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 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));
}
public static bool HasAccess(this IPublicAccessService publicAccessService, string path, MembershipUser member, RoleProvider roleProvider)
{
return publicAccessService.HasAccess(path, member.UserName, roleProvider.GetRolesForUser);
}
///
/// Checks if the member with the specified username has access to the path which is also based on the passed in roles for the member
///
///
///
///
/// A callback to retrieve the roles for this member
///
public static bool HasAccess(this IPublicAccessService publicAccessService, string path, string username, Func> rolesCallback)
{
if (rolesCallback == null) throw new ArgumentNullException("roles");
if (string.IsNullOrWhiteSpace(username)) throw new ArgumentException("Value cannot be null or whitespace.", "username");
if (string.IsNullOrWhiteSpace(path)) throw new ArgumentException("Value cannot be null or whitespace.", "path");
var entry = publicAccessService.GetEntryForContent(path.EnsureEndsWith(path));
if (entry == null) return true;
var roles = rolesCallback(username);
return entry.Rules.Any(x => x.RuleType == Constants.Conventions.PublicAccess.MemberRoleRuleType
&& roles.Contains(x.RuleValue));
}
}
}