forked from ScoDoc/ScoDoc
Migration: tolère dates logs aberrantes, et élimine relations manquantes dans entreprises
This commit is contained in:
parent
30e7fd516b
commit
01dcd8cccd
30
scodoc.py
30
scodoc.py
@ -278,20 +278,36 @@ def user_role(username, dept_acronym=None, add_role_name=None, remove_role_name=
|
|||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
|
||||||
|
|
||||||
|
def abort_if_false(ctx, param, value):
|
||||||
|
if not value:
|
||||||
|
ctx.abort()
|
||||||
|
|
||||||
|
|
||||||
@app.cli.command()
|
@app.cli.command()
|
||||||
|
@click.option(
|
||||||
|
"--yes",
|
||||||
|
is_flag=True,
|
||||||
|
callback=abort_if_false,
|
||||||
|
expose_value=False,
|
||||||
|
prompt=f"""Attention: Cela va effacer toutes les données du département
|
||||||
|
(étudiants, notes, formations, etc)
|
||||||
|
Voulez-vous vraiment continuer ?
|
||||||
|
""",
|
||||||
|
)
|
||||||
@click.argument("dept")
|
@click.argument("dept")
|
||||||
def delete_dept(dept): # delete-dept
|
def delete_dept(dept): # delete-dept
|
||||||
"""Delete existing departement"""
|
"""Delete existing departement"""
|
||||||
from app.scodoc import notesdb as ndb
|
from app.scodoc import notesdb as ndb
|
||||||
from app.scodoc import sco_dept
|
from app.scodoc import sco_dept
|
||||||
|
|
||||||
click.confirm(
|
if False:
|
||||||
f"""Attention: Cela va effacer toutes les données du département {dept}
|
click.confirm(
|
||||||
(étudiants, notes, formations, etc)
|
f"""Attention: Cela va effacer toutes les données du département {dept}
|
||||||
Voulez-vous vraiment continuer ?
|
(étudiants, notes, formations, etc)
|
||||||
""",
|
Voulez-vous vraiment continuer ?
|
||||||
abort=True,
|
""",
|
||||||
)
|
abort=True,
|
||||||
|
)
|
||||||
db.reflect()
|
db.reflect()
|
||||||
ndb.open_db_connection()
|
ndb.open_db_connection()
|
||||||
d = models.Departement.query.filter_by(acronym=dept).first()
|
d = models.Departement.query.filter_by(acronym=dept).first()
|
||||||
|
@ -170,6 +170,11 @@ def import_scodoc7_dept(dept_id: str, dept_db_uri=None):
|
|||||||
logging.info(f"connecting to database {dept_db_uri}")
|
logging.info(f"connecting to database {dept_db_uri}")
|
||||||
cnx = psycopg2.connect(dept_db_uri)
|
cnx = psycopg2.connect(dept_db_uri)
|
||||||
cursor = cnx.cursor(cursor_factory=ndb.ScoDocCursor)
|
cursor = cnx.cursor(cursor_factory=ndb.ScoDocCursor)
|
||||||
|
# FIX : des dates aberrantes (dans le futur) peuvent tenir en SQL mais pas en Python
|
||||||
|
cursor.execute(
|
||||||
|
"""UPDATE scolar_events SET event_date='2021-09-30' WHERE event_date > '2200-01-01'"""
|
||||||
|
)
|
||||||
|
cnx.commit()
|
||||||
# Create dept:
|
# Create dept:
|
||||||
dept = models.Departement(acronym=dept_id, description="migré de ScoDoc7")
|
dept = models.Departement(acronym=dept_id, description="migré de ScoDoc7")
|
||||||
db.session.add(dept)
|
db.session.add(dept)
|
||||||
@ -374,6 +379,8 @@ def convert_object(
|
|||||||
new_ref = id_from_scodoc7[old_ref]
|
new_ref = id_from_scodoc7[old_ref]
|
||||||
elif (not is_table) and table_name in {
|
elif (not is_table) and table_name in {
|
||||||
"scolog",
|
"scolog",
|
||||||
|
"entreprise_correspondant",
|
||||||
|
"entreprise_contact",
|
||||||
"etud_annotations",
|
"etud_annotations",
|
||||||
"notes_notes_log",
|
"notes_notes_log",
|
||||||
"scolar_news",
|
"scolar_news",
|
||||||
@ -389,7 +396,6 @@ def convert_object(
|
|||||||
new_ref = None
|
new_ref = None
|
||||||
elif is_table and table_name in {
|
elif is_table and table_name in {
|
||||||
"notes_semset_formsemestre",
|
"notes_semset_formsemestre",
|
||||||
"entreprise_contact",
|
|
||||||
}:
|
}:
|
||||||
# pour anciennes installs où des relations n'avait pas été déclarées clés étrangères
|
# pour anciennes installs où des relations n'avait pas été déclarées clés étrangères
|
||||||
# eg: notes_semset_formsemestre.semset_id n'était pas une clé
|
# eg: notes_semset_formsemestre.semset_id n'était pas une clé
|
||||||
|
Loading…
x
Reference in New Issue
Block a user