| @@ -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) |