Refringe 52172f2953 InsuranceController Quality and Maintainability (!148)
This pull request aims to refactor the InsuranceController class to improve its code quality and maintainability. The changes include restructuring methods, adding detailed comments, and enhancing the overall logic for processing insured items.

Specific changes include:

- Updating the `findItemstoDelete()` method (and the entire class, really) to keep track of which items are tagged using a Set. This *ensures* that an item can only be attempted to be deleted once, as Sets cannot contain duplicates.

- Changing the method in which we remove insurance packages from the profile. We were iterating over them using a `for` in reverse order and then removing them with a splice and the current index. On paper this should work, but funny things were happening... Sometimes. I've created a new method that removes packages from a profile by matching against the package systemData date, time, and location. This should give us a specific insurance package (as we don't have an ID to use). In addition to this we're fetching a new instance of the profile to edit, instead of modifying packages that are being iterated over as they're being iterated over.

-----

I was unable to reproduce the issue where insurance packages were not being removed from the profile, but hopefully these simplified approaches lead to less funny business.

Co-authored-by: Refringe <brownelltyler@gmail.com>
Reviewed-on: https://dev.sp-tarkov.com/SPT-AKI/Server/pulls/148
Co-authored-by: Refringe <refringe@noreply.dev.sp-tarkov.com>
Co-committed-by: Refringe <refringe@noreply.dev.sp-tarkov.com>
2023-10-12 08:38:22 +00:00
..
2023-10-10 11:03:20 +00:00
2023-10-10 11:03:20 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-10-10 11:03:20 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-10-10 11:03:20 +00:00
2023-03-03 15:23:46 +00:00
2023-10-10 11:03:20 +00:00
2023-10-10 11:03:20 +00:00
2023-03-03 15:23:46 +00:00
2023-07-15 10:43:09 +01:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00
2023-03-03 15:23:46 +00:00