mirror of
https://gitlab.crans.org/bde/nk20-scripts
synced 2025-06-30 02:01:07 +02:00
Compare commits
12 Commits
9fafa3b373
...
borg_backu
Author | SHA1 | Date | |
---|---|---|---|
abd5af9ad2 | |||
472c9c33ce | |||
6149f11e53 | |||
08455e6e60 | |||
b17780e5e9 | |||
354a1f845e | |||
f580f9b9e9 | |||
d7715fa81a | |||
11bcc07bf4 | |||
c518b3dddb | |||
c69c5197c9 | |||
3442edd2bf |
1
.gitignore
vendored
1
.gitignore
vendored
@ -33,6 +33,7 @@ coverage
|
|||||||
|
|
||||||
# Local data
|
# Local data
|
||||||
secrets.py
|
secrets.py
|
||||||
|
*/.env_borg
|
||||||
*.log
|
*.log
|
||||||
|
|
||||||
# Virtualenv
|
# Virtualenv
|
||||||
|
1
apps.py
1
apps.py
@ -2,7 +2,6 @@
|
|||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
from django.apps import AppConfig
|
from django.apps import AppConfig
|
||||||
from django.core.signals import got_request_exception
|
|
||||||
|
|
||||||
|
|
||||||
class ScriptsConfig(AppConfig):
|
class ScriptsConfig(AppConfig):
|
||||||
|
@ -5,10 +5,9 @@ import json
|
|||||||
import time
|
import time
|
||||||
from collections import defaultdict
|
from collections import defaultdict
|
||||||
|
|
||||||
from django.core.management.base import BaseCommand
|
|
||||||
from django.apps import apps
|
from django.apps import apps
|
||||||
|
from django.core.management.base import BaseCommand
|
||||||
from django.db import transaction
|
from django.db import transaction
|
||||||
|
|
||||||
from polymorphic.models import PolymorphicModel
|
from polymorphic.models import PolymorphicModel
|
||||||
|
|
||||||
|
|
||||||
@ -16,6 +15,7 @@ def timed(method):
|
|||||||
""""
|
""""
|
||||||
A simple decorator to measure time elapsed in class function (hence the args[0])
|
A simple decorator to measure time elapsed in class function (hence the args[0])
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def _timed(*args, **kw):
|
def _timed(*args, **kw):
|
||||||
ts = time.time()
|
ts = time.time()
|
||||||
result = method(*args, **kw)
|
result = method(*args, **kw)
|
||||||
|
@ -13,6 +13,7 @@ class Command(BaseCommand):
|
|||||||
"""
|
"""
|
||||||
Generate Javascript translation files
|
Generate Javascript translation files
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def handle(self, *args, **kwargs):
|
def handle(self, *args, **kwargs):
|
||||||
for code, _ in settings.LANGUAGES:
|
for code, _ in settings.LANGUAGES:
|
||||||
if code == settings.LANGUAGE_CODE:
|
if code == settings.LANGUAGE_CODE:
|
||||||
|
@ -1,18 +1,16 @@
|
|||||||
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
# Copyright (C) 2018-2024 by BDE ENS Paris-Saclay
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
from datetime import date
|
from datetime import date
|
||||||
|
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.core.management import BaseCommand
|
from django.core.management import BaseCommand
|
||||||
from django.db.models import Q
|
from member.models import Club, Membership
|
||||||
from member.models import Membership, Club
|
|
||||||
from wei.models import WEIClub
|
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
help = "Get mailing list registrations from the last wei. " \
|
help = "Get mailing list registrations from the last wei. " \
|
||||||
"Usage: manage.py extract_ml_registrations -t {events,art,sport} -t {fr, en}. " \
|
"Usage: manage.py extract_ml_registrations -t {events,art,sport} -l {fr, en} -y {0, 1, ...}. " \
|
||||||
"You can write this into a file with a pipe, then paste the document into your mail manager."
|
"You can write this into a file with a pipe, then paste the document into your mail manager."
|
||||||
|
|
||||||
def add_arguments(self, parser):
|
def add_arguments(self, parser):
|
||||||
@ -21,6 +19,8 @@ class Command(BaseCommand):
|
|||||||
parser.add_argument('--lang', '-l', type=str, choices=['fr', 'en'], default='fr',
|
parser.add_argument('--lang', '-l', type=str, choices=['fr', 'en'], default='fr',
|
||||||
help='Select the registred users of the ML of the given language. Useful only for the '
|
help='Select the registred users of the ML of the given language. Useful only for the '
|
||||||
'events mailing list.')
|
'events mailing list.')
|
||||||
|
parser.add_argument('--years', '-y', type=int, default=0,
|
||||||
|
help='Select the cumulative registred users of a membership from years ago. 0 means the current users')
|
||||||
|
|
||||||
def handle(self, *args, **options):
|
def handle(self, *args, **options):
|
||||||
# TODO: Improve the mailing list extraction system, and link it automatically with Mailman.
|
# TODO: Improve the mailing list extraction system, and link it automatically with Mailman.
|
||||||
@ -30,10 +30,12 @@ class Command(BaseCommand):
|
|||||||
return
|
return
|
||||||
|
|
||||||
if options["type"] == "members":
|
if options["type"] == "members":
|
||||||
|
today_date = date.today()
|
||||||
|
selected_date = date(today_date.year - options["years"], today_date.month, today_date.day)
|
||||||
for membership in Membership.objects.filter(
|
for membership in Membership.objects.filter(
|
||||||
club__name="BDE",
|
club__name="BDE",
|
||||||
date_start__lte=date.today(),
|
date_start__lte=today_date,
|
||||||
date_end__gte=date.today(),
|
date_end__gte=selected_date,
|
||||||
).all():
|
).all():
|
||||||
self.stdout.write(membership.user.email)
|
self.stdout.write(membership.user.email)
|
||||||
return
|
return
|
||||||
@ -51,8 +53,11 @@ class Command(BaseCommand):
|
|||||||
return
|
return
|
||||||
|
|
||||||
if options["type"] == "art":
|
if options["type"] == "art":
|
||||||
|
nb=0
|
||||||
for user in User.objects.filter(profile__ml_art_registration=True).all():
|
for user in User.objects.filter(profile__ml_art_registration=True).all():
|
||||||
self.stdout.write(user.email)
|
self.stdout.write(user.email)
|
||||||
|
nb+=1
|
||||||
|
self.stdout.write(str(nb))
|
||||||
return
|
return
|
||||||
|
|
||||||
if options["type"] == "sport":
|
if options["type"] == "sport":
|
||||||
|
@ -11,7 +11,6 @@ from django.core.management.base import BaseCommand
|
|||||||
from django.db import transaction
|
from django.db import transaction
|
||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
from django.test import override_settings
|
from django.test import override_settings
|
||||||
|
|
||||||
from note.models import Alias, Transaction
|
from note.models import Alias, Transaction
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,23 +1,19 @@
|
|||||||
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
import psycopg2 as pg
|
|
||||||
import psycopg2.extras as pge
|
|
||||||
import datetime
|
import datetime
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from django.template.loader import render_to_string
|
import psycopg2 as pg
|
||||||
from django.utils.timezone import make_aware, now
|
import psycopg2.extras as pge
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
|
|
||||||
from django.db import transaction
|
from django.db import transaction
|
||||||
|
from django.utils.timezone import make_aware
|
||||||
from note.models import Note, NoteUser, NoteClub
|
|
||||||
from note.models import Alias
|
|
||||||
from member.models import Club, Profile
|
from member.models import Club, Profile
|
||||||
|
from note.models import Alias, Note, NoteClub, NoteUser
|
||||||
|
|
||||||
from ._import_utils import ImportCommand, BulkCreateManager, timed
|
from ._import_utils import BulkCreateManager, ImportCommand, timed
|
||||||
|
|
||||||
M_DURATION = 396
|
M_DURATION = 396
|
||||||
M_START = datetime.date(2019, 8, 1)
|
M_START = datetime.date(2019, 8, 1)
|
||||||
|
@ -3,32 +3,30 @@
|
|||||||
|
|
||||||
import psycopg2 as pg
|
import psycopg2 as pg
|
||||||
import psycopg2.extras as pge
|
import psycopg2.extras as pge
|
||||||
import datetime
|
from activity.models import Activity, ActivityType, Entry, Guest
|
||||||
import copy
|
|
||||||
|
|
||||||
from django.utils.timezone import make_aware
|
|
||||||
from django.db import transaction
|
from django.db import transaction
|
||||||
|
from django.utils.timezone import make_aware
|
||||||
from activity.models import ActivityType, Activity, Guest, Entry
|
|
||||||
from member.models import Club
|
from member.models import Club
|
||||||
from note.models import Note, NoteUser
|
from note.models import Note, NoteUser
|
||||||
from ._import_utils import ImportCommand, BulkCreateManager, timed
|
|
||||||
|
from ._import_utils import BulkCreateManager, ImportCommand, timed
|
||||||
|
|
||||||
MAP_ACTIVITY = dict()
|
MAP_ACTIVITY = dict()
|
||||||
|
|
||||||
CLUB_RELOU = [
|
CLUB_RELOU = [
|
||||||
0, # BDE
|
0, # BDE
|
||||||
4771, # Kataclist
|
4771, # Kataclist
|
||||||
5162, # Assurance BDE ?!
|
5162, # Assurance BDE ?!
|
||||||
5164, # S & L
|
5164, # S & L
|
||||||
625, # Aspique
|
625, # Aspique
|
||||||
5154, # Frekens
|
5154, # Frekens
|
||||||
3944, # DiskJok[ENS]
|
3944, # DiskJok[ENS]
|
||||||
5153, # Monopo[list]
|
5153, # Monopo[list]
|
||||||
2351, # JdRM
|
2351, # JdRM
|
||||||
2365, # Pot Vieux
|
2365, # Pot Vieux
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
class Command(ImportCommand):
|
class Command(ImportCommand):
|
||||||
"""
|
"""
|
||||||
Import command for Activities Base Data (Comptes, and Aliases)
|
Import command for Activities Base Data (Comptes, and Aliases)
|
||||||
@ -50,7 +48,7 @@ class Command(ImportCommand):
|
|||||||
row["responsable"] = 3508
|
row["responsable"] = 3508
|
||||||
note = self.MAP_IDBDE[row["responsable"]]
|
note = self.MAP_IDBDE[row["responsable"]]
|
||||||
if note == 6244:
|
if note == 6244:
|
||||||
# Licorne magique ne doit pas utiliser son compte club pour proposer des activités
|
# Licorne magique ne doit pas utiliser son compte club pour proposer des activités
|
||||||
note = Note.objects.get(pk=self.MAP_IDBDE[6524])
|
note = Note.objects.get(pk=self.MAP_IDBDE[6524])
|
||||||
note = note.id
|
note = note.id
|
||||||
organizer = Club.objects.filter(name=row["signature"])
|
organizer = Club.objects.filter(name=row["signature"])
|
||||||
|
@ -3,15 +3,15 @@
|
|||||||
|
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
from django.core.management.base import BaseCommand
|
|
||||||
from django.core.management import call_command
|
from django.core.management import call_command
|
||||||
|
|
||||||
from ._import_utils import ImportCommand
|
from ._import_utils import ImportCommand
|
||||||
|
|
||||||
|
|
||||||
class Command(ImportCommand):
|
class Command(ImportCommand):
|
||||||
"""
|
"""
|
||||||
Command for importing the database of NK15.
|
Command for importing the database of NK15.
|
||||||
Need to be run by a user with a registered role in postgres for the database nk15.
|
Need to be run by a user with a registered role in postgres for the database nk15.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def handle(self, *args, **kwargs):
|
def handle(self, *args, **kwargs):
|
||||||
|
@ -1,31 +1,25 @@
|
|||||||
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
|
import copy
|
||||||
|
import datetime
|
||||||
import re
|
import re
|
||||||
|
|
||||||
|
import pytz
|
||||||
import psycopg2 as pg
|
import psycopg2 as pg
|
||||||
import psycopg2.extras as pge
|
import psycopg2.extras as pge
|
||||||
import pytz
|
from activity.models import Entry, GuestTransaction
|
||||||
import datetime
|
|
||||||
import copy
|
|
||||||
|
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.utils.timezone import make_aware
|
|
||||||
from django.db import transaction
|
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
|
from django.db import transaction
|
||||||
from note.models import (TemplateCategory,
|
from django.utils.timezone import make_aware
|
||||||
TransactionTemplate,
|
|
||||||
Transaction,
|
|
||||||
RecurrentTransaction,
|
|
||||||
SpecialTransaction,
|
|
||||||
MembershipTransaction,
|
|
||||||
)
|
|
||||||
from note.models import Note, NoteClub
|
|
||||||
from activity.models import Guest, GuestTransaction, Entry
|
|
||||||
|
|
||||||
from member.models import Membership
|
from member.models import Membership
|
||||||
from treasury.models import Remittance, SpecialTransactionProxy, SogeCredit
|
from note.models import (MembershipTransaction, Note, NoteClub,
|
||||||
from ._import_utils import ImportCommand, BulkCreateManager, timed
|
RecurrentTransaction, SpecialTransaction,
|
||||||
|
TemplateCategory, Transaction, TransactionTemplate)
|
||||||
|
from treasury.models import Remittance, SogeCredit, SpecialTransactionProxy
|
||||||
|
|
||||||
|
from ._import_utils import BulkCreateManager, ImportCommand, timed
|
||||||
|
|
||||||
MAP_TRANSACTION = dict()
|
MAP_TRANSACTION = dict()
|
||||||
MAP_REMITTANCE = dict()
|
MAP_REMITTANCE = dict()
|
||||||
|
@ -2,14 +2,14 @@
|
|||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
import os
|
import os
|
||||||
from bs4 import BeautifulSoup
|
|
||||||
from django.core.management import BaseCommand
|
|
||||||
from django.urls import reverse
|
|
||||||
from django.utils import timezone
|
|
||||||
from urllib.parse import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib.request import Request, urlopen
|
from urllib.request import Request, urlopen
|
||||||
|
|
||||||
|
from bs4 import BeautifulSoup
|
||||||
from activity.models import Activity
|
from activity.models import Activity
|
||||||
|
from django.core.management import BaseCommand
|
||||||
|
from django.urls import reverse
|
||||||
|
from django.utils import timezone
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
|
@ -6,7 +6,6 @@ from datetime import timedelta
|
|||||||
from django.core.management.base import BaseCommand
|
from django.core.management.base import BaseCommand
|
||||||
from django.db.models import Count
|
from django.db.models import Count
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
|
||||||
from note.models import RecurrentTransaction, TransactionTemplate
|
from note.models import RecurrentTransaction, TransactionTemplate
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,8 +8,7 @@ from django.core.management import BaseCommand
|
|||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
from django.utils.translation import activate
|
from django.utils.translation import activate
|
||||||
|
from note.models import Note
|
||||||
from note.models import NoteUser, Note
|
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
|
@ -1,14 +1,11 @@
|
|||||||
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
from datetime import timedelta
|
|
||||||
|
|
||||||
from django.core.management import BaseCommand
|
from django.core.management import BaseCommand
|
||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.utils.translation import activate
|
from django.utils.translation import activate
|
||||||
|
|
||||||
from note.models import NoteUser, Transaction
|
from note.models import NoteUser, Transaction
|
||||||
from note.tables import HistoryTable
|
from note.tables import HistoryTable
|
||||||
|
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
# Copyright (C) 2018-2021 by BDE ENS Paris-Saclay
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
from django.core.management.base import BaseCommand
|
|
||||||
from django.apps import apps
|
from django.apps import apps
|
||||||
|
from django.core.management.base import BaseCommand
|
||||||
from django.db import connection
|
from django.db import connection
|
||||||
|
|
||||||
|
|
||||||
from polymorphic.models import PolymorphicModel
|
from polymorphic.models import PolymorphicModel
|
||||||
|
|
||||||
NO_SEQ = [
|
NO_SEQ = [
|
||||||
@ -14,6 +12,7 @@ NO_SEQ = [
|
|||||||
"WEIRole", # dirty fix
|
"WEIRole", # dirty fix
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
"""
|
"""
|
||||||
Command to synchronise primary sequence of postgres after bulk insert of django.
|
Command to synchronise primary sequence of postgres after bulk insert of django.
|
||||||
|
3
shell/.env_borg_example
Normal file
3
shell/.env_borg_example
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
BORG_PASSPHRASE='CHANGE_ME'
|
||||||
|
BORG_REPO='USER@SERVER:PATH'
|
||||||
|
BACKUP_FILE='PATH'
|
@ -1,9 +1,14 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
export $(cat .env_borg | xargs)
|
||||||
|
|
||||||
# Create temporary backups directory
|
# Create temporary backups directory
|
||||||
[[ -d /tmp/note-backups ]] || mkdir /tmp/note-backups
|
mkdir -p /tmp/note-backups
|
||||||
date=$(date +%Y-%m-%d)
|
|
||||||
# Backup database and save it as tar archive
|
# Backup database
|
||||||
su postgres -c "pg_dump -F t note_db" | tee "/tmp/note-backups/$date.tar" > /dev/null
|
sudo -u postgres pg_dump -F t note_db > $BACKUP_FILE
|
||||||
# Compress backup as gzip
|
|
||||||
gzip "/tmp/note-backups/$date.tar"
|
# Keep the last 30 backups
|
||||||
scp "/tmp/note-backups/$date.tar.gz" "club-bde@zamok.crans.org:backup/$date.tar.gz"
|
borg prune --keep-last 30
|
||||||
|
|
||||||
|
# Save backup
|
||||||
|
borg create --compression lz4 ::backup-{now} $BACKUP_FILE
|
||||||
|
Reference in New Issue
Block a user