Esempio n. 1
0
def update_manager(organization, managers):
    managers_toadd = [u for u in managers
                      if not has_role(
                        user=u,
                        role=('OrganizationResponsible',
                            organization))]
    managers_todel = [u for u in organization.managers
                      if u not in managers]

    for manager in managers_todel:
        revoke_roles(manager, (('OrganizationResponsible',
                                organization),))

    for manager in managers_toadd:
        grant_roles(user=manager,
                    roles=(('OrganizationResponsible',
                           organization),))

    for manager in managers:
        if manager not in organization.members:
            organization.addtoproperty('members', manager)

    for member in organization.members:
        grant_roles(user=member,
                    roles=(('OrganizationMember',
                           organization),))
Esempio n. 2
0
    def set_organization(self, organization):
        current_organization = self.organization
        if organization:
            if current_organization is not organization:
                is_manager = current_organization and has_role(
                    ('OrganizationResponsible', current_organization),
                    self,
                    ignore_superiors=True)
                if current_organization and is_manager:
                    revoke_roles(
                        self,
                        (('OrganizationResponsible', current_organization), ))

                self.setproperty('organization', organization)
        elif current_organization:
            is_manager = has_role(
                ('OrganizationResponsible', current_organization),
                self,
                ignore_superiors=True)
            if is_manager:
                revoke_roles(
                    self,
                    (('OrganizationResponsible', current_organization), ))

            self.delfromproperty('organization', current_organization)
Esempio n. 3
0
    def _set(self, new_managers):
        old_managers = self.managers
        managers_toadd = [u for u in new_managers if u not in old_managers]
        managers_todel = [u for u in old_managers if u not in new_managers]

        for manager in managers_todel:
            revoke_roles(manager, (('OrganizationResponsible', self), ))

        for manager in managers_toadd:
            for current_org in manager.managed_organization:
                revoke_roles(manager,
                             (('OrganizationResponsible', current_org), ))

            grant_roles(user=manager,
                        roles=(('OrganizationResponsible', self), ))
Esempio n. 4
0
    def unsubscribe(self, context, user, **kwargs):
        if not hasattr(user, 'customeraccount'):
            user = getattr(self, 'customer', None)

        if not user and hasattr(context, 'customer') and\
           context.customer:
            user = context.customer.user

        customeraccount = getattr(user, 'customeraccount', None)
        if customeraccount:
            revoke_roles(user=user, roles=(("Owner", self), ))
            customeraccount.delfromproperty('services', self)

        if context:
            context.delfromproperty('services', self)
Esempio n. 5
0
    def unsubscribe(self, context, user, **kwargs):
        if not hasattr(user, 'customeraccount'):
            user = getattr(self, 'customer', None)

        if not user and hasattr(context, 'customer') and\
           context.customer:
            user = context.customer.user

        customeraccount = getattr(user, 'customeraccount', None)
        if customeraccount:
            revoke_roles(user=user, roles=(("Owner", self),))
            customeraccount.delfromproperty('services', self)

        if context:
            context.delfromproperty('services', self)
Esempio n. 6
0
    def start(self, context, request, appstruct, **kw):
        context.modified_at = datetime.datetime.now(tz=pytz.UTC)
        if isinstance(context.perimeter, SiteFolder):
            revoke_roles(context.delegate,
                         roles=(('Moderator', context.perimeter), ),
                         root=context.perimeter)
            context.delegate.reindex()
            context.delegate = appstruct['delegate']
            grant_roles(context.delegate,
                        roles=(("Moderator", context.perimeter), ))
        else:
            context.delegate = appstruct['delegate']

        context.delegate.reindex()
        context.reindex()
        return {}
Esempio n. 7
0
    def start(self, context, request, appstruct, **kw):
        members = appstruct['members']
        for member in members:
            if member in context.invited_users:
                context.delfromproperty('invited_users', member)
                revoke_roles(
                    user=member,
                    roles=(('ChallengeParticipant', context), ))

            member.reindex()

        context.reindex()
        context.modified_at = datetime.datetime.now(tz=pytz.UTC)
        request.registry.notify(ActivityExecuted(
            self, [context], get_current()))
        return {}
Esempio n. 8
0
    def start(self, context, request, appstruct, **kw):
        if isinstance(context.perimeter, SiteFolder):
            processes = [
                p for p in context.involvers if p.discriminator == 'Service'
            ]
            if processes:
                runtime = find_service('runtime')
                for process in processes:
                    runtime.delfromproperty('processes', process)

            revoke_roles(context.delegate,
                         roles=(('Moderator', context.perimeter), ),
                         root=context.perimeter)
            context.delegate.reindex()

        context.unsubscribe(context.perimeter, context.customer.user)
        return {}
Esempio n. 9
0
    def start(self, context, request, appstruct, **kw):
        if isinstance(context.perimeter, SiteFolder):
            processes = [p for p in context.involvers
                         if p.discriminator == 'Service']
            if processes:
                runtime = find_service('runtime')
                for process in processes:
                    runtime.delfromproperty('processes', process)

            revoke_roles(
                context.delegate,
                roles=(('Moderator', context.perimeter),),
                root=context.perimeter)
            context.delegate.reindex()

        context.unsubscribe(context.perimeter, context.customer.user)
        return {}
Esempio n. 10
0
    def start(self, context, request, appstruct, **kw):
        members = appstruct['members']
        for member in members:
            if member in context.members:
                context.delfromproperty('members', member)
                if has_role(user=member,
                    role=('OrganizationResponsible', context),
                    ignore_superiors=True):
                    revoke_roles(
                        user=member,
                        roles=(('OrganizationResponsible', context), ))
            member.reindex()

        context.reindex()
        context.modified_at = datetime.datetime.now(tz=pytz.UTC)
        request.registry.notify(ActivityExecuted(
            self, [context], get_current()))
        return {}
Esempio n. 11
0
    def start(self, context, request, appstruct, **kw):
        members = appstruct['members']
        for member in members:
            if member in context.members:
                context.delfromproperty('members', member)
                if has_role(user=member,
                            role=('OrganizationResponsible', context),
                            ignore_superiors=True):
                    revoke_roles(user=member,
                                 roles=(('OrganizationResponsible',
                                         context), ))
            member.reindex()

        context.reindex()
        context.modified_at = datetime.datetime.now(tz=pytz.UTC)
        request.registry.notify(
            ActivityExecuted(self, [context], get_current()))
        return {}
Esempio n. 12
0
    def start(self, context, request, appstruct, **kw):
        context.modified_at = datetime.datetime.now(tz=pytz.UTC)
        if isinstance(context.perimeter, SiteFolder):
            revoke_roles(
                context.delegate,
                roles=(('Moderator', context.perimeter),),
                root=context.perimeter)
            context.delegate.reindex()
            context.delegate = appstruct['delegate']
            grant_roles(
                context.delegate,
                roles=(("Moderator", context.perimeter),))
        else:
            context.delegate = appstruct['delegate']

        context.delegate.reindex()
        context.reindex()
        return {}
Esempio n. 13
0
    def empty(self, remove_author=True):
        author = self.proposal.author
        self.state = PersistentList(['deactivated'])
        self.setproperty('wating_list', [])
        if hasattr(self, 'first_improvement_cycle'):
            del self.first_improvement_cycle

        if hasattr(self, 'first_vote'):
            del self.first_vote

        members = self.members
        if remove_author and author in members:
            members.remove(author)

        for member in members:
            self.delfromproperty('members', member)
            revoke_roles(member, (('Participant', self.proposal), ))

        self.init_nonproductive_cycle()
Esempio n. 14
0
    def _set(self, new_managers):
        old_managers = self.managers
        managers_toadd = [u for u in new_managers
                          if u not in old_managers]
        managers_todel = [u for u in old_managers
                          if u not in new_managers]

        for manager in managers_todel:
            revoke_roles(manager, (('OrganizationResponsible',
                                    self),))

        for manager in managers_toadd:
            for current_org in manager.managed_organization:
                revoke_roles(manager, (('OrganizationResponsible',
                             current_org),))

            grant_roles(user=manager,
                        roles=(('OrganizationResponsible',
                                self),))
Esempio n. 15
0
    def empty(self, remove_author=True):
        author = self.proposal.author
        self.state = PersistentList(['deactivated'])
        self.setproperty('wating_list', [])
        if hasattr(self, 'first_improvement_cycle'):
            del self.first_improvement_cycle

        if hasattr(self, 'first_vote'):
            del self.first_vote

        members = self.members
        if remove_author and author in members:
            members.remove(author)

        for member in members:
            self.delfromproperty('members', member)
            revoke_roles(member, (('Participant', self.proposal),))

        self.init_nonproductive_cycle()
Esempio n. 16
0
    def start(self, context, request, appstruct, **kw):
        new_roles = list(appstruct['roles'])
        authorized_roles = get_authorized_roles()
        new_roles = [r for r in new_roles if r in authorized_roles]
        if new_roles:
            current_roles = [
                r for r in get_roles(context)
                if not getattr(DACE_ROLES.get(r, None), 'islocal', False)
            ]
            roles_to_revoke = [r for r in current_roles if r not in new_roles]
            roles_to_grant = [r for r in new_roles if r not in current_roles]
            revoke_roles(context, roles_to_revoke)
            grant_roles(context, roles_to_grant)
            context.modified_at = datetime.datetime.now(tz=pytz.UTC)
            context.reindex()
            request.registry.notify(
                ActivityExecuted(self, [context], get_current()))

        return {}
Esempio n. 17
0
    def start(self, context, request, appstruct, **kw):
        new_roles = list(appstruct['roles'])
        authorized_roles = get_authorized_roles()
        new_roles = [r for r in new_roles if r in authorized_roles]
        if new_roles:
            current_roles = [r for r in get_roles(context) if
                             not getattr(
                                 DACE_ROLES.get(r, None), 'islocal', False)]
            roles_to_revoke = [r for r in current_roles
                               if r not in new_roles]
            roles_to_grant = [r for r in new_roles
                              if r not in current_roles]
            revoke_roles(context, roles_to_revoke)
            grant_roles(context, roles_to_grant)
            context.modified_at = datetime.datetime.now(tz=pytz.UTC)
            context.reindex()
            request.registry.notify(ActivityExecuted(
                self, [context], get_current()))

        return {}
Esempio n. 18
0
    def start(self, context, request, appstruct, **kw):
        organization = appstruct['organization']
        if organization:
            is_manager = appstruct['ismanager']
            context.set_organization(organization)
            if is_manager:
                grant_roles(user=context,
                            roles=(('OrganizationResponsible',
                                    organization), ))
            else:
                revoke_roles(user=context,
                             roles=(('OrganizationResponsible',
                                     organization), ))

            context.reindex()
            context.modified_at = datetime.datetime.now(tz=pytz.UTC)
            request.registry.notify(
                ActivityExecuted(self, [context], get_current()))

        return {}
Esempio n. 19
0
    def after_execution(self, context, request, **kw):
        content = self.process.execution_context.involved_entity('content')
        close_ballot(self, content, request)
        # content not removed
        if content and content.__parent__:
            root = getSite()
            moderators = self.process.execution_context.get_involved_collection(
                'electors')
            for moderator in moderators:
                revoke_roles(user=moderator,
                             roles=(('LocalModerator', content), ))

            ballots = getattr(self.sub_process, 'ballots', [])
            ballot = None
            for ballot_ in ballots:
                ballot_.finish_ballot()
                ballot = ballot_

            ballot_oid = get_oid(ballot, '')
            ballot_url = request.resource_url(
                root, '@@seeballot', query={'id': ballot_oid}) \
                if ballot_oid else None
            accepted = ballot_result(self, _marker)
            if accepted:
                ignore(content, request, root)
                alert('internal', [request.root],
                      moderators,
                      internal_kind=InternalAlertKind.moderation_alert,
                      subjects=[content],
                      alert_kind='object_report_ignored',
                      ballot=ballot_url if accepted is not _marker else None)
            else:
                censor(content, request, root, ballot_url=ballot_url)
                alert('internal', [request.root],
                      moderators,
                      internal_kind=InternalAlertKind.moderation_alert,
                      subjects=[content],
                      alert_kind='object_censor',
                      ballot=ballot_url)

        super(ModerationVote, self).after_execution(content, request, **kw)
Esempio n. 20
0
    def start(self, context, request, appstruct, **kw):
        new_roles = list(appstruct['roles'])
        site = get_site_folder(True)
        if 'global_site' in kw:
            site = getSite()

        current_roles = [r for r in get_roles(context, root=site,
                                              ignore_groups=True)
                         if not getattr(DACE_ROLES.get(r, None),
                         'islocal', False)]
        roles_to_revoke = [(r, site) for r in current_roles
                           if r not in new_roles]
        roles_to_grant = [(r, site) for r in new_roles
                          if r not in current_roles]
        revoke_roles(context, roles_to_revoke)
        grant_roles(context, roles_to_grant)
        if 'Member' in roles_to_grant:
            grant_roles(context, ('Member',))

        context.reindex()
        request.registry.notify(ActivityExecuted(self, [context], get_current()))
        return {}
Esempio n. 21
0
    def start(self, context, request, appstruct, **kw):
        organization = appstruct['organization']
        if organization:
            is_manager = appstruct['ismanager']
            context.set_organization(organization)
            if is_manager:
                grant_roles(
                    user=context,
                    roles=(('OrganizationResponsible',
                            organization),))
            else:
                revoke_roles(
                    user=context,
                    roles=(('OrganizationResponsible',
                            organization),))

            context.reindex()
            context.modified_at = datetime.datetime.now(tz=pytz.UTC)
            request.registry.notify(ActivityExecuted(
                self, [context], get_current()))

        return {}
Esempio n. 22
0
    def set_organization(self, organization):
        current_organization = self.organization
        if organization:
            if current_organization is not organization:
                is_manager = current_organization and has_role(
                    ('OrganizationResponsible', current_organization), self,
                    ignore_superiors=True)
                if current_organization and is_manager:
                    revoke_roles(
                        self,
                        (('OrganizationResponsible', current_organization),))

                self.setproperty('organization', organization)
        elif current_organization:
            is_manager = has_role(
                ('OrganizationResponsible', current_organization), self,
                ignore_superiors=True)
            if is_manager:
                revoke_roles(
                    self,
                    (('OrganizationResponsible', current_organization),))

            self.delfromproperty('organization', current_organization)
Esempio n. 23
0
    def start(self, context, request, appstruct, **kw):
        new_roles = list(appstruct['roles'])
        site = get_site_folder(True)
        if 'global_site' in kw:
            site = getSite()

        current_roles = [
            r for r in get_roles(context, root=site, ignore_groups=True)
            if not getattr(DACE_ROLES.get(r, None), 'islocal', False)
        ]
        roles_to_revoke = [(r, site) for r in current_roles
                           if r not in new_roles]
        roles_to_grant = [(r, site) for r in new_roles
                          if r not in current_roles]
        revoke_roles(context, roles_to_revoke)
        grant_roles(context, roles_to_grant)
        if 'Member' in roles_to_grant:
            grant_roles(context, ('Member', ))

        context.reindex()
        request.registry.notify(
            ActivityExecuted(self, [context], get_current()))
        return {}
Esempio n. 24
0
    def test_grantroles(self):
        object1, object2 = self._create_objects()
        user = self.request.user #Admin
        self.assertEqual(len(get_roles(user)), 1)
        self.assertTrue(has_any_roles(user, roles=('Admin', )))
        grant_roles(user, roles=('Collaborator', ('Owner', object1)))
        self.assertTrue(has_any_roles(user, roles=('Collaborator', 'Owner')))
        self.assertTrue(has_any_roles(user, roles=('Collaborator', ('Owner', object1))))
        self.assertFalse(has_any_roles(user, roles=(('Owner', object2),)))

        roles = get_roles(user)
        self.assertEqual(len(roles), 3)
        self.assertIn('Collaborator',roles)
        self.assertIn('Owner',roles)
        self.assertIn('Admin',roles)

        self.assertTrue(has_all_roles(user, ('Collaborator', 'Owner')))
        self.assertFalse(has_all_roles(user, ('Collaborator', 'Owner', 'Other')))

        users = get_users_with_role(role=('Owner', object1))
        self.assertEqual(len(users), 1)
        self.assertIn(self.request.user,users)

        users = get_users_with_role(role='Owner')
        self.assertEqual(len(users), 1)
        self.assertIn(self.request.user,users)

        objects = get_objects_with_role(user=self.request.user, role='Owner')
        self.assertEqual(len(objects), 1)
        self.assertIn(object1,objects)
        
        revoke_roles(user, roles=(('Owner', object1),))
        self.assertFalse(has_all_roles(user, ('Collaborator', 'Owner')))
        self.assertTrue(has_all_roles(user, ('Collaborator', )))

        revoke_roles(user, roles=('Collaborator', ))
        self.assertEqual(len(get_roles(user)), 1)


        self.request.user = self.users['alice']
        user = self.request.user  #Alice
        roles = get_roles(user)
        self.assertEqual(len(roles), 0)
        grant_roles(user, roles=('Admin',))
        roles = get_roles(user)
        self.assertEqual(len(roles), 1)
        self.assertIn('Admin',roles)
        self.assertTrue(has_any_roles(user, roles=('Collaborator', )))

        revoke_roles(user, roles=('Admin', ))
        self.assertFalse(has_any_roles(user, roles=('Collaborator', )))
        grant_roles(user, roles=('Developer',))
        roles = get_roles(user)
        self.assertEqual(len(roles), 1)
        self.assertIn('Developer',roles)
        self.assertTrue(has_any_roles(user, roles=('Collaborator', )))
        self.assertFalse(has_any_roles(user, ('Collaborator', ), True)) #exclude superiors
 
        #Anonymous
        self.request.user = None
        roles = get_roles()
        self.assertEqual(len(roles), 1)
        self.assertIn('Anonymous',roles)
        self.assertFalse(has_any_roles(roles=('Collaborator', 'Owner')))
        self.assertTrue(has_any_roles(roles=('Anonymous',)))
Esempio n. 25
0
    def test_grantroles(self):
        object1, object2 = self._create_objects()
        user = self.request.user #Admin
        self.assertEqual(len(get_roles(user)), 1)
        self.assertTrue(has_any_roles(user, roles=('Admin', )))
        grant_roles(user, roles=('Collaborator', ('Owner', object1)))
        self.assertTrue(has_any_roles(user, roles=('Collaborator', 'Owner')))
        self.assertTrue(has_any_roles(user, roles=('Collaborator', ('Owner', object1))))
        self.assertFalse(has_any_roles(user, roles=(('Owner', object2),)))

        roles = get_roles(user)
        self.assertEqual(len(roles), 3)
        self.assertIn('Collaborator',roles)
        self.assertIn('Owner',roles)
        self.assertIn('Admin',roles)

        self.assertTrue(has_all_roles(user, ('Collaborator', 'Owner')))
        self.assertFalse(has_all_roles(user, ('Collaborator', 'Owner', 'Other')))

        users = get_users_with_role(role=('Owner', object1))
        self.assertEqual(len(users), 1)
        self.assertIn(self.request.user,users)

        users = get_users_with_role(role='Owner')
        self.assertEqual(len(users), 1)
        self.assertIn(self.request.user,users)

        objects = get_objects_with_role(user=self.request.user, role='Owner')
        self.assertEqual(len(objects), 1)
        self.assertIn(object1,objects)
        
        revoke_roles(user, roles=(('Owner', object1),))
        self.assertFalse(has_all_roles(user, ('Collaborator', 'Owner')))
        self.assertTrue(has_all_roles(user, ('Collaborator', )))

        revoke_roles(user, roles=('Collaborator', ))
        self.assertEqual(len(get_roles(user)), 1)


        self.request.user = self.users['alice']
        user = self.request.user  #Alice
        roles = get_roles(user)
        self.assertEqual(len(roles), 0)
        grant_roles(user, roles=('Admin',))
        roles = get_roles(user)
        self.assertEqual(len(roles), 1)
        self.assertIn('Admin',roles)
        self.assertTrue(has_any_roles(user, roles=('Collaborator', )))

        revoke_roles(user, roles=('Admin', ))
        self.assertFalse(has_any_roles(user, roles=('Collaborator', )))
        grant_roles(user, roles=('Developer',))
        roles = get_roles(user)
        self.assertEqual(len(roles), 1)
        self.assertIn('Developer',roles)
        self.assertTrue(has_any_roles(user, roles=('Collaborator', )))
        self.assertFalse(has_any_roles(user, ('Collaborator', ), True)) #exclude superiors
 
        #Anonymous
        self.request.user = None
        roles = get_roles()
        self.assertEqual(len(roles), 1)
        self.assertIn('Anonymous',roles)
        self.assertFalse(has_any_roles(roles=('Collaborator', 'Owner')))
        self.assertTrue(has_any_roles(roles=('Anonymous',)))