db parse module

This commit is contained in:
2024-12-06 12:37:15 +09:00
parent bd52a68cc7
commit 7309aef349
4 changed files with 61 additions and 4 deletions

Binary file not shown.

View File

@@ -83,10 +83,16 @@ DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': BASE_DIR / 'db.sqlite3',
}
},
'wordpress': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'u1510415_wp832',
'USER': 'root',
'PASSWORD': 'R0sebud',
'HOST': '0.0.0.0',
'PORT': '3306',
},
}
# Password validation
# https://docs.djangoproject.com/en/5.1/ref/settings/#auth-password-validators

View File

@@ -0,0 +1,29 @@
from django.core.management.base import BaseCommand
from users.models import WordPressUserActivityLog
from users.models import LocalUserActivityLog
from asgiref.sync import sync_to_async
class Command(BaseCommand):
help = "Синхронизация данных из WordPress в локальную базу данных"
def handle(self, *args, **kwargs):
self.stdout.write("Начало синхронизации данных...")
try:
# Получаем данные из WordPress
wordpress_logs = WordPressUserActivityLog.objects.using('wordpress').all()
for log in wordpress_logs:
# Сохраняем данные в локальную базу
LocalUserActivityLog.objects.update_or_create(
id=log.id, # Используем уникальный идентификатор
defaults={
'user_id': log.user_id,
'activity_type': log.activity_type,
'timestamp': log.timestamp,
'additional_data': log.additional_data,
},
)
self.stdout.write(self.style.SUCCESS("Синхронизация завершена успешно!"))
except Exception as e:
self.stderr.write(self.style.ERROR(f"Ошибка синхронизации: {str(e)}"))

View File

@@ -49,3 +49,25 @@ class UserConfirmation(models.Model):
def __str__(self):
return f"Confirmation for {self.user.username} - {self.confirmation_code}"
class WordPressUserActivityLog(models.Model):
id = models.AutoField(primary_key=True)
user_id = models.IntegerField()
activity_type = models.CharField(max_length=255)
timestamp = models.DateTimeField()
additional_data = models.JSONField(null=True, blank=True)
class Meta:
db_table = 'wpts_user_activity_log' # Название таблицы в базе данных WordPress
managed = False # Django не будет управлять этой таблицей
app_label = 'Users' # Замените на имя вашего приложения
class LocalUserActivityLog(models.Model):
id = models.AutoField(primary_key=True)
user_id = models.IntegerField()
activity_type = models.CharField(max_length=255)
timestamp = models.DateTimeField()
additional_data = models.JSONField(null=True, blank=True)
def __str__(self):
return f"User {self.user_id} - {self.activity_type}"