Bot functionsa mainly operational
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
from django.contrib import admin
|
||||
from .models import User, UserConfirmation, UserActivityLog
|
||||
from .models import User, UserConfirmation, UserActivityLog, NotificationSettings
|
||||
|
||||
@admin.register(User)
|
||||
class UserAdmin(admin.ModelAdmin):
|
||||
@@ -20,4 +20,11 @@ class UserActivityLogAdmin(admin.ModelAdmin):
|
||||
search_fields = ('user_id', 'ip', 'datetime', 'agent', 'platform', 'version', 'model', 'device', 'UAString', 'location', 'page_id', 'url_parameters', 'page_title', 'type', 'last_counter', 'hits', 'honeypot', 'reply', 'page_url')
|
||||
list_filter = ('page_title', 'user_id', 'ip')
|
||||
ordering = ('-id',)
|
||||
|
||||
@admin.register(NotificationSettings)
|
||||
class NotificationSettingsAdmin(admin.ModelAdmin):
|
||||
list_display = ('user', 'email', 'telegram_enabled', 'email_enabled', 'notification_time')
|
||||
search_fields = ('user', 'email', 'telegram_enabled', 'email_enabled', 'notification_time')
|
||||
list_filter = ('user', 'email', 'telegram_enabled', 'email_enabled', 'notification_time')
|
||||
ordering = ('-id',)
|
||||
|
||||
29
users/migrations/0005_notificationsettings.py
Normal file
29
users/migrations/0005_notificationsettings.py
Normal file
@@ -0,0 +1,29 @@
|
||||
# Generated by Django 5.1.4 on 2024-12-06 12:01
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('users', '0004_alter_user_options_alter_userconfirmation_options_and_more'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='NotificationSettings',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('telegram_enabled', models.BooleanField(default=True, verbose_name='Уведомления в Telegram')),
|
||||
('email_enabled', models.BooleanField(default=False, verbose_name='Уведомления по Email')),
|
||||
('email', models.EmailField(blank=True, max_length=254, null=True, verbose_name='Email для уведомлений')),
|
||||
('notification_time', models.TimeField(default='09:00', verbose_name='Время отправки уведомлений')),
|
||||
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, to='users.user', verbose_name='Пользователь')),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'Способ оповещения',
|
||||
'verbose_name_plural': 'Способы оповещений',
|
||||
},
|
||||
),
|
||||
]
|
||||
@@ -112,4 +112,18 @@ class UserActivityLog(models.Model):
|
||||
verbose_name_plural = 'Журналы активности'
|
||||
|
||||
def __str__(self):
|
||||
return f"User {self.user_id} - {self.type} - {self.date_time}"
|
||||
return f"User {self.user_id} - {self.type} - {self.date_time}"
|
||||
|
||||
class NotificationSettings(models.Model):
|
||||
user = models.OneToOneField(User, on_delete=models.CASCADE, verbose_name="Пользователь")
|
||||
telegram_enabled = models.BooleanField(default=True, verbose_name="Уведомления в Telegram")
|
||||
email_enabled = models.BooleanField(default=False, verbose_name="Уведомления по Email")
|
||||
email = models.EmailField(blank=True, null=True, verbose_name="Email для уведомлений")
|
||||
notification_time = models.TimeField(default="09:00", verbose_name="Время отправки уведомлений")
|
||||
|
||||
def __str__(self):
|
||||
return f"Настройки уведомлений для {self.user.username}"
|
||||
|
||||
class Meta:
|
||||
verbose_name = "Способ оповещения"
|
||||
verbose_name_plural = "Способы оповещений"
|
||||
Reference in New Issue
Block a user