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:
- The password can’t resemble other personal information like the user’s email address
- The password must contain at least 8 characters
- The password can’t be a commonly used password
- The password can’t be entirely numeric
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
Navigation confirmation shown incorrectly when editing tasks
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:
- The error page would not correctly distinguish between 404-like errors and other errors, such as page render errors. This was fixed.
New features
Here are some small quality-of-life updates that have been added over the last few weeks:
- Image asset optimization using Svelte’s enhanced:img was added. This makes pages lighter and faster to load.
- A sitemap is now rendered to ease crawling public facing pages.
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.