本文整理匯總了Python中katapult.requests.RequestHelper.error方法的典型用法代碼示例。如果您正苦於以下問題:Python RequestHelper.error方法的具體用法?Python RequestHelper.error怎麽用?Python RequestHelper.error使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類katapult.requests.RequestHelper
的用法示例。
在下文中一共展示了RequestHelper.error方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: get
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def get(self, name, **kw):
helper = RequestHelper(self)
source = ArtifactSourceAccessor.get_by_name(name, return_none=True)
if not source:
helper.error(404)
return
helper.write_json(source_hash(source))
示例2: get
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def get(self, **kw):
helper = RequestHelper(self)
q = self.request.get("q", None)
output = self.request.get("o", None)
max_results = int(self.request.get("max", -1))
if not q:
helper.error(400, "q not provided.")
return
q_results = ArtifactContent.all().search(q)
json_results = None
if output == "short":
json_results = {}
json_results["count"] = q_results.count()
elif output == "id":
json_results = {}
count = q_results.count()
if max_results > 0 and max_results < q_results.count():
count = max_results
json_results["count"] = count
ids = []
json_results["ids"] = ids
results = q_results.fetch(1000) if max_results == -1 else q_results.fetch(max_results)
for c in results:
ids.append(c.guid)
else:
json_results = []
if q_results.count():
for content in q_results.fetch(10):
info = ArtifactInfo.get_by_guid(content.guid)
json_results.append(ArtifactsHelper.artifact_to_hash(info, content))
helper.write_json(json_results)
示例3: delete
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def delete(self, **kw):
helper = RequestHelper(self)
q = self.request.get("q", None)
if not q:
helper.error(400, "q not provided.")
return
results = {}
deleted_guids = []
results["deleted"] = deleted_guids
errors = 0
q_results = ArtifactContent.all().search(q)
infos = []
batch_size = 50
q_count = q_results.count()
batches = (q_count / batch_size) + 1
count = 0
for i in range(0, batches):
for c in q_results.fetch(batch_size, i * batch_size):
try:
logging.debug("deleting guid:%s" % c.guid)
c.delete()
count += 1
deleted_guids.append(c.guid)
if c.info is not None:
c.info.delete()
except Exception, ex:
logging.error(ex)
errors += 1
示例4: put
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def put(self, source_name):
helper = RequestHelper(self)
source_name = urllib.unquote(source_name)
success, values = read_json_fields(helper, "url", "active", logger=logging)
if not success:
return
url, active = values
# a Feed must be sole owner of an ArtifactSource;
# fails if source already exists and is already linked to a feed
source = ArtifactSourceAccessor.get_by_name(source_name, return_none=True)
if source:
source_feed_key = Feed.get_by_source(source, keys_only=True, return_none=True)
if source_feed_key:
msg = "source '%s' is referenced by feed %s" % (source_name, source_feed_key.name())
helper.error(409, msg)
else:
source = ArtifactSourceAccessor.create(source_name)
# creates UrlResource if necessary
resource = UrlResourceAccessor.get_by_url(url, return_none=True)
if not resource:
resource = UrlResourceAccessor.create(url)
# create or update Feed
feed = Feed.get_by_source_name(source_name, return_none=True)
if feed:
feed.artifact_source = source
feed.url_resource = resource
feed.put()
else:
Feed.create(source_name, artifact_source=source, url=url, url_resource=resource, active=bool(active))
helper.set_status(204)
示例5: delete
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def delete(self, name, **kw):
helper = RequestHelper(self)
try:
ArtifactSourceAccessor.delete_by_name(name)
helper.set_status(204)
except NotFoundException, ex:
helper.error(404)
return
示例6: args_call
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def args_call(*args, **kw):
handler = args[0]
helper = RequestHelper(handler)
if not Authenticator.is_authenticated(handler.request.path, handler.request.method, helper):
helper.header(error_header, error_message)
helper.error(403)
else:
f(*args, **kw)
示例7: get
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def get(self, source_name):
helper = RequestHelper(self)
source_name = urllib.unquote(source_name)
f = Feed.get_by_source_name(source_name, return_none=True)
if not f:
helper.error(404)
return
helper.write_json(build_feed_hash(f))
示例8: args_call
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def args_call(*args, **kw):
handler = args[0]
helper = RequestHelper(handler)
if not users.is_current_user_admin():
helper.header(error_header, error_msg)
helper.error(403)
else:
f(*args, **kw)
示例9: delete
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def delete(self, source_name):
helper = RequestHelper(self)
source_name = urllib.unquote(source_name)
feed = Feed.get_by_source_name(source_name, return_none=True)
if not feed:
helper.error(404)
return
feed.delete()
helper.set_status(204)
示例10: post
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def post(self):
helper = RequestHelper(self)
if not len(self.request.body):
helper.error(400, "body required")
return
decoded_body = urllib.unquote(self.request.body)
t_api = TwitterConnector.new_api()
status = t_api.PostUpdate(decoded_body)
helper.write_json(status.asDict())
示例11: put
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def put(self, key):
helper = RequestHelper(self)
if not self.request.body:
helper.error(400, "body required")
return
value = self.request.body
logging.info("%s=%s" % (key, value))
try:
ConfigurationAccessor.update(**{key: value})
except IllegalArgumentException, e:
helper.error(400, "invalid key")
return
示例12: args_call
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def args_call(*args, **kw):
handler = args[0]
helper = RequestHelper(handler)
auth_header = handler.request.headers.get(Headers.AUTHORIZATION, "")
code, headers, user = DigestAuth(realm, users).authenticate(handler.request.method,
handler.request.path,
auth_header)
if code >= 400 and code < 499:
for k, v in headers:
helper.header(k, v)
helper.error(code)
else:
kw['username'] = user
return f(*args, **kw)
示例13: ingest
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def ingest(cls, handler, source_name):
helper = RequestHelper(handler)
source_name = urllib.unquote(source_name)
keep = handler.request.get("keep")
if keep:
keep = int(keep)
else:
keep = 50
# TODO: get from cache
f = Feed.get_by_source_name(source_name, return_none=True)
if not f:
helper.error(404)
return
results = {}
entries = []
results['created'] = entries
# TODO: use etag from previous ingest
error_call = lambda entry, ex: logging.error(Exceptions.format_last())
user = users.get_current_user()
if not user:
# there is no logged in user for cron requests
user = User(Services.API_USER)
try:
for artifact_guid, entry, created in model.ingest_feed_entries(f, user, error_call=error_call):
entries.append({ "artifact-guid": artifact_guid,
"url": entry.link,
"title": entry.title,
"created": created })
finally:
# delete oldest feed entries
# TODO: shouldn't I be deleting ArtifactContent instances also?
def delete_info(c):
try:
i = c.info
if i:
i.delete()
except Exception, e:
pass
deleted_key_names = ArtifactContent.delete_oldest_by_source(f.artifact_source, keep, pre_call=delete_info)
results['deleted'] = deleted_key_names
Counters.source_counter(f.artifact_source.name).decrement(len(deleted_key_names))
示例14: get
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def get(self, **kw):
helper = RequestHelper(self)
message = self.request.get("q", None)
if not message:
helper.error(400, "q must be provided")
return
message = urllib.unquote(message)
try:
sources, response = Mixer(new_speaker()).mix_response(message)
logging.debug("sources:%s, response:%s" % (sources, response))
result = dict(response=response)
helper.write_json(result)
except DataException, ex:
helper.error(503, Exceptions.format(ex))
logging.error(ex)
示例15: put
# 需要導入模塊: from katapult.requests import RequestHelper [as 別名]
# 或者: from katapult.requests.RequestHelper import error [as 別名]
def put(cls, rhandler, guid, **kw):
helper = RequestHelper(rhandler)
artifact = ArtifactInfo.get_by_guid(guid)
if not artifact:
helper.error(404)
return
# removes existing properties
props = ArtifactInfo.properties().keys()
for prop in props:
delattr(artifact, prop)
# save artifact
ArtifactInfo.save(artifact)