Skip to content

Latest commit

 

History

History
535 lines (307 loc) · 14.8 KB

CHANGELOG.md

File metadata and controls

535 lines (307 loc) · 14.8 KB

CHANGELOG

75.0.0

  • BREAKING CHANGE: notifications_utils/clients/encryption/encryption_client has been removed. It has been replaced with notifications_utils/clients/signing/signing_client. This is because the encyrption_client was not using encryption. It was just signing the contents of the string.

74.12.3

  • Add structured time_taken log to celery logs

74.12.2

  • Fix use of hyphen in phone number validation error

74.12.1

  • email template: use the new crown and associated styling

74.12.0

  • Remove celery.* structured logging for now. It can return when we have more certainty over what values it will log or can rule out that it is ever given sensitive values.

74.11.0

  • Add option to ignore list of web paths from request logging. Defaults to /_status and /metrics.
  • Add new fields to web request log messages (user_agent, host, path)

74.9.1

  • logging: set celery.worker.strategy logging to WARNING to prevent sensitive information being logged

74.9.0

  • logging: also attach handlers etc. to celery.worker and celery.redirected

74.8.1

  • Always hide barcodes when printing a letter - not only when adding a NOTIFY tag

74.8.0

  • NotifyRequest: generate own span_id if none provided in headers

74.7.0

  • Include onwards request headers in AntivirusClient requests

74.6.0

  • Include parent_span_id in request logs
  • Include span_id in all logs when available

74.5.0

  • Include remote_addr in request logs
  • NotifyRequest: handle trace ids when not handed X-B3-TraceId by paas

74.4.0

  • Reverts the 'single session' change from 74.1.0, which may be causing us some connection errors.

74.3.0

  • Add decrby method to the RedisClient

74.2.0

  • Change logging's date formatting to include microseconds

74.1.0

  • remove the geojson dependency (another emergency alerts module)
  • reuse a single session for all antivirus/zendesk requests to get http keepalive advantages

74.0.0

Removes Emergency-Alerts-related code

  • the polygons module has been removed
  • template.BroadcastPreviewTemplate and template.BroadcastMessageTemplate have been removed

73.2.1

  • Fix utils packaging to allow access to subpackages again.

73.2.0

  • Adds a include_notify_tag parameter to LetterPrintTemplate so that bilingual letters can disable the NOTIFY tag on the English pages of a letter.

73.1.3

  • Add compatibility with Python 3.11 and 3.12

73.1.2

  • Change how utils is packaged to exclude tests.

73.1.1

  • SKIPPED VERSION - NO RELEASE.

73.1.0

  • Adds request logging to flask apps.
  • Adds RestrictedAny family of testing utilities to new testing.comparisons submodule.

73.0.0

  • Removes LetterImageTemplate. This has been moved to admin, as that is the only app using it.

72.2.0

  • Render Welsh language templated letter, with page numbers footer and name of the month in Welsh
  • Recognise placeholders from letter_welsh_content and letter_welsh_subject fields

72.1.0

  • Change the email template to use a HTML5 doctype and add a 'hidden' attribute to the preheader

72.0.0

  • Remove the deprecated from_address param from EmailPreviewTemplate (it's been unused for six years)

71.0.0

  • Remove support for Markdown-style links in letters [label](https://example.url)

70.0.6

  • Fix QR code rendering for old-style syntax [QR]()

70.0.5

  • Ensure UUIDs in Redis cache keys are always lowercase

70.0.4

  • Update the commit message auto-generated by make bump-utils (in app repos) to be copy/pastable via eg vim commit message editing.

70.0.3

  • Remove empty table cell from 'branding only' branding HTML to fix bug with JAWS screen reader

70.0.2

  • Update sanitising of SMS content to include more obscure whitespace

70.0.0

  • InvalidPhoneError messages have been updated. The new error messages are more user friendly.

69.0.0

  • Remove old syntax for QR codes in letters (only QR: http://example.com will work now)

68.0.1

  • Fix a bug with some HTML getting injected into QR codes

68.0.0

  • Update return value of BaseLetterTemplate.has_qr_code_with_too_much_data from bool to Optional[QrCodeTooLong].

67.0.0

  • Add has_qr_code_with_too_much_data property to letter templates.
  • Update RecipientCSV to detect and throw errors when rows generate QR codes with too much data in them. Anything using RecipientCSV to process letters will need to check for and report on the row-level property qr_code_too_long.

66.1.0

66.0.2

  • Style the QR code placeholder so it looks better when the placeholder text is long

66.0.1

  • Use HTML-encoded parenthesis (( and )) when rendering template content with placeholders.
  • Bump phonenumbers to >= 8.13.8.

66.0.0

65.2.0

  • Update international billing rates for text messages to latest values from MMG.

65.1.0

  • Add a few more mappings to the list of countries for postage

65.0.0

  • Remove automatic formatting from JSONFormatter. Any log messages using {} to inject strings should be converted to "old-style" log messages using %s and passing variables as arguments to the log function. Do not eagerly interpolate the string (eg "log: {}" % ("string") - let Python's logging module do this itself. This is to provide compatability with Sentry. Add the "G" rule to Ruff's checks to enforce this.
  • Removes CustomLogFormatter altogether, as its only purpose was the auto-formatting as above.

64.2.0

  • LetterImageTemplate now adds a hidden element marking the first page of any attachment

64.1.0

  • RequestCache now stores items in Redis for 28 days by default (2419200 seconds instead of 7 days or 604800 seconds)

64.0.0

  • Remove the postage argument from LetterImageTemplate in favour of getting postage from the template dict (can still be overridden by setting template_instance.postage)
  • The page_count argument of LetterImageTemplate is now optional until the template is rendered (calling str(template))

63.4.0

  • Allow subheadings via markdown for emails using ##.

63.3.0

  • Only log a warning and no longer raise an error if creating a Zendesk ticket fails because the user is suspended.

63.2.0

  • LetterImageTemplate.page_count is now a property which can be overriden by subclasses
  • New attributes and properties on BaseLetterTemplate (and its subclasses):
    • max_page_count
    • max_sheet_count
    • too_many_pages (requires subclasses to implement page_count)

63.1.0

  • argument image_url to LetterImageTemplate is now optional unless calling str(LetterImageTemplate(…))

63.0.0

  • Remove the technical_ticket parameter from NotifySupportTicket; replace with an optional notify_ticket_type that takes a NotifyTicketType enum value. If provided, this will maintain the existing behaviour where tickets are tagged as technical/non-technical on creation. If omitted, then tickets will have no ticket type, which may help us have a clearer process around triaging tickets.

62.4.0

  • Add class="page--first" and class="page--last" to the first and last pages (respectively) of letters rendered with LetterImageTemplate

62.3.1

  • Change logger.exception to logger.warning for log formatting error.

62.3.0

  • Adds support for Chinese character sets in letters

62.2.1

  • Injects the celery task ID into logging output if no requestId is present.

62.2.0

  • Add odd/even class to letter pages

62.1.0

  • Allow extra logging filters to be passed into notifications_utils.logging.init_app.
  • Add a UserIdFilter to automatically inject the user_id to flask request logs.

62.0.1

  • Include the country for normalised BFPO lines.

62.0.0

  • Updated PostalAddress to parse BFPO addresses. Any validation done on PostalAddresses should be update to report on the new error property has_invalid_country_for_bfpo_address.

61.2.0

61.1.0

  • Adds a method to the ZendeskClient to add a comment to a pre-existing ticket, including adding attachments.

61.0.0

  • Provide our own cache file for bank holidays data, which will help us keep it up-to-date. This is a breaking change as any apps pulling in utils should now use notifications_utils.bank_holidays.BankHolidays rather than govuk_bank_holidays.bank_holidays.BankHolidays directly.

60.1.0

  • Add letter_timings.is_dvla_working_day
  • Add letter_timings.is_royal_mail_working_day
  • Add letter_timings.get_dvla_working_day_offset_by
  • Add letter_timings.get_previous_dvla_working_day
  • Add letter_timings.get_royal_mail_working_day_offset_by
  • Add letter_timings.get_previous_royal_mail_working_day

60.0.0

  • Bump pyproj to be version 3.4.1 or greater. This changes the ESPG codes to be upper case, which affects the how Polygons class transforms data.

59.3.0

  • Add tooling to bump utils version in apps

59.2.0

  • Add support for creating redis cache keys for a specific notification type.

59.1.0

  • Add synonyms for sending letters to the Canary Islands

59.0.0

  • Remove Template.encoding (very unlikely to be used anywhere)

58.1.0

  • add a message_as_html parameter to NotifySupportTicket to enable creating tickets containing HTML (eg links).

58.0.0

  • replace brand_name with brand_alt_text in HTMLEmailTemplate to more accurately reflect its purpose

57.1.0

  • Do not log to file when NOTIFY_RUNTIME_PLATFORM is set to ecs

57.0.0

  • Breaking changes to field.Field:

    • The html argument must now be escape or passthrough. strip is no longer valid
    • The default value of the html argument is now escape not strip
  • Removal of formatters.strip_html:

56.0.0

  • Breaking: upgrade PyPDF2 to version 2.0.0. You will need to:

    • Change error class imports from pypdf2.utils to pypdf2.errors.
    • Run the tests and make changes based on the deprecation warnings.

55.2.0

  • Links in previews of text messages and emergency alerts now have the correct CSS classes added automatically
  • URLs in previews of text messages and emergency alerts will now become links even if they don’t have http:// or https:// at the start

55.1.7

  • Move some functions and variable from the notifications_utils.formatters module to the notifications_utils.markdown and notifications_utils modules. None of our apps are directly importing the functions and variables which have moved.

55.1.4

  • Downgrade min version of boto3 due to incompatibility with awscli-cwlogs dependency.

55.1.3

  • Unpin most dependencies and remove redundant ones (no action required).

55.1.1

  • Bump shapely to 1.8.0 to support Mac M1 installation of geos.

55.1.0

  • Added "delete_by_pattern" wrapper to RequestCache decorator group.

55.0.0

  • Shortened "delete_cache_keys_by_pattern" to "delete_by_pattern".
  • "delete_by_pattern" has a new "raise_exception" parameter (default False).

54.1.0

  • Add should_validate flag to notifications_utils.recipients.RecipientCSV. Defaults to True.

54.0.0

  • remove the column argument from recipients.validate_phone_number, recipients.validate_uk_phone_number, recipients.try_validate_and_format_phone_numberandrecipients.validate_email_address` (no consuming code uses this argument)
  • remove recipients.validate_recipient (consuming code already uses recipients.validate_phone_number, recipients.validate_email_address or postal_address.PostalAddress(…).valid instead)

53.0.0

  • notifications_utils.columns.Columns has moved to notifications_utils.insensitive_dict.InsensitiveDict
  • notifications_utils.columns.Rows has moved to notifications_utils.recipients.Rows
  • notifications_utils.columns.Cell has moved to notifications_utils.recipients.Cell

52.0.0

  • Deprecate the following unused redis_client functions:
    • redis_client.increment_hash_value
    • redis_client.decrement_hash_value
    • redis_client.get_all_from_hash
    • redis_client.set_hash_and_expire
    • redis_client.expire

51.3.1

  • Bump govuk-bank-holidays to cache holidays for next year.

51.3.0

  • Log exception and stacktrace when Celery tasks fail.

51.2.1

  • Revert 51.2.0.

51.2.0

  • Timeout processing CSVs to avoid timing out downstream requests

This only affects the Admin app, which should ideally rescue the exception, but just letting it propagate is also acceptable as it's similar to the current behaviour where we timeout in CloudFront.

51.1.0

  • Make processing of spreadsheets with many empty columns more efficient

51.0.0

  • Initial argument to RecipientCSV renamed from whitelist to guestlist, in other words consuming code should call RecipientCSV(guestlist=['[email protected]'])
  • RecipientCSV.whitelist property renamed to RecipientCSV.guestlist

50.0.0

  • Make icon in broadcast_preview_template.jinja2 an inline SVG (requires changes to the CSS of consumer code)

49.1.0

  • Add ttl_in_seconds argument to RequestCache.set to let users specify a custom TTL

49.0.0

  • Polygons must now be called with either shapely.Polygon objects and a valid Coordinate Reference System code for utm_crs or a list of lists of coordinates in degrees

48.2.0

  • Enable Celery argument checking for apply_async.
  • Remove redundant "kwargs" handling code for Celery Request ID tracing.

48.1.0

  • Add new NotifyCelery base class as a drop in replacement to DRY-up the "app/celery/celery.py" file we have in many apps.

48.0.0

  • Rename normalise_lines to get_lines_with_normalised_whitespace
  • Rename strip_whitespace to strip_all_whitespace
  • Remove OBSCURE_WHITESPACE variable (appears unused in other apps)
  • Remove multiple_spaces_in_a_row variable (appears unused in other apps)
  • Remove normalise_line function (appears unused in other apps)

47.0.0

  • Breaking: remove create_ticket method from ZendeskClient

46.1.0

  • Extract ticket formatting from ZendeskClient into NotifySupportTicket

46.0.0

  • Revert 45.0.0 (pyproj dependency won't install on PaaS)

45.0.0

  • Use cartesian coordinate system for polygon geometry

44.5.1

  • Split out separate too_late_to_cancel_letter function to allow reuse

44.5.0

  • Add intersects method to Polygons

44.4.1

  • Detect optional placeholders with brackets in their text

44.4.0

  • Allow Zendesk tickets to be create with internal notes

44.3.1

  • Round coordinates to 5 decimal places

44.3.0

  • Add methods to get the bounds and overlap of polygons

44.2.1

  • Normalise international numbers when formatting

Prior versions

Changelog not recorded - please see pull requests on github.