@@ -0,0 +1,27 @@ |
||
| 1 |
+# -*- coding: utf-8 -*- |
|
| 2 |
+ |
|
| 3 |
+from django.conf import settings |
|
| 4 |
+from django_logit import logit |
|
| 5 |
+from django_response import response |
|
| 6 |
+ |
|
| 7 |
+from logs.models import MchSearchModelAndCameraLogInfo |
|
| 8 |
+ |
|
| 9 |
+@logit |
|
| 10 |
+def collect_camera_adaptive_log(request): |
|
| 11 |
+ brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
| 12 |
+ |
|
| 13 |
+ user_id = request.POST.get('user_id', '')
|
|
| 14 |
+ is_search_model = int(request.POST.get('is_search_model', 0))
|
|
| 15 |
+ is_search_camera = int(request.POST.get('is_search_camera', 0))
|
|
| 16 |
+ is_search_model_camera = int(request.POST.get('is_search_model_camera', 0))
|
|
| 17 |
+ is_search_camera_after_model = int(request.POST.get('is_search_camera_after_model', 0))
|
|
| 18 |
+ |
|
| 19 |
+ MchSearchModelAndCameraLogInfo.objects.create( |
|
| 20 |
+ user_id=user_id, |
|
| 21 |
+ is_search_model=is_search_model, |
|
| 22 |
+ is_search_camera=is_search_camera, |
|
| 23 |
+ is_search_model_camera=is_search_model_camera, |
|
| 24 |
+ is_search_camera_after_model=is_search_camera_after_model, |
|
| 25 |
+ ) |
|
| 26 |
+ |
|
| 27 |
+ return response(200, 'Collect Camera Adaptive Log Success', u'收集型号适配日志成功') |
@@ -6,7 +6,7 @@ from django_file_upload import views as file_views |
||
| 6 | 6 |
from account import tourguide_views |
| 7 | 7 |
from account import views as account_views |
| 8 | 8 |
from api import (admin_views, clerk_views, distributor_views, encrypt_views, mch_views, member_views, model_views, |
| 9 |
- operator_views, sr_views) |
|
| 9 |
+ operator_views, sr_views, log_views) |
|
| 10 | 10 |
from box import views as box_views |
| 11 | 11 |
from geo import views as geo_views |
| 12 | 12 |
from group import (groupuser_views, lensman_views, tourguidegroup_views, tourguidegroupadmin_views, |
@@ -340,3 +340,7 @@ urlpatterns += [ |
||
| 340 | 340 |
url(r'^good/detail$', member_views.good_detail, name='good_detail'), |
| 341 | 341 |
url(r'^integrals$', member_views.integrals, name='integrals'), |
| 342 | 342 |
] |
| 343 |
+ |
|
| 344 |
+urlpatterns += [ |
|
| 345 |
+ url(r'^log/camera/adaptive$', log_views.collect_camera_adaptive_log, name='log_camera_adaptive'), |
|
| 346 |
+] |
@@ -3,7 +3,7 @@ |
||
| 3 | 3 |
from django.contrib import admin |
| 4 | 4 |
from django_admin import ReadOnlyModelAdmin |
| 5 | 5 |
|
| 6 |
-from logs.models import MchInfoDecryptLogInfo, MchInfoEncryptLogInfo, MchLogInfo |
|
| 6 |
+from logs.models import MchInfoDecryptLogInfo, MchInfoEncryptLogInfo, MchLogInfo, MchSearchModelAndCameraLogInfo |
|
| 7 | 7 |
|
| 8 | 8 |
|
| 9 | 9 |
class MchInfoEncryptLogInfoAdmin(ReadOnlyModelAdmin, admin.ModelAdmin): |
@@ -21,7 +21,15 @@ class MchLogInfoAdmin(ReadOnlyModelAdmin, admin.ModelAdmin): |
||
| 21 | 21 |
list_filter = ('operator_id', 'app_version', 'status')
|
| 22 | 22 |
search_fields = ('operator_id', 'app_version')
|
| 23 | 23 |
|
| 24 |
+class MchLogInfoAdmin(ReadOnlyModelAdmin, admin.ModelAdmin): |
|
| 25 |
+ list_display = ('log_id', 'log_file', 'operator_id', 'app_version', 'status', 'created_at', 'updated_at')
|
|
| 26 |
+ list_filter = ('operator_id', 'app_version', 'status')
|
|
| 27 |
+ search_fields = ('operator_id', 'app_version')
|
|
| 28 |
+ |
|
| 29 |
+class MchSearchModelAndCameraLogInfoAdmin(admin.ModelAdmin): |
|
| 30 |
+ list_display = ('user_id', 'is_search_model', 'is_search_camera', 'is_search_model_camera', 'is_search_camera_after_model', 'created_at')
|
|
| 31 |
+ list_filter = ('is_search_model', 'is_search_camera', 'is_search_model_camera', 'is_search_camera_after_model')
|
|
| 24 | 32 |
|
| 25 | 33 |
admin.site.register(MchInfoDecryptLogInfo, MchInfoDecryptLogInfoAdmin) |
| 26 | 34 |
admin.site.register(MchInfoEncryptLogInfo, MchInfoEncryptLogInfoAdmin) |
| 27 |
-admin.site.register(MchLogInfo, MchLogInfoAdmin) |
|
| 35 |
+admin.site.register(MchSearchModelAndCameraLogInfo, MchSearchModelAndCameraLogInfoAdmin) |
@@ -71,3 +71,20 @@ class MchLogInfo(BaseModelMixin): |
||
| 71 | 71 |
|
| 72 | 72 |
def __unicode__(self): |
| 73 | 73 |
return unicode(self.pk) |
| 74 |
+ |
|
| 75 |
+class MchSearchModelAndCameraLogInfo(BaseModelMixin): |
|
| 76 |
+ user_id = models.CharField(_(u'user_id'), max_length=32, blank=True, null=True, help_text=u'用户唯一标识', db_index=True) |
|
| 77 |
+ |
|
| 78 |
+ log_id = ShortUUIDField(_(u'log_id'), max_length=32, help_text=u'日志唯一标识', db_index=True) |
|
| 79 |
+ |
|
| 80 |
+ is_search_model = models.IntegerField(_(u'is_search_model'), default=0, help_text=u'搜索镜头型号', db_index=True) |
|
| 81 |
+ is_search_camera = models.IntegerField(_(u'is_search_model'), default=0, help_text=u'搜索相机型号', db_index=True) |
|
| 82 |
+ is_search_model_camera = models.IntegerField(_(u'is_search_model'), default=0, help_text=u'搜索相机型号和镜头型号', db_index=True) |
|
| 83 |
+ is_search_camera_after_model = models.IntegerField(_(u'is_search_camera_after_model'), default=0, help_text=u'选择镜头后搜索相机型号', db_index=True) |
|
| 84 |
+ |
|
| 85 |
+ class Meta: |
|
| 86 |
+ verbose_name = _(u'mchsearchmodelandcameraloginfo') |
|
| 87 |
+ verbose_name_plural = _(u'mchsearchmodelandcameraloginfo') |
|
| 88 |
+ |
|
| 89 |
+ def __unicode__(self): |
|
| 90 |
+ return unicode(self.pk) |