From 2ddfd77122c1436fe8f0c61192c2a0e885f1c5bc Mon Sep 17 00:00:00 2001 From: cmsetzer <37311998+cmsetzer@users.noreply.github.com> Date: Thu, 5 Dec 2024 08:35:36 -0800 Subject: [PATCH] Disallow firm names that are too long and cause database errors (#3674) --- perma_web/perma/forms.py | 3 ++ perma_web/perma/models.py | 55 ++++++++++++++------------ perma_web/perma/views/user_settings.py | 4 +- perma_web/perma/views/user_sign_up.py | 5 +-- 4 files changed, 36 insertions(+), 31 deletions(-) diff --git a/perma_web/perma/forms.py b/perma_web/perma/forms.py index 24347024a..460615e62 100755 --- a/perma_web/perma/forms.py +++ b/perma_web/perma/forms.py @@ -102,6 +102,9 @@ def __init__(self, *args, **kwargs): ### FIRM (OTHER ORG) QUOTE FORMS ### class FirmRegistrarForm(ModelForm): + # Ensure firm name doesn't throw a DataError when we write it to LinkUser.requested_account_note + name = forms.CharField(max_length=LinkUser.requested_account_note.field.max_length) + class Meta: model = Registrar fields = ['name', 'email', 'website'] diff --git a/perma_web/perma/models.py b/perma_web/perma/models.py index 9d7c1eb41..29e041b43 100755 --- a/perma_web/perma/models.py +++ b/perma_web/perma/models.py @@ -1,57 +1,62 @@ import calendar from contextlib import contextmanager +from datetime import datetime +from datetime import timezone as tz from decimal import Decimal -from datetime import datetime, timezone as tz -from dateutil.relativedelta import relativedelta import hashlib +import hmac +import itertools import json -import os import logging +import os import random import re -from urllib.parse import urlparse -import simple_history -import requests -import itertools import time -import hmac +from urllib.parse import urlparse import uuid -from psycopg2.extras import DateTimeTZRange import zipfile -from rest_framework.settings import api_settings -from simple_history.models import HistoricalRecords -from tree_queries.models import TreeNode -from tree_queries.query import TreeQuerySet - +from dateutil.relativedelta import relativedelta +from django.conf import settings import django.contrib.auth.models -from django.contrib.auth.models import BaseUserManager, AbstractBaseUser, PermissionsMixin +from django.contrib.auth.models import AbstractBaseUser, BaseUserManager, PermissionsMixin from django.contrib.postgres.fields import ArrayField, DateTimeRangeField -from django.conf import settings +from django.contrib.postgres.indexes import GinIndex, GistIndex, OpClass from django.core.files.storage import storages from django.db import models, transaction -from django.db.models import Q, Max, Count, Sum, JSONField, F, Exists, OuterRef, When, Case -from django.db.models.functions import Now, Upper, TruncDate +from django.db.models import Case, Count, Exists, F, JSONField, Max, OuterRef, Q, Sum, When +from django.db.models.functions import Now, TruncDate, Upper from django.db.models.query import QuerySet -from django.contrib.postgres.indexes import GistIndex, GinIndex, OpClass from django.template.defaultfilters import truncatechars from django.urls import reverse from django.utils import timezone from django.utils.functional import cached_property from django.views.decorators.debug import sensitive_variables from model_utils import FieldTracker +from psycopg2.extras import DateTimeTZRange +import requests +from rest_framework.settings import api_settings +import simple_history +from simple_history.models import HistoricalRecords import surt from taggit.managers import TaggableManager from taggit.models import CommonGenericTaggedItemBase, TaggedItemBase +from tree_queries.models import TreeNode +from tree_queries.query import TreeQuerySet -from .exceptions import PermaPaymentsCommunicationException, InvalidTransmissionException -from .utils import (tz_datetime, - prep_for_perma_payments, process_perma_payments_transmission, +from perma.exceptions import InvalidTransmissionException, PermaPaymentsCommunicationException +from perma.utils import ( + first_day_of_next_month, pp_date_from_post, - first_day_of_next_month, today_next_year, preserve_perma_warc, + prep_for_perma_payments, + preserve_perma_warc, + process_perma_payments_transmission, + protocol, + remove_control_characters, + today_next_year, + tz_datetime, write_resource_record_from_asset, - protocol, remove_control_characters) - +) logger = logging.getLogger(__name__) diff --git a/perma_web/perma/views/user_settings.py b/perma_web/perma/views/user_settings.py index 89264b46c..91874e36a 100644 --- a/perma_web/perma/views/user_settings.py +++ b/perma_web/perma/views/user_settings.py @@ -4,10 +4,10 @@ from django.contrib import messages from django.contrib.auth.decorators import login_required from django.contrib.auth.forms import PasswordChangeForm -from django.http import HttpResponseRedirect, Http404, HttpResponseForbidden +from django.http import Http404, HttpResponseForbidden, HttpResponseRedirect +from django.shortcuts import render from django.urls import reverse from django.utils import timezone -from django.shortcuts import render from django.views.decorators.debug import sensitive_variables from django.views.decorators.http import require_http_methods diff --git a/perma_web/perma/views/user_sign_up.py b/perma_web/perma/views/user_sign_up.py index 3fdddf8e5..5e82a3f76 100644 --- a/perma_web/perma/views/user_sign_up.py +++ b/perma_web/perma/views/user_sign_up.py @@ -24,10 +24,7 @@ UserForm, check_honeypot, ) -from perma.models import ( - LinkUser, - Registrar, -) +from perma.models import LinkUser, Registrar from perma.utils import ( apply_pagination, apply_search_query,