@@ -38,6 +38,7 @@ def update_branch_campus_admin(request): |
||
| 38 | 38 |
target_admin_id = request.POST.get('target_admin_id', '')
|
| 39 | 39 |
name = request.POST.get('name', '')
|
| 40 | 40 |
phone = request.POST.get('phone', '')
|
| 41 |
+ admin_type = int(request.POST.get('admin_type', 1))
|
|
| 41 | 42 |
user_status = request.POST.get('user_status', 0)
|
| 42 | 43 |
|
| 43 | 44 |
password = phone[-6:] |
@@ -46,6 +47,7 @@ def update_branch_campus_admin(request): |
||
| 46 | 47 |
BranchCampusAdministratorInfo.objects.filter( |
| 47 | 48 |
admin_id=target_admin_id, |
| 48 | 49 |
).update( |
| 50 |
+ admin_type=admin_type, |
|
| 49 | 51 |
name=name, |
| 50 | 52 |
phone=phone, |
| 51 | 53 |
password=password, |
@@ -50,7 +50,13 @@ def get_branch_campus_list(request): |
||
| 50 | 50 |
def delete_branch_campus(request): |
| 51 | 51 |
campus_id = request.POST.get('campus_id', '')
|
| 52 | 52 |
|
| 53 |
- if campus_id == "htmRPpdE3PjB4V35uAesxu": |
|
| 53 |
+ try: |
|
| 54 |
+ campus = BranchCampusInfo.objects.get(id=campus_id) |
|
| 55 |
+ except: |
|
| 56 |
+ return response() |
|
| 57 |
+ |
|
| 58 |
+ |
|
| 59 |
+ if campus.campus_type == BranchCampusInfo.MAIN: |
|
| 54 | 60 |
return response(40001, '', '总院不可删除') |
| 55 | 61 |
|
| 56 | 62 |
BranchCampusInfo.objects.filter(campus_id=campus_id).update(status=False) |
@@ -105,6 +105,9 @@ def course_register_list(request): |
||
| 105 | 105 |
campus = BranchCampusInfo.objects.get(campus_id=admin.campus_id) |
| 106 | 106 |
if campus.campus_type == BranchCampusInfo.BRANCH: |
| 107 | 107 |
registers = UserCourseRegisterInfo.objects.filter(campus_id=admin.campus_id) |
| 108 |
+ |
|
| 109 |
+ if campus.campus_type == BranchCampusInfo.BRANCH and admin.admin_type == BranchCampusAdministratorInfo.CHANNEL_ADMIN: |
|
| 110 |
+ registers = UserCourseRegisterInfo.objects.filter(admin_id=admin.admin_id) |
|
| 108 | 111 |
|
| 109 | 112 |
if course_id: |
| 110 | 113 |
registers = UserCourseRegisterInfo.objects.filter(course_id=course_id) |
@@ -6,7 +6,7 @@ from django_query import get_query_value |
||
| 6 | 6 |
from django_response import response |
| 7 | 7 |
from paginator import pagination |
| 8 | 8 |
|
| 9 |
-from registration.models import BranchCampusAdministratorInfo, CourseInfo, CourseRegisterFieldInfo, CourseRegisterInfo |
|
| 9 |
+from registration.models import BranchCampusAdministratorInfo, CourseInfo, CourseRegisterFieldInfo, CourseRegisterInfo, BranchCampusInfo |
|
| 10 | 10 |
|
| 11 | 11 |
|
| 12 | 12 |
def add_course(request): |
@@ -79,9 +79,10 @@ def get_course_list(request): |
||
| 79 | 79 |
admin = BranchCampusAdministratorInfo.objects.get(admin_id=admin_id, user_status=BranchCampusAdministratorInfo.ACTIVATED) |
| 80 | 80 |
except BranchCampusAdministratorInfo.DoesNotExist: |
| 81 | 81 |
admin = None |
| 82 |
+ |
|
| 82 | 83 |
|
| 83 | 84 |
courses = CourseInfo.objects.filter(status=True) |
| 84 |
- if admin: |
|
| 85 |
+ if admin and admin.data.get('campus_type', BranchCampusInfo.BRANCH) == BranchCampusInfo.BRANCH:
|
|
| 85 | 86 |
courses = courses.filter(authorities__contains=admin.campus_id) |
| 86 | 87 |
count = courses.count() |
| 87 | 88 |
courses, left = pagination(courses, page, num) |
@@ -10,11 +10,11 @@ from registration.models import (BranchCampusAdministratorInfo, BranchCampusInfo |
||
| 10 | 10 |
|
| 11 | 11 |
|
| 12 | 12 |
class BranchCampusInfoAdmin(admin.ModelAdmin): |
| 13 |
- list_display = ('campus_id', 'campus_name', 'updated_at', 'created_at')
|
|
| 13 |
+ list_display = ('campus_id', 'campus_name', 'status', 'updated_at', 'created_at')
|
|
| 14 | 14 |
|
| 15 | 15 |
|
| 16 | 16 |
class BranchCampusAdministratorInfoAdmin(admin.ModelAdmin): |
| 17 |
- list_display = ('admin_id', 'campus_id', 'campus_name', 'name', 'phone', 'password', 'encryption', 'user_status', 'updated_at', 'created_at')
|
|
| 17 |
+ list_display = ('admin_id', 'campus_id', 'campus_name', 'admin_type', 'name', 'phone', 'password', 'encryption', 'user_status', 'updated_at', 'created_at')
|
|
| 18 | 18 |
|
| 19 | 19 |
def save_model(self, request, obj, form, change): |
| 20 | 20 |
password = obj.password or obj.phone[-6:] |
@@ -0,0 +1,18 @@ |
||
| 1 |
+# Generated by Django 2.2.15 on 2021-11-03 09:18 |
|
| 2 |
+ |
|
| 3 |
+from django.db import migrations, models |
|
| 4 |
+ |
|
| 5 |
+ |
|
| 6 |
+class Migration(migrations.Migration): |
|
| 7 |
+ |
|
| 8 |
+ dependencies = [ |
|
| 9 |
+ ('registration', '0011_usercourseregisterinfo_user_status'),
|
|
| 10 |
+ ] |
|
| 11 |
+ |
|
| 12 |
+ operations = [ |
|
| 13 |
+ migrations.AddField( |
|
| 14 |
+ model_name='branchcampusadministratorinfo', |
|
| 15 |
+ name='admin_type', |
|
| 16 |
+ field=models.IntegerField(choices=[(0, '超级管理员'), (1, '渠道管理员')], db_index=True, default=1, help_text='管理员类型', verbose_name='admin_type'), |
|
| 17 |
+ ), |
|
| 18 |
+ ] |
@@ -50,8 +50,17 @@ class BranchCampusAdministratorInfo(BaseModelMixin): |
||
| 50 | 50 |
(DELETED, '已删除'), |
| 51 | 51 |
) |
| 52 | 52 |
|
| 53 |
+ SUPER_ADMIN = 0 |
|
| 54 |
+ CHANNEL_ADMIN = 1 |
|
| 55 |
+ |
|
| 56 |
+ ADMIN_TYPE = ( |
|
| 57 |
+ (SUPER_ADMIN, '超级管理员'), |
|
| 58 |
+ (CHANNEL_ADMIN, '渠道管理员'), |
|
| 59 |
+ ) |
|
| 60 |
+ |
|
| 53 | 61 |
user_id = models.CharField(_('user_id'), max_length=32, blank=True, null=True, help_text='用户ID', db_index=True, unique=True)
|
| 54 | 62 |
admin_id = ShortUUIDField(_('admin_id'), max_length=32, blank=True, null=True, help_text='管理员唯一标识', db_index=True, unique=True)
|
| 63 |
+ admin_type = models.IntegerField(_('admin_type'), choices=ADMIN_TYPE, default=CHANNEL_ADMIN, help_text='管理员类型', db_index=True)
|
|
| 55 | 64 |
|
| 56 | 65 |
campus_id = models.CharField(_('campus_id'), max_length=32, blank=True, null=True, help_text='分院唯一标识', db_index=True)
|
| 57 | 66 |
campus_name = models.CharField(_('campus_name'), max_length=255, blank=True, null=True, help_text='分院名称')
|
@@ -77,6 +86,7 @@ class BranchCampusAdministratorInfo(BaseModelMixin): |
||
| 77 | 86 |
return {
|
| 78 | 87 |
'user_id': self.user_id, |
| 79 | 88 |
'admin_id': self.admin_id, |
| 89 |
+ 'admin_type': self.admin_type, |
|
| 80 | 90 |
'campus_id': self.campus_id, |
| 81 | 91 |
'campus_name': self.campus_name, |
| 82 | 92 |
'campus_type': admin.campus_type, |