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


Python reversion.set_user方法代碼示例

本文整理匯總了Python中reversion.set_user方法的典型用法代碼示例。如果您正苦於以下問題:Python reversion.set_user方法的具體用法?Python reversion.set_user怎麽用?Python reversion.set_user使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在reversion的用法示例。


在下文中一共展示了reversion.set_user方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _save_as_revision

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def _save_as_revision(self, object_list, user, comment):
        for object in object_list:
            object.save()
            reversion.set_user(user=user)
            reversion.set_comment(comment=comment) 
開發者ID:madprime,項目名稱:gennotes,代碼行數:7,代碼來源:add_clinvar_data.py

示例2: event_undelete

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def event_undelete(request, event_id):
    request.user.is_authenticated() and reversion.set_user(request.user)
    try:
        deleted_version = Version.objects. \
                get_deleted(Event).get(object_id=event_id)
    except Version.DoesNotExist:
        raise Http404
    # TODO ask the user for a reason for the undeletion
    deleted_revision = deleted_version.revision
    revisioninfos = deleted_revision.revisioninfo_set.all()
    # a revision should have only one revisioninfo (design constraint)
    # TODO check this constranint with a post_save signal in revisioninfo
    assert len( revisioninfos ) == 1
    revisioninfo = revisioninfos[0]
    # we check if there is an event with the same name and start date
    # TODO test when there is one
    as_text = revisioninfo.as_text
    simple_fields = Event.get_fields( as_text )[0]
    title = simple_fields['title']
    start = simple_fields['start']
    try:
        equal = Event.objects.get( title = title,
                dates__eventdate_name = start )
    except Event.DoesNotExist:
        deleted_revision.revert()
        reversion.add_meta( RevisionInfo, as_text = as_text )
        equal = False
    if not equal:
        messages.info( request, _('Event has been successfully undeleted.') )
        return HttpResponseRedirect( reverse(
            'event_show_all', kwargs = {'event_id': event_id} ) )
    messages.error( request, _( 'Undelete operation not possible' ) )
    templates = {
            'title': _( "undelete event %(event_nr)s" ) % \
                        {'event_nr': deleted_version.object_id,},
            'as_text': as_text,
            'event_id': event_id,
            'title': title,
            'start': start,
            'equal': equal,}
    return render(request, 'event_undelete_error.html', templates) 
開發者ID:wikical,項目名稱:grical,代碼行數:43,代碼來源:views.py

示例3: update_from_korben

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def update_from_korben(self):
        """Update the model fields from Korben.

        :return the new instance
        """
        with reversion.create_revision():
            korben_data = self._convert_model_to_korben_format()
            korben_response = self.korben_connector.get(data=korben_data)
            self._map_korben_response_to_model_instance(korben_response)
            self.save(as_korben=True)

            reversion.set_user(get_korben_user())
            reversion.set_comment('Updated by Korben')
        return self 
開發者ID:uktrade-attic,項目名稱:data-hub-backend,代碼行數:16,代碼來源:mixins.py

示例4: testCanAddMetaToRevision

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def testCanAddMetaToRevision(self):
        # Create a revision with lots of meta data.
        with reversion.create_revision():
            self.test11.save()
            reversion.set_comment("Foo bar")
            self.assertEqual(reversion.get_comment(), "Foo bar")
            reversion.set_user(self.user)
            self.assertEqual(reversion.get_user(), self.user)
            reversion.add_meta(RevisionMeta, age=5)
        # Test the revision data.
        revision = reversion.get_for_object(self.test11)[0].revision
        self.assertEqual(revision.user, self.user)
        self.assertEqual(revision.comment, "Foo bar")
        self.assertEqual(revision.revisionmeta.age, 5) 
開發者ID:osess,項目名稱:mes,代碼行數:16,代碼來源:tests.py

示例5: generate_pairings_view

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def generate_pairings_view(self, request, object_id):
        round_ = get_object_or_404(Round, pk=object_id)
        if not request.user.has_perm('tournament.generate_pairings', round_.season.league):
            raise PermissionDenied

        if request.method == 'POST':
            form = forms.GeneratePairingsForm(request.POST)
            if form.is_valid():
                try:
                    if form.cleaned_data['run_in_background']:
                        signals.do_generate_pairings.send(sender=self.__class__, round_id=round_.pk, overwrite=form.cleaned_data['overwrite_existing'])
                        self.message_user(request, 'Generating pairings in background.', messages.INFO)
                        return redirect('admin:review_pairings', object_id)
                    else:
                        pairinggen.generate_pairings(round_, overwrite=form.cleaned_data['overwrite_existing'])
                        with reversion.create_revision():
                            reversion.set_user(request.user)
                            reversion.set_comment('Generated pairings.')
                            round_.publish_pairings = False
                            round_.save()

                        self.message_user(request, 'Pairings generated.', messages.INFO)
                        return redirect('admin:review_pairings', object_id)
                except pairinggen.PairingsExistException:
                    if not round_.publish_pairings:
                        self.message_user(request, 'Unpublished pairings already exist.', messages.WARNING)
                        return redirect('admin:review_pairings', object_id)
                    self.message_user(request, 'Pairings already exist for the selected round.', messages.ERROR)
                except pairinggen.PairingHasResultException:
                    self.message_user(request, 'Pairings with results can\'t be overwritten.', messages.ERROR)
                except pairinggen.PairingGenerationException as e:
                    self.message_user(request, 'Error generating pairings. %s' % e.message, messages.ERROR)
                return redirect('admin:generate_pairings', object_id=round_.pk)
        else:
            form = forms.GeneratePairingsForm()

        context = {
            'has_permission': True,
            'opts': self.model._meta,
            'site_url': '/',
            'original': round_,
            'title': 'Generate pairings',
            'form': form
        }

        return render(request, 'tournament/admin/generate_pairings.html', context) 
開發者ID:cyanfish,項目名稱:heltour,代碼行數:48,代碼來源:admin.py

示例6: reject_registration

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def reject_registration(self, request, object_id):
        reg = get_object_or_404(Registration, pk=object_id)
        if not request.user.has_perm('tournament.change_registration', reg.season.league):
            raise PermissionDenied

        if reg.status != 'pending':
            return redirect('admin:review_registration', object_id)

        if request.method == 'POST':
            changelist_filters = request.POST.get('_changelist_filters', '')
            form = forms.RejectRegistrationForm(request.POST, registration=reg)
            if form.is_valid():
                if 'confirm' in form.data:
                    with reversion.create_revision():
                        reversion.set_user(request.user)
                        reversion.set_comment('Rejected registration.')

                        reg.status = 'rejected'
                        reg.status_changed_by = request.user.username
                        reg.status_changed_date = timezone.now()
                        reg.save()

                    self.message_user(request, 'Registration for "%s" rejected.' % reg.lichess_username, messages.INFO)
                    return redirect_with_params('admin:tournament_registration_changelist', params='?' + changelist_filters)
                else:
                    return redirect('admin:review_registration', object_id)
                    return redirect_with_params('admin:review_registration', object_id, params='?_changelist_filters=' + urlquote(changelist_filters))
        else:
            changelist_filters = request.GET.get('_changelist_filters', '')
            form = forms.RejectRegistrationForm(registration=reg)

        context = {
            'has_permission': True,
            'opts': self.model._meta,
            'site_url': '/',
            'original': reg,
            'title': 'Confirm rejection',
            'form': form,
            'changelist_filters': changelist_filters
        }

        return render(request, 'tournament/admin/reject_registration.html', context) 
開發者ID:cyanfish,項目名稱:heltour,代碼行數:44,代碼來源:admin.py

示例7: run

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def run(self, complete_round=False, complete_season=False, update_board_order=False, generate_pairings=False, background=False, user=None):
        msg_list = []
        round_to_close = self.round_to_close
        round_to_open = self.round_to_open
        season_to_close = self.season_to_close

        with transaction.atomic():
            if complete_round and round_to_close is not None:
                with reversion.create_revision():
                    reversion.set_user(user)
                    reversion.set_comment('Closed round.')
                    round_to_close.is_completed = True
                    round_to_close.save()
                msg_list.append(('Round %d set as completed.' % round_to_close.number, messages.INFO))
            if complete_season and season_to_close is not None and (round_to_close is None or round_to_close.is_completed):
                with reversion.create_revision():
                    reversion.set_user(user)
                    reversion.set_comment('Closed season.')
                    season_to_close.is_completed = True
                    season_to_close.save()
                msg_list.append(('%s set as completed.' % season_to_close.name, messages.INFO))
            if update_board_order and round_to_open is not None and self.season.league.competitor_type == 'team':
                try:
                    UpdateBoardOrderWorkflow(self.season).run(alternates_only=False)
                    msg_list.append(('Board order updated.', messages.INFO))
                except IndexError:
                    msg_list.append(('Error updating board order.', messages.ERROR))
                    return msg_list
            if generate_pairings and round_to_open is not None:
                if background:
                    signals.do_generate_pairings.send(sender=self.__class__, round_id=round_to_open.pk)
                    msg_list.append(('Generating pairings in background.', messages.INFO))
                else:
                    try:
                        pairinggen.generate_pairings(round_to_open, overwrite=False)
                        with reversion.create_revision():
                            reversion.set_user(user)
                            reversion.set_comment('Generated pairings.')
                            round_to_open.publish_pairings = False
                            round_to_open.save()
                        msg_list.append(('Pairings generated.', messages.INFO))
                    except pairinggen.PairingsExistException:
                        msg_list.append(('Unpublished pairings already exist.', messages.WARNING))
                    except pairinggen.PairingHasResultException:
                        msg_list.append(('Pairings with results can\'t be overwritten.', messages.ERROR))
                    except pairinggen.PairingGenerationException as e:
                        msg_list.append(('Error generating pairings. %s' % e.message, messages.ERROR))
        return msg_list 
開發者ID:cyanfish,項目名稱:heltour,代碼行數:50,代碼來源:workflows.py

示例8: _change_recurrences

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import set_user [as 別名]
def _change_recurrences( user, event, events ): # {{{1
    """ modifies the events in ``events`` with the data of ``event`` except for
    ``start`` and ``end``, and including urls changes also. """
    if not events:
        return
    for rec in events:
        assert rec.recurring.master == event.recurring.master
        something_changed = False
        with reversion.create_revision():
            user.is_authenticated() and reversion.set_user(user)
            for field in Event.get_simple_fields():
                if field in ['startdate', 'enddate']:
                    continue
                if getattr(rec, field) != getattr(event, field):
                    setattr( rec, field, getattr( event, field ) )
                    something_changed = True
            if rec.description != event.description:
                rec.description = event.description
                something_changed = True
            rec_urls = rec.urls.all()
            event_urls = event.urls.all()
            for i in range( max( len(rec_urls), len(event_urls) ) ):
                if i < len( rec_urls ) and i < len( event_urls ):
                    url_changed = False
                    if rec_urls[i].url_name != event_urls[i].url_name:
                        rec_urls[i].url_name = event_urls[i].url_name
                        url_changed = True
                    if rec_urls[i].url != event_urls[i].url:
                        rec_urls[i].url = event_urls[i].url
                        url_changed = True
                    if url_changed:
                        rec_urls[i].save()
                        something_changed = True
                elif i >= len( event_urls ):
                    rec_urls[i].delete()
                    something_changed = True
                else:
                    assert i >= len( rec_urls )
                    EventUrl.objects.create(
                            event    = rec,
                            url_name = event_urls[i].url_name,
                            url      = event_urls[i].url )
                    something_changed = True
            if something_changed:
                rec.version = rec.version + 1
                rec.save()
                reversion.add_meta( RevisionInfo,
                        as_text = smart_unicode( rec.as_text() ) )

# def event_new_raw( request, template_event_id = None ): {{{1 
開發者ID:wikical,項目名稱:grical,代碼行數:52,代碼來源:views.py


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