Commit 3040a6c4 authored by 王浩's avatar 王浩

fix code conflicts

parents a660591c ca13dc89
...@@ -10,27 +10,90 @@ from utils.logger import error_logger ...@@ -10,27 +10,90 @@ from utils.logger import error_logger
class TopicListView(APIView): class TopicListView(APIView):
def get(self, request): def get(self, request):
user_id = request.GET.get('user_id', '')
pictorial_id = request.GET.get('pictorial_id', '') pictorial_id = request.GET.get('pictorial_id', '')
offset = int(request.GET.get('page', 0)) user_id = request.GET.get('user_id', '')
page = int(request.GET.get('page', 1))
limit = int(request.GET.get('limit', 10)) limit = int(request.GET.get('limit', 10))
filter = self.handle_filter(request.GET.get('filter', "")) filters = json.loads(request.GET.get('filter', "{}"))
sort_params = request.GET.getlist('sort[]') sorts_by = list(map(lambda i: int(i), request.GET.getlist('sort_params[]', [3])))
if user_id: if user_id:
filter.update({'user_id': user_id}) filters.update({'user_id': user_id})
if pictorial_id: if pictorial_id:
filter.update({'pictorial_id': pictorial_id}) filters.update({"pictorial_id": int(pictorial_id)})
res = self.rpc['physical/search/business/topic'](
offset=(page-1) * limit,
size=limit,
filters=filters,
sorts_by=sorts_by
).unwrap()
topic_ids = res.get("topic_ids", [])
total_count = res.get("total_count", 0)
try: try:
data = self.rpc['venus/sun/topic/list']( data = self.rpc['venus/sun/topic/list'](
offset=(offset - 1) * limit, topic_ids=topic_ids
limit=limit,
filters=filter,
sort_params=sort_params
).unwrap() ).unwrap()
except Exception as e: except Exception as e:
error_logger.error(u'获取帖子列表失败%s', e) error_logger.error(u'获取帖子列表失败%s', e)
raise raise
return data
result = {
"data": data.get("data", []),
"total": total_count,
}
return result
class TopicImageListView(APIView):
def get(self, request):
pictorial_id = request.GET.get('pictorial_id', '')
page = int(request.GET.get('page', 1))
limit = int(request.GET.get('limit', 50))
filters = json.loads(request.GET.get('filter', "{}"))
sorts_by = list(map(lambda i: int(i), request.GET.getlist('sort_params[]', [3])))
filters.update({"has_image": True})
if pictorial_id:
filters.update({"pictorial_id": int(pictorial_id)})
res = self.rpc['physical/search/business/topic'](
offset=(page-1) * limit,
size=limit,
filters=filters,
sorts_by=sorts_by
).unwrap()
topic_ids = res.get("topic_ids", [])
total_count = res.get("total_count", 0)
try:
data = self.rpc['venus/community/topic/images_info_dict'](
topic_ids=topic_ids
).unwrap()
except Exception as e:
error_logger.error(u'获取帖子列表失败%s', e)
raise
result = []
for topic_id in topic_ids:
imgs_info = data.get(str(topic_id), [])
if not imgs_info:
continue
result.append({
"id": topic_id,
"img_url": imgs_info[0].get("url", "") + '-w'
})
result = {
"data": result,
"total": total_count,
}
return result
class TopicUpdateOrCreateView(APIView): class TopicUpdateOrCreateView(APIView):
......
...@@ -45,6 +45,7 @@ urlpatterns = [ ...@@ -45,6 +45,7 @@ urlpatterns = [
# topic相关 # topic相关
url(r'^topic/list$', TopicListView.as_view()), url(r'^topic/list$', TopicListView.as_view()),
url(r'^topic/img/list$', TopicImageListView.as_view()),
url(r'^topic/detail$', TopicUpdateOrCreateView.as_view()), url(r'^topic/detail$', TopicUpdateOrCreateView.as_view()),
url(r'^topic/create$', TopicUpdateOrCreateView.as_view()), url(r'^topic/create$', TopicUpdateOrCreateView.as_view()),
url(r'^topic/batch_update$', TopicListBatchUpdate.as_view()), url(r'^topic/batch_update$', TopicListBatchUpdate.as_view()),
......
...@@ -159,8 +159,8 @@ OPERATOR_PASSWORD = 123456 ...@@ -159,8 +159,8 @@ OPERATOR_PASSWORD = 123456
DOWNLOAD_IMAGE_PATH = u'/data/header-images/' DOWNLOAD_IMAGE_PATH = u'/data/header-images/'
# apk 七牛上传空间 # apk 七牛上传空间
APK_SCOPE = 'download' APK_SCOPE = 'alpha-s'
APK_DOMAIN = 'http://dl.igengmei.com/' APK_DOMAIN = 'http://alpha-s.iyanzhi.com/'
DEFAULT_CHANNEL = 'benzhan' DEFAULT_CHANNEL = 'benzhan'
APK_RELEASE_DIR = 'test' APK_RELEASE_DIR = 'test'
APK_BUILD_DIR = 'testbuild' APK_BUILD_DIR = 'testbuild'
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment