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


Python deferred.defer方法代碼示例

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


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

示例1: _run_function_as_task

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def _run_function_as_task(all_functions_list, function_name, kwargs=None):
  """Runs a specific function and its kwargs as an AppEngine task.

  Args:
    all_functions_list: string list, A list with all function names that are
        registered as bootstrap functions on the Loaner app.
    function_name: string, A specific function that should be ran as a task.
    kwargs: dict, Optional kwargs to be passed to the function that will run.

  Returns:
    The deferred task from AppEngine taskqueue.

  Raises:
    Error: if requested bootstrap method is not allowed or does not exist.
  """
  logging.debug('Running %s as a task.', function_name)
  function = all_functions_list.get(function_name)
  if function is None:
    raise Error(
        'Requested bootstrap method {} does not exist.'.format(function_name))
  if not kwargs:
    kwargs = {}
  kwargs['user_email'] = user.get_user_email()
  return deferred.defer(function, **kwargs) 
開發者ID:google,項目名稱:loaner,代碼行數:26,代碼來源:bootstrap.py

示例2: send_mail_notification

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def send_mail_notification(subject, body, to=None, **kwargs):
  if not config.CONFIG_DB.feedback_email:
    return
  brand_name = config.CONFIG_DB.brand_name
  sender = '%s <%s>' % (brand_name, config.CONFIG_DB.feedback_email)
  subject = '[%s] %s' % (brand_name, subject)
  if config.DEVELOPMENT:
    logging.info(
      '\n'
      '######### Deferring sending this email: #############################'
      '\nFrom: %s\nTo: %s\nSubject: %s\n\n%s\n'
      '#####################################################################',
      sender, to or sender, subject, body
    )
  deferred.defer(mail.send_mail, sender, to or sender, subject, body, **kwargs)


###############################################################################
# Admin Notifications
############################################################################### 
開發者ID:lipis,項目名稱:github-stats,代碼行數:22,代碼來源:task.py

示例3: repo_cleanup

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def repo_cleanup(days, cursor=None):
  before_date = datetime.utcnow() - timedelta(days=days)
  repo_qry = model.Repo.query().filter(model.Repo.modified < before_date)
  repo_keys, repo_cursors = util.get_dbs(
      repo_qry,
      order='modified',
      keys_only=True,
      cursor=cursor,
    )

  ndb.delete_multi(repo_keys)
  if repo_cursors['next']:
    deferred.defer(repo_cleanup, days, repo_cursors['next'])


###############################################################################
# Account Clean-ups
############################################################################### 
開發者ID:lipis,項目名稱:github-stats,代碼行數:20,代碼來源:task.py

示例4: MakeCommandHandler

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def MakeCommandHandler(cmd_cls):
  """Takes a command class and returns a route tuple which allows that command
     to be executed.
  """
  class H(webapp2.RequestHandler):
    def get(self):
      self.response.write("""
      <h1>You are about to run command "{}". Are you sure?</h1>
      <form action="" method="POST">
      <button>Punch it</button>
      </form>""".format(self._get_cmd().NAME))

    def post(self):
      deferred.defer(self._get_cmd().run)
      self.response.write('Command started.')

    def _get_cmd(self):
      if 'cmds' not in self.app.registry:
        self.app.registry['cmds'] = {}
      if cmd_cls.SHORT_NAME not in self.app.registry['cmds']:
        self.app.registry['cmds'][cmd_cls.SHORT_NAME] = cmd_cls(self.app.config)
      return self.app.registry['cmds'][cmd_cls.SHORT_NAME]

  return ('/admin/command/' + cmd_cls.SHORT_NAME, H) 
開發者ID:MayOneUS,項目名稱:pledgeservice,代碼行數:26,代碼來源:admin.py

示例5: _perform_backup_complete

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def _perform_backup_complete(
    operation, job_id, kind, backup_info_pk, gcs_path_prefix, filenames, queue):
  backup_info = BackupInformation.get(backup_info_pk)
  if backup_info:
    if job_id in backup_info.active_jobs:
      backup_info.active_jobs.remove(job_id)
      backup_info.completed_jobs = list(
          set(backup_info.completed_jobs + [job_id]))


    filenames = [GCSUtil.add_gs_prefix_if_missing(name) for name in filenames]
    kind_backup_files = backup_info.get_kind_backup_files([kind])[0]
    if kind_backup_files:
      kind_backup_files.files = list(set(kind_backup_files.files + filenames))
    else:
      kind_backup_files = backup_info.create_kind_backup_files(kind, filenames)
    db.put((backup_info, kind_backup_files), force_writes=True)
    if operation.status == utils.DatastoreAdminOperation.STATUS_COMPLETED:
      deferred.defer(finalize_backup_info, backup_info.key(),
                     gcs_path_prefix,
                     _url=config.DEFERRED_PATH,
                     _queue=queue,
                     _transactional=True)
  else:
    logging.warn('BackupInfo was not found for %s', backup_info_pk) 
開發者ID:GoogleCloudPlatform,項目名稱:python-compat-runtime,代碼行數:27,代碼來源:backup_handler.py

示例6: Dispatch

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def Dispatch():
  """Dispatches per-host tasks onto the event processing queue."""
  total_dispatch_count = 0
  logging.info('Starting a new dispatch task')

  # Query for all distinct host_id values among the _UnsyncedEvents, in batches,
  # either until we run out, or the task nears its deadline.
  query = _UnsyncedEvent.query(
      projection=[_UnsyncedEvent.host_id], distinct=True)
  for event_page in datastore_utils.Paginate(query, page_size=25):
    host_ids = [event.host_id for event in event_page]
    for host_id in host_ids:
      deferred.defer(Process, host_id, _queue=constants.TASK_QUEUE.BIT9_PROCESS)
      total_dispatch_count += 1

  logging.info('Dispatched %d task(s)', total_dispatch_count) 
開發者ID:google,項目名稱:upvote,代碼行數:18,代碼來源:bit9_syncing.py

示例7: get

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def get(self):

    now = datetime.datetime.utcnow()

    # Notify all users whose Exemptions now have less than a week left, in order
    # to give reasonable advance warning (e.g. long weekends, holidays, etc).
    one_week_start_dt = now + datetime.timedelta(days=7, hours=-1)
    one_week_end_dt = now + datetime.timedelta(days=7)

    # Notify all users whose Exemptions now have less that 24 hours left. This
    # will act as a final reminder, and will also ensure that even users who
    # choose a 1-day Exemption will get an email warning (for what it's worth).
    one_day_start_dt = now + datetime.timedelta(days=1, hours=-1)
    one_day_end_dt = now + datetime.timedelta(days=1)

    tuples = [
        (one_week_start_dt, one_week_end_dt),
        (one_day_start_dt, one_day_end_dt)]

    # Defer a task for each batch of notifications.
    for start_dt, end_dt in tuples:
      deferred.defer(
          _NotifyExpirationsInRange, start_dt, end_dt,
          _queue=constants.TASK_QUEUE.EXEMPTIONS) 
開發者ID:google,項目名稱:upvote,代碼行數:26,代碼來源:exemption_upkeep.py

示例8: cron

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def cron():
  stories = topstories()
  chunks = chunkify(stories, 20)
  for chunk in chunks:
    deferred.defer(task, chunk)
  return 'OK' 
開發者ID:phil-r,項目名稱:hackernewsbot,代碼行數:8,代碼來源:main.py

示例9: clear

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def clear(self, request):
    """Clears a search index for the given type."""
    if request.model == search_messages.SearchIndexEnum.DEVICE:
      deferred.defer(device_model.Device.clear_index)
    elif request.model == search_messages.SearchIndexEnum.SHELF:
      deferred.defer(shelf_model.Shelf.clear_index)
    return message_types.VoidMessage() 
開發者ID:google,項目名稱:loaner,代碼行數:9,代碼來源:search_api.py

示例10: reindex

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def reindex(self, request):
    """Reindexes a search index for the given type."""
    if request.model == search_messages.SearchIndexEnum.DEVICE:
      deferred.defer(device_model.Device.index_entities_for_search)
    elif request.model == search_messages.SearchIndexEnum.SHELF:
      deferred.defer(shelf_model.Shelf.index_entities_for_search)
    return message_types.VoidMessage() 
開發者ID:google,項目名稱:loaner,代碼行數:9,代碼來源:search_api.py

示例11: enable_guest_mode

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def enable_guest_mode(self, user_email):
    """Moves a device into guest mode if allowed.

    Args:
      user_email: str, The email of the acting user.

    Raises:
      GuestNotAllowedError: when the allow_guest_mode config is not True.
      EnableGuestError: if there is an RPC error in the Directory API, or the
          allow_guest_mode setting is not True.
      UnassignedDeviceError: if the device is not assigned, guest mode should
          not be allowed.
    """
    if not self.is_assigned:
      raise UnassignedDeviceError(_UNASSIGNED_DEVICE % self.identifier)
    if config_model.Config.get('allow_guest_mode'):
      directory_client = directory.DirectoryApiClient(user_email)
      guest_ou = constants.ORG_UNIT_DICT['GUEST']

      try:
        directory_client.move_chrome_device_org_unit(
            device_id=self.chrome_device_id,
            org_unit_path=guest_ou)
      except directory.DirectoryRPCError as err:
        raise EnableGuestError(str(err))
      else:
        self.current_ou = guest_ou
        self.ou_changed_date = datetime.datetime.utcnow()
        self.stream_to_bq(
            user_email, 'Moving device %s into Guest Mode.' % self.identifier)
        self.put()
        if config_model.Config.get('timeout_guest_mode'):
          countdown = datetime.timedelta(
              hours=config_model.Config.get(
                  'guest_mode_timeout_in_hours')).total_seconds()
          deferred.defer(
              self._disable_guest_mode, user_email, _countdown=countdown)
    else:
      raise GuestNotAllowedError(_GUEST_MODE_DISABLED_MSG) 
開發者ID:google,項目名稱:loaner,代碼行數:41,代碼來源:device_model.py

示例12: _pre_delete_hook

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def _pre_delete_hook(cls, key):
    """Cleans up any entities that reference the key.

    Note that this operation can have a long tail in that it requires a bulk tag
    disassociation across potentially many entities in Datastore.

    Args:
      key: ndb.Key, a Tag model key.
    """
    logging.info(
        'Destroying the tag with urlsafe key %r and name %r.',
        key.urlsafe(), key.get().name)
    for model in _MODELS_WITH_TAGS:
      deferred.defer(_delete_tags, model, key.get()) 
開發者ID:google,項目名稱:loaner,代碼行數:16,代碼來源:tag_model.py

示例13: _delete_tags

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def _delete_tags(model, tag, cursor=None, num_updated=0, batch_size=100):
  """Cleans up any entities on the given model that reference the given key.

  Args:
    model: ndb.Model, a Model with a repeated TagData property.
    tag: Tag, an instance of a Tag model.
    cursor: Optional[datastore_query.Cursor], pointing to the last result.
    num_updated: int, the number of entities that were just updated.
    batch_size: int, the number of entities to include in the batch.
  """
  entities, next_cursor, more = model.query(
      model.tags.tag == tag).fetch_page(batch_size, start_cursor=cursor)

  for entity in entities:
    entity.tags = [
        model_tag for model_tag in entity.tags if model_tag.tag != tag
    ]
  ndb.put_multi(entities)

  num_updated += len(entities)
  logging.info(
      'Destroyed %d occurrence(s) of the tag with URL safe key %r',
      len(entities), tag.key.urlsafe())
  if more:
    deferred.defer(
        _delete_tags, model, tag,
        cursor=next_cursor, num_updated=num_updated, batch_size=batch_size)
  else:
    logging.info(
        'Destroyed a total of %d occurrence(s) of the tag with URL safe key %r',
        num_updated, tag.key.urlsafe()) 
開發者ID:google,項目名稱:loaner,代碼行數:33,代碼來源:tag_model.py

示例14: get_test_set_from_results_str

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def get_test_set_from_results_str(category, results_str):
    """Creates a runtime version of a browserscope TestSet by parsing strings.
    Args:
      category: A string that looks like 'usertest_sad7dsa987sa9dsa7dsa9'.
      results_str: A string that looks like 'test_1=0,test_2=1'.

    Returns:
      A models.user_test.TestSet instance.

    Raises:
      KeyTooLong: When any of the key names is longer than MAX_KEY_LENGTH.
    """
    category_prefix = '%s_' % Test.get_prefix()
    if category_prefix not in category:
      return None
    key = category.replace(category_prefix, '')
    test = Test.get_mem(key)
    if not test:
      return None

    test_scores = [x.split('=') for x in str(results_str).split(',')]
    test_keys = sorted([x[0] for x in test_scores])
    ValidateTestKeys(test_keys)

    # If it's test run #1, save what we've got for test keys and swap
    # memcache.
    if not test.test_keys:
      test.test_keys = test_keys
      test.save_memcache()
    else:
      deferred.defer(update_test_keys, key, test_keys)

    # Regardless we'll defer updating the TestMeta reference.
    deferred.defer(update_test_meta, key, test_scores)

    test_set = test.get_test_set_from_test_keys(test_keys)
    return test_set 
開發者ID:elsigh,項目名稱:browserscope,代碼行數:39,代碼來源:user_test.py

示例15: queue_account

# 需要導入模塊: from google.appengine.ext import deferred [as 別名]
# 或者: from google.appengine.ext.deferred import defer [as 別名]
def queue_account(account_db):
  import logging
  if account_db.status in ['404']:
    return

  max_repos = 3000
  queue_it = False
  delta = datetime.utcnow() - account_db.synced

  if account_db.status in ['new', 'error']:
    account_db.status = 'syncing'
    account_db.synced = datetime.utcnow()
    account_db.put()
    queue_it = True

  elif delta.days > 0 and account_db.status == 'failed' and account_db.public_repos < max_repos:
    account_db.status = 'syncing'
    account_db.synced = datetime.utcnow()
    account_db.put()
    queue_it = True

  elif account_db.status == 'syncing':
    if delta.seconds > 60 * 60 or account_db.public_repos > max_repos:
      account_db.status = 'failed'
      account_db.synced = datetime.utcnow()
      account_db.put()
    elif delta.seconds > 30 * 60:
      queue_it = True

  # older than 4 hours long sunc them
  if (delta.days > 0 or delta.seconds > 60 * 60 * 4) and account_db.status != 'failed':
    account_db.status = 'syncing'
    account_db.synced = datetime.utcnow()
    account_db.put()
    queue_it = True

  if queue_it:
    deferred.defer(sync_account, account_db) 
開發者ID:lipis,項目名稱:github-stats,代碼行數:40,代碼來源:task.py


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