當前位置: 首頁>>代碼示例>>C#>>正文


C# Permissions.Permission類代碼示例

本文整理匯總了C#中Orchard.Security.Permissions.Permission的典型用法代碼示例。如果您正苦於以下問題:C# Permission類的具體用法?C# Permission怎麽用?C# Permission使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Permission類屬於Orchard.Security.Permissions命名空間,在下文中一共展示了Permission類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: GetOwnerVariation

 private static Permission GetOwnerVariation(Permission permission) {
     if (permission.Name == Permissions.Management.Name)
         return Permissions.Lead;
     if (permission.Name == Orchard.Core.Contents.Permissions.ViewContent.Name)
         return Orchard.Core.Contents.Permissions.ViewOwnContent;
     return null;
 }
開發者ID:dioptre,項目名稱:nkd,代碼行數:7,代碼來源:NKDAuthorizationEventHandler.cs

示例2: OnAuthorization

        public override void OnAuthorization(AuthorizationContext filterContext)
        {
            if (String.IsNullOrEmpty(PermissionName))
            {
                throw new ApplicationException("No permission supplied");
            }

            //No authorization if permission is AllowAnonymous
            if (String.Equals(PermissionName, "AllowAnonymous", StringComparison.InvariantCultureIgnoreCase))
            {
                return;
            }

            WorkContext workContext = filterContext.GetWorkContext();
            IAuthorizer authorizer = workContext.Resolve<IAuthorizer>();
            Permission permission = new Permission {Name = PermissionName};

            if (authorizer.Authorize(permission,
                new LocalizedString("Access is denied")))
            {
                return;
            }

            //Access is denied
            filterContext.Result = new HttpUnauthorizedResult();
        }
開發者ID:rijkshuisstijl,項目名稱:Orchard-Seeds,代碼行數:26,代碼來源:OrchardAuthorizationAttribute.cs

示例3: Authorize

        public new bool Authorize(Permission permission, IContent content, LocalizedString message) {
            var authorizerMessage = new AuthorizerMessage {PermissionName = permission.Name};

            if (content != null)
            {
                authorizerMessage.ContentId = content.Id;
                authorizerMessage.ContentType = content.ContentItem.ContentType;
                authorizerMessage.ContentName = content.GetContentName();
            }

            return _performanceMonitor.PublishTimedAction(() =>
            {
                if (permission == StandardPermissions.AccessFrontEnd)
                {
                    return true;
                }

                return base.Authorize(permission, content, message);
            }, (r, t) => { 
                authorizerMessage.Duration = t.Duration;
                authorizerMessage.UserIsAuthorized = r;

                return authorizerMessage;
            }, TimelineCategories.Authorization, "Authorize", permission.Name).ActionResult;
        }
開發者ID:pszmyd,項目名稱:Glimpse.Orchard,代碼行數:25,代碼來源:GlimpseAuthorizer.cs

示例4: ConvertToDynamicPermission

        /// <summary>
        /// Returns a dynamic permission for a content type, based on a global content permission template
        /// </summary>
        public static Permission ConvertToDynamicPermission(Permission permission) {
            if (PermissionTemplates.ContainsKey(permission.Name)) {
                return PermissionTemplates[permission.Name];
            }

            return null;
        }
開發者ID:RasterImage,項目名稱:Orchard,代碼行數:10,代碼來源:DynamicPermissions.cs

示例5: TryCheckAccess

        public bool TryCheckAccess(Permission permission, IUser user, IContent content) {
            var context = new CheckAccessContext { Permission = permission, User = user, Content = content };
            _authorizationServiceEventHandler.Checking(context);

            for (var adjustmentLimiter = 0; adjustmentLimiter != 3; ++adjustmentLimiter) {
                if (!context.Granted && context.User != null) {
                    if (String.Equals(context.User.UserName, "Administrator", StringComparison.OrdinalIgnoreCase) ||
                        ((!String.IsNullOrEmpty(CurrentSite.SuperUser) &&
                           String.Equals(context.User.UserName, CurrentSite.SuperUser, StringComparison.OrdinalIgnoreCase)))) {
                        context.Granted = true;
                    }
                }

                if (!context.Granted) {

                    // determine which set of permissions would satisfy the access check
                    var grantingNames = PermissionNames(context.Permission, Enumerable.Empty<string>()).ToArray();

                    // determine what set of roles should be examined by the access check
                    IEnumerable<string> rolesToExamine;
                    if (context.User == null) {
                        rolesToExamine = AnonymousRole;
                    }
                    else if (context.User.Has<IUserRoles>()) {
                        rolesToExamine = context.User.As<IUserRoles>().Roles.Concat(AuthenticatedRole);
                    }
                    else {
                        rolesToExamine = AuthenticatedRole;
                    }

                    foreach (var role in rolesToExamine) {
                        RoleRecord roleRecord = _roleService.GetRoleByName(role);
                        if ( roleRecord == null )
                            continue;
                        foreach (var permissionName in _roleService.GetPermissionsForRole(roleRecord.Id)) {
                            string possessedName = permissionName;
                            if (grantingNames.Any(grantingName => String.Equals(possessedName, grantingName, StringComparison.OrdinalIgnoreCase))) {
                                context.Granted = true;
                            }

                            if (context.Granted)
                                break;
                        }

                        if (context.Granted)
                            break;
                    }
                }

                context.Adjusted = false;
                _authorizationServiceEventHandler.Adjust(context);
                if (!context.Adjusted)
                    break;
            }

            _authorizationServiceEventHandler.Complete(context);

            return context.Granted;
        }
開發者ID:mofashi2011,項目名稱:orchardcms,代碼行數:59,代碼來源:RolesBasedAuthorizationService.cs

示例6: TryCheckAccess

        public bool TryCheckAccess(Permission permission, IUser user, IContent content) {
            var context = new CheckAccessContext { Permission = permission, User = user, Content = content };
            _authorizationServiceEventHandler.Checking(context);

            for (var adjustmentLimiter = 0; adjustmentLimiter != 3; ++adjustmentLimiter) {
                if (!context.Granted && context.User != null) {
                    if (!String.IsNullOrEmpty(_workContextAccessor.GetContext().CurrentSite.SuperUser) &&
                           String.Equals(context.User.UserName, _workContextAccessor.GetContext().CurrentSite.SuperUser, StringComparison.Ordinal)) {
                        context.Granted = true;
                    }
                }

                if (!context.Granted) {

                    // determine which set of permissions would satisfy the access check
                    var grantingNames = PermissionNames(context.Permission, Enumerable.Empty<string>()).Distinct().ToArray();

                    // determine what set of roles should be examined by the access check
                    IEnumerable<string> rolesToExamine;
                    if (context.User == null) {
                        rolesToExamine = AnonymousRole;
                    } 
                    else if (user.As<IUserRoles>().Roles.Any()) {
                        

                        // the current user is not null, so get his roles and add "Authenticated" to it
                        rolesToExamine = user.As<IUserRoles>().Roles.Union(AuthenticatedRole);

                    } else {
                        // the user is not null and has no specific role, then it's just "Authenticated"
                        rolesToExamine = AuthenticatedRole;
                    }

                    foreach (var role in rolesToExamine) {
                        foreach (var permissionName in _roleService.GetPermissionsForRoleByName(role)) {
                            string possessedName = permissionName;
                            if (grantingNames.Any(grantingName => String.Equals(possessedName, grantingName, StringComparison.OrdinalIgnoreCase))) {
                                context.Granted = true;
                            }

                            if (context.Granted)
                                break;
                        }

                        if (context.Granted)
                            break;
                    }
                }

                context.Adjusted = false;
                _authorizationServiceEventHandler.Adjust(context);
                if (!context.Adjusted)
                    break;
            }

            _authorizationServiceEventHandler.Complete(context);

            return context.Granted;
        }
開發者ID:NIKASoftwareDevs,項目名稱:Orchard,代碼行數:59,代碼來源:CASAuthorizationService.cs

示例7: CreateDynamicPermission

 /// <summary>
 /// Generates a permission dynamically for a content type
 /// </summary>
 public static Permission CreateDynamicPermission(Permission template, ContentTypeDefinition typeDefinition) {
     return new Permission {
         Name = String.Format(template.Name, typeDefinition.Name),
         Description = String.Format(template.Description, typeDefinition.DisplayName),
         Category = typeDefinition.DisplayName,
         ImpliedBy = (template.ImpliedBy ?? new Permission[0]).Select(t => CreateDynamicPermission(t, typeDefinition))
     };
 }
開發者ID:RasterImage,項目名稱:Orchard,代碼行數:11,代碼來源:DynamicPermissions.cs

示例8: PermissionRequirement

        public PermissionRequirement(Permission permission)
        {
            if (permission == null)
            {
                throw new ArgumentNullException(nameof(permission));
            }

            Permission = permission;
        }
開發者ID:jchenga,項目名稱:Orchard2,代碼行數:9,代碼來源:PermissionRequirement.cs

示例9: GetOwnerVariation

 private static Permission GetOwnerVariation(Permission permission) {
     if (permission.Name == Permissions.PublishOthersPages.Name)
         return Permissions.PublishPages;
     if (permission.Name == Permissions.EditOthersPages.Name)
         return Permissions.EditPages;
     if (permission.Name == Permissions.DeleteOthersPages.Name)
         return Permissions.DeletePages;
     return null;
 }
開發者ID:mofashi2011,項目名稱:orchardcms,代碼行數:9,代碼來源:AuthorizationEventHandler.cs

示例10: GetOwnerVariation

 private static Permission GetOwnerVariation(Permission permission) {
     if (permission.Name == Permissions.PublishTimetableAppointment.Name)
         return Permissions.PublishOwnTimetableAppointment;
     if (permission.Name == Permissions.EditTimetableAppointment.Name)
         return Permissions.EditOwnTimetableAppointment;
     if (permission.Name == Permissions.DeleteTimetableAppointment.Name)
         return Permissions.DeleteOwnTimetableAppointment;
     return null;
 }
開發者ID:dminik,項目名稱:voda_code,代碼行數:9,代碼來源:TimetableAuthorizationEventHandler.cs

示例11: CheckAccess

 public void CheckAccess(Permission permission, IUser user, IContent content) {
     if (!TryCheckAccess(permission, user, content)) {
         throw new OrchardSecurityException(T("A security exception occurred in the content management system.")) {
             PermissionName = permission.Name,
             User = user,
             Content = content
         };
     }
 }
開發者ID:githubzwj,項目名稱:Orchard.Platform,代碼行數:9,代碼來源:RolesBasedAuthorizationService.cs

示例12: GetOwnerVariation

 private static Permission GetOwnerVariation(Permission permission) {
     if (permission.Name == Permissions.PublishBlogPost.Name)
         return Permissions.PublishOwnBlogPost;
     if (permission.Name == Permissions.EditBlogPost.Name)
         return Permissions.EditOwnBlogPost;
     if (permission.Name == Permissions.DeleteBlogPost.Name)
         return Permissions.DeleteOwnBlogPost;
     return null;
 }
開發者ID:rupertwhitlock,項目名稱:IncreasinglyAbsorbing,代碼行數:9,代碼來源:BlogAuthorizationEventHandler.cs

示例13: GetOwnerVariation

 private static Permission GetOwnerVariation(Permission permission) {
     if (permission.Name == Permissions.PublishContent.Name)
         return Permissions.PublishOwnContent;
     if (permission.Name == Permissions.EditContent.Name)
         return Permissions.EditOwnContent;
     if (permission.Name == Permissions.DeleteContent.Name)
         return Permissions.DeleteOwnContent;
     return null;
 }
開發者ID:Vinna,項目名稱:DeepInSummer,代碼行數:9,代碼來源:AuthorizationEventHandler.cs

示例14: GetOwnerVariation

 private static Permission GetOwnerVariation(Permission permission)
 {
     if (permission.Name == Permissions.DeletePost.Name)
         return Permissions.DeleteOwnPost;
     if (permission.Name == Permissions.EditPost.Name)
         return Permissions.EditOwnPost;
     if (permission.Name == Permissions.MarkPostAsAnswer.Name)
         return Permissions.MarkPostInOwnThreadAsAnswer;
     return null;
 }
開發者ID:Trifectgaming,項目名稱:Trifect-CMS,代碼行數:10,代碼來源:ForumAuthorizationEventHandler.cs

示例15: GetOwnerVariation

 private static Permission GetOwnerVariation(Permission permission) {
     if (permission.Name == Permissions.ManageForums.Name)
         return Permissions.ManageOwnForums;
     if (permission.Name == Permissions.MoveThread.Name)
         return Permissions.MoveOwnThread;
     if (permission.Name == Permissions.StickyThread.Name)
         return Permissions.StickyOwnThread;
     if (permission.Name == Permissions.CloseThread.Name)
         return Permissions.CloseOwnThread;
     return null;
 }
開發者ID:WoB-OSS,項目名稱:NGM.Forum,代碼行數:11,代碼來源:ForumAuthorizationEventHandler.cs


注:本文中的Orchard.Security.Permissions.Permission類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。