本文整理匯總了Python中website.models.DraftRegistration.find方法的典型用法代碼示例。如果您正苦於以下問題:Python DraftRegistration.find方法的具體用法?Python DraftRegistration.find怎麽用?Python DraftRegistration.find使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類website.models.DraftRegistration
的用法示例。
在下文中一共展示了DraftRegistration.find方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_delete_draft_registration
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def test_delete_draft_registration(self):
assert_equal(1, DraftRegistration.find().count())
url = self.node.api_url_for('delete_draft_registration', draft_id=self.draft._id)
res = self.app.delete(url, auth=self.user.auth)
assert_equal(res.status_code, http.NO_CONTENT)
assert_equal(0, DraftRegistration.find().count())
示例2: test_delete_draft_registration_non_admin
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def test_delete_draft_registration_non_admin(self):
assert_equal(1, DraftRegistration.find().count())
url = self.node.api_url_for('delete_draft_registration', draft_id=self.draft._id)
res = self.app.delete(url, auth=self.non_admin.auth, expect_errors=True)
assert_equal(res.status_code, http.FORBIDDEN)
assert_equal(1, DraftRegistration.find().count())
示例3: test_delete_draft_registration_approved_and_registration_deleted
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def test_delete_draft_registration_approved_and_registration_deleted(self, mock_register_draft):
self.draft.register(auth=self.auth, save=True)
self.draft.registered_node.is_deleted = True
self.draft.registered_node.save()
assert_equal(1, DraftRegistration.find().count())
url = self.node.api_url_for('delete_draft_registration', draft_id=self.draft._id)
res = self.app.delete(url, auth=self.user.auth)
assert_equal(res.status_code, http.NO_CONTENT)
assert_equal(0, DraftRegistration.find().count())
示例4: migrate_drafts
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def migrate_drafts(dry):
PREREG_CHALLENGE_METASCHEMA = get_prereg_schema()
draft_registrations = DraftRegistration.find(
Q('registration_schema', 'eq', PREREG_CHALLENGE_METASCHEMA)
)
count = 0
for r in draft_registrations:
# NOTE: We don't query Q('approval', 'eq', None) just in case
# approval is set but the fk doesn't exist in the database
if r.approval or r.registered_node:
continue
logger.debug('Reading draft with id: {0}'.format(r._id))
data = r.registration_metadata
migrated = False
for q, ans in data.iteritems():
if isinstance(ans.get('value'), dict):
for value in ans['value'].values():
migrated = migrate_file_meta(value)
else:
migrated = migrate_file_meta(ans)
if migrated:
count += 1
logger.info('Migrated draft with id: {0}'.format(r._id))
if not dry:
r.save()
logger.info('Done with {0} drafts migrated.'.format(count))
示例5: main
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def main(dry_run=False, test=False):
with TokuTransaction():
prereg_drafts = DraftRegistration.find(
Q('registration_schema', 'eq', PREREG_SCHEMA)
)
for draft in prereg_drafts:
migrate_draft_metadata(draft, test)
if dry_run:
raise RuntimeError("Dry run, rolling back transaction")
示例6: migrate_drafts_metadata_key
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def migrate_drafts_metadata_key(schema):
"""
Finds Veer draft registrations whose registration_metadata has an undefined key and corrects.
"""
drafts = DraftRegistration.find(Q('registration_schema', 'eq', schema))
total_drafts = drafts.count()
logger.info('Examining {} drafts for improper key'.format(total_drafts))
draft_count = 0
for draft in drafts:
draft_count += 1
if draft.registration_metadata.get('recommended-methods', {}).get('value', {}).get('undefined', {}):
draft.registration_metadata['recommended-methods']['value']['procedure'] = draft.registration_metadata['recommended-methods']['value'].pop('undefined')
draft.save()
logger.info('{}/{} Migrated key for {}'.format(draft_count, total_drafts, draft._id))
else:
logger.info('{}/{} Key already correct for {}. No change.'.format(draft_count, drafts.count(), draft._id))
示例7: migrate_drafts_q5_metadata
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def migrate_drafts_q5_metadata(schema):
"""
Finds Prereg Challenge draft registrations and corrects q5 response metadata
"""
drafts = DraftRegistration.find(Q('registration_schema', 'eq', schema))
total_drafts = drafts.count()
logger.info('Examining {} drafts for q5 metadata'.format(total_drafts))
draft_count = 0
for draft in drafts:
draft_count += 1
if draft.registration_metadata.get('q5', {}).get('value', {}):
draft.registration_metadata['q5']['value'] = draft.registration_metadata['q5']['value'].rstrip()
draft.save()
logger.info('{}/{} Migrated q5 response for {}'.format(draft_count, total_drafts, draft._id))
else:
logger.info('{}/{} q5 not answered. No change needed for {}.'.format(draft_count, drafts.count(), draft._id))
示例8: migrate
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def migrate(dry=True):
registrations = Node.find(
Q('is_registration', 'eq', True) &
Q('registered_meta', 'ne', None)
)
regs_migrated, reg_errored = migrate_extras(registrations, dry=dry)
drafts = DraftRegistration.find(Q('registration_metadata', 'ne', {}))
drafts_migrated, drafts_errored = migrate_extras(drafts, dry=dry)
logger.info('Migrated registered_meta for {} registrations'.format(len(regs_migrated)))
if reg_errored:
logger.error('{} errored: {}'.format(len(reg_errored), reg_errored))
logger.info('Migrated registered_meta for {} draft registrations'.format(len(drafts_migrated)))
if drafts_errored:
logger.error('{} errored: {}'.format(len(drafts_errored), drafts_errored))
示例9: main
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def main(dry_run=True):
if dry_run:
logger.warn('DRY RUN mode')
pending_approval_drafts = DraftRegistration.find()
need_approval_drafts = [draft for draft in pending_approval_drafts
if draft.requires_approval and draft.approval and draft.approval.state == Sanction.UNAPPROVED]
for draft in need_approval_drafts:
sanction = draft.approval
try:
if not dry_run:
sanction.state = Sanction.APPROVED
sanction._on_complete(None)
sanction.save()
logger.warn('Approved {0}'.format(draft._id))
except Exception as e:
logger.error(e)
示例10: main
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def main(dry_run=False, test=False):
init_app(set_backends=True, routes=False)
prereg_schema = get_prereg_schema()
count = 0
with TokuTransaction():
prereg_drafts = DraftRegistration.find(
Q('registration_schema', 'eq', prereg_schema)
)
for draft in prereg_drafts:
# only migrate unapproved drafts
if draft.is_approved:
continue
changed = migrate_draft_metadata(draft, test)
if changed:
count += 1
logger.info('Migrated {} drafts'.format(count))
if dry_run:
raise RuntimeError('Dry run, rolling back transaction')
示例11: main
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def main(dry_run=True):
if dry_run:
logger.warn('DRY RUN mode')
pending_approval_drafts = DraftRegistration.find()
need_approval_drafts = [draft for draft in pending_approval_drafts
if draft.requires_approval and draft.approval and draft.approval.state == Sanction.UNAPPROVED]
for draft in need_approval_drafts:
add_comments(draft)
sanction = draft.approval
try:
if not dry_run:
sanction.forcibly_reject()
#manually do the on_reject functionality to prevent send_mail problems
sanction.meta = {}
sanction.save()
draft.approval = None
draft.save()
logger.warn('Rejected {0}'.format(draft._id))
except Exception as e:
logger.error(e)
示例12: migrate_drafts
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def migrate_drafts():
PREREG_CHALLENGE_METASCHEMA = get_prereg_schema()
draft_registrations = DraftRegistration.find(
Q('registration_schema', 'eq', PREREG_CHALLENGE_METASCHEMA)
)
count = 0
for draft in draft_registrations:
migrated = False
logger.debug('Reading preregistration draft with id: {0}'.format(draft._id))
for answer in draft.registration_metadata.values():
if isinstance(answer.get('value'), dict):
for value in answer['value'].values():
migrated_one = migrate_file_meta(value)
if migrated_one and not migrated:
migrated = True
else:
migrated_one = migrate_file_meta(answer)
if migrated_one and not migrated:
migrated = True
if migrated:
draft.save()
count += 1
logger.info('Migrated preregistration draft {0}'.format(draft._id))
logger.info('Done with {0} prereg drafts migrated.'.format(count))
示例13: migrate_drafts
# 需要導入模塊: from website.models import DraftRegistration [as 別名]
# 或者: from website.models.DraftRegistration import find [as 別名]
def migrate_drafts(dry):
PREREG_CHALLENGE_METASCHEMA = get_prereg_schema()
draft_registrations = DraftRegistration.find(
Q('registration_schema', 'eq', PREREG_CHALLENGE_METASCHEMA) &
Q('approval', 'eq', None) &
Q('registered_node', 'eq', None)
)
count = 0
for r in draft_registrations:
data = r.registration_metadata
migrated = False
for q, ans in data.iteritems():
if isinstance(ans.get('value'), dict):
for value in ans['value'].values():
migrated = migrate_file_meta(value)
else:
migrated = migrate_file_meta(ans)
if migrated:
count += 1
logger.info('Migrated draft with id: {0}'.format(r._id))
if not dry:
r.save()
logger.info('Done with {0} drafts migrated.'.format(count))