JWP Consulting GK

Projectify Development Log #4

Written on 2024-05-24

Here’s what’s new in the Projectify project management app since the last update blog on 2024-04-08.

Security

Password validation applied when changing passwords as well

The password validation logic that was added recently for new users is now also applied to users changing their current password. To reiterate, the current validation criteria are:

Please keep in mind that these criteria only raise the lowest standard for passwords. They don’t guarantee that a password is actually difficult to crack and safe from brute-forcing. At JWP Consulting, we recommend use a password manager and generating unique and random passwords for each log in account to stay safe.

Bug fixes

When creating or editing tasks, the Projectify frontend navigates back to a task’s project page, after everything has been saved correctly in the backend. I have recently added a confirmation dialog to task creation and update screens. This confirmation dialog asks the user to confirm whether they want to navigate away from a task and discard their changes.

This dialog also opens when the Projectify frontend successfully saves a task. Akin to: error, this operation has succeeded.

The confirmation logic wasn’t “aware” of why the navigation was triggered. When the user wants to leave the page and discard their changes, they might trigger it. When the app successfully saves a task, the user is redirected back to the project page. This also triggers the page navigation.

The solution was to keep track of the form’s state and to not show the confirmation dialog when the form state was “everything has been saved correctly.”

Preferred name validation

Preferred names ending on periods were falsely rejected. This affect preferred names such as Firstname Lastname Jr..

The original preferred name filtering was introduced to prevent arbitrary content injection. Before, a user could set a preferred name to be a web address or domain name. Some email clients liberally turned this into clickable URLs. This happened despite Projectify emails being plain-text only, and thus not containing any HTML.

A user could, for example, change their name to a malicious web address and send out team member invitation emails. These emails would contain clickable links that could lead a victim to click a link not belonging to the Projectify app. The origin of this problem lies beyond the realm of the Projectify app. Still, we do everything possible prevent content injections like these

Names ending on a period are not rendered as clickable URLs in an email client, and thus do not need to be rejected. I have changed the regular expression validating preferred emails in pull request #509.

Input validation remains a challenge, even when using secure frameworks. Peripheral software, such as email clients, can exhibit surprising behavior, and it’s up to us software developers to stay on top of this.

Other bug fixes

Here are some miscellaneous bug fixes added over the last few weeks:

New features

Here are some small quality-of-life updates that have been added over the last few weeks:

Thank you

Thank you to all the kind people on the internet who have been trying out the Projectify app over the last few weeks and have reported so many issues.