Pre-process json data before importing

- Removes any unwanted "permissions" entries from data imported from an *older* version of InvenTree
This commit is contained in:
Oliver Walters 2021-04-25 12:07:58 +10:00
parent b6cfa50e12
commit 2f2354afdc
2 changed files with 28 additions and 2 deletions

1
.gitignore vendored
View File

@ -48,6 +48,7 @@ config.yaml
# Default data file # Default data file
data.json data.json
*.json.tmp *.json.tmp
*.tmp.json
# Key file # Key file
secret_key.txt secret_key.txt

View File

@ -288,7 +288,7 @@ def export_records(c, filename='data.json'):
print("Running data post-processing step...") print("Running data post-processing step...")
# Post-process the file, to remove any "permissions" specified for a group # Post-process the file, to remove any "permissions" specified for a user or group
with open(tmpfile, "r") as f_in: with open(tmpfile, "r") as f_in:
data = json.loads(f_in.read()) data = json.loads(f_in.read())
@ -307,6 +307,8 @@ def export_records(c, filename='data.json'):
with open(filename, "w") as f_out: with open(filename, "w") as f_out:
f_out.write(json.dumps(data, indent=2)) f_out.write(json.dumps(data, indent=2))
print("Data export completed")
@task(help={'filename': 'Input filename'}) @task(help={'filename': 'Input filename'})
def import_records(c, filename='data.json'): def import_records(c, filename='data.json'):
@ -324,10 +326,33 @@ def import_records(c, filename='data.json'):
print(f"Importing database records from '{filename}'") print(f"Importing database records from '{filename}'")
cmd = f"loaddata {filename} -i {content_excludes()}" # Pre-process the data, to remove any "permissions" specified for a user or group
tmpfile = f"{filename}.tmp.json"
with open(filename, "r") as f_in:
data = json.loads(f_in.read())
for entry in data:
if "model" in entry:
# Clear out any permissions specified for a group
if entry["model"] == "auth.group":
entry["fields"]["permissions"] = []
# Clear out any permissions specified for a user
if entry["model"] == "auth.user":
entry["fields"]["user_permissions"] = []
# Write the processed data to the tmp file
with open(tmpfile, "w") as f_out:
f_out.write(json.dumps(data, indent=2))
cmd = f"loaddata {tmpfile} -i {content_excludes()}"
manage(c, cmd, pty=True) manage(c, cmd, pty=True)
print("Data import completed")
@task @task
def import_fixtures(c): def import_fixtures(c):
""" """