Release v6.11.0 (2024-06-05)
Published 2024-06-05 12:09:26Z
Server
Important
When using limited masks, nested values are protected from data loss. If a limited mask for record of an object type with nested fields A and B would only allow write access to field A, data in field B would be lost upon save. The merging of data in other fields than allowed by a mask happened on top level only (that behavior is consistent with how it was in easydb 5). See below for more details on this API change.
Group members are not automatically seeing others members of the same group. If your setup relied on that default, you need to grant that right manually by adding the appropriate
READ
permission to the ACL of the group (see below).This update brings a database update which updates all nested records in the table
value
in the database. This can, depending on the size and performance of your installation, take a few minutes.POST /api/event/list?skipConstraints=0|1
: New API to bulk import events. WithskipConstraints=1
(system.root
only) all event types can be imported. Used forfylr restore
.
New
/api/config: Added
iiif_links
andiiif_default_links
as option for the frontend to use HTML templates for the share dialog.POST /api/user?skipConstraints=0|1
: New URL-Parameter (system.root
only) to allow saving of invalid email addresses. Used forfylr restore
.
Improved
Build with PGO enabled. According to the Go blog this should give us 2-10% better performance at certain tasks. We profiled injecting new objects via POST /api/db as well as indexing which puts pressure on db loading and rendering of objects. However, measuring performance of fylr on production system is difficult as it's not only fylr doing a lot of tasks, but it usually involved i/o to data base and the indexer. Please let us know if you notice a difference on your production systems.
Set
fylr.db.maxOpenConn
to 100 infylr.default.yml
. Before we had this set to 0 which could cause a lot of connections to be opened on busy systems. In some cases fylr ran out of file handler for new TCP connections.Metadata mapping: Allow metadata mapping for
Track<n>:SourceImageWidth
. Before this wasn't possible to map due to a discrepancy inexiftool
between tag listing and actual tag out.Rights management for groups has changed: Groups do not assign
READ
rights to all members of the same group any more. This is a breaking change if your setup relies on group members seeing other fellow group members without further configuration. This now requires to manually add the desired permissions to the ACL of the group.POST /api/db does not accept empty fields any more if the mask hasn't enabled it. Before it was possible to send uneditable fields of a mask if they were zero. This was harmless but felt inconsistent, so we changed it.
POST /api/search: Support localized columns in
_fields
collector: It uses the same language which is used for sorting (order of users data languages preceded by the optionallanguage
setting of the search request) as for the collected value. To collect a specific language with no further computation a newlanguage
parameter can be used./api/config: Support
logo_external_url
to store a localized link which is followed if the user clicks on the custom logo in the fylr frontend.2-state boolean: fylr supports saving booleans in 3 states (null, false and true). This update turns booleans into 2-states in searches and for all object renderings. That means, that booleans are now always part of the object's JSON representation even if they are unset in the database. With this change search aggregations will aggregate false for booleans which are unset, resulting in a perfect sum where true and false buckets match the could of the search result.
/api/config: Output of the
produce_config
has better zero values. Arrays and string values no longer have anull
value but are output as[]
and""
resp.Docker images: The fylr docker images are both (
fylr
&&fylr-server
) based on Alpine 3.20 now. Beforefylr
was based on Alpine 3.18 andfylr-server
on Alpine 3.20. Updateimagemagick
to7.1.1-33
./api/pool, /api/objecttype: Omit output of
_acl
,_tags
,_maskfilters
,_transitions
to users withsystem.root
orsystem.poolmanager
andsystem.objecttypemanager
(resp.). Also this limitation is present in /api/search responses for all users.fylr backup & fylr restore: Support Events. Events are included in the backup now and also in the restore. For that a new API
POST /api/event/list?skipConstraints=0|1
has been added./api/db
:_last_modified
and_created
can now both be set using the API. Before only_last_modified
was writable and stored inobject.updated_at
from where it was never read. This change streamlines the usage ofobject.created_at
andobject.updated_at
in a way that fylr will now never update or setobject.updated_at
unless it is set via the API (it is ignored if it is the same asobject.created_at
)._last_modified
is now for any version eitherobject.updated_at
, or if unset theobject.created_at
._created
is theobject.created_at
of the object with version 1.
Fixed
GET /api/objects: Fixed rendering
integer.2
columns in IIIF manifests and HTML output.Rights management for files in reverse nested: When exporting files from a reverse nested, fylr failed to check the permissions properly. The permissions can be given by the top level object if a file is part of a reverse nested object even if the reverse nested object as standalone would not allow access to that file.
Rights management for system groups: If system groups would grant to users, this would not be reflected in /api/search. Users not gain the
READ
rights when granted by a system group.POST /api/search: Collecting of empty fields is now supported. If a field is empty we would skip the value before which could result in unpredictable items counts in the collected field array.
Backups of Postgres 16: When using format
pg_dump
fylr was unable to backup databases where the Postgres server was at version 16.GET /api/db
: The_created
date was wrong if the not latest version 1 of an object was requested. In that case, the_created
equaled the_last_modified
date of the latest version.
_uuid
for nested records
_uuid
for nested recordsThis API change introduces a new _uuid
field for nested records. This _uuid
is automatically created upon save, so this change is backwards compatible with existing installations.
Before, nested records would never be merged with existing data, so saving a limited mask could lead to unexpected data loss.
Existing nested data is merged, if limited masks provide a _uuid
for the sent nested records. Each record is filled with values from the currently stored record which cannot be provided by the limited mask.
Users of the API are required to send the _uuid
alongside with the nested record in order for the server to recognize existing nested. Existing implementations of the API will continue working, as the API behaves like before if the _uuid
is not sent. In that case the mode for this is replace.
To support backup & restore, _uuid
can be provided for newly inserted nested records in the payload of POST /api/db if the url parameter skipConstraints=1
is set. The _uuid
is still checked to match fylr syntax for the _uuid
. Strictly speaking this feature is not really required to make restore work, but in case we have any use for a stable _uuid
in the future it is a nice to have addition.
Webfrontend
New
IIIF Links: Added support in the frontend to display custom IIIF Links configured in the base config. If custom links are configured, they will be shown in the object's share panel. These custom links can display the embed code that can be copied to an external page.
Nested Tables UUID: Added support in the frontend for the new fylr feature, UUID in nested elements.
Logo External URL: Now an external link can be configured in the custom logo in the base config.
Improved
Nested Table and Limited Mask: Improved frontend functionality with nested tables when the mask is configured so that not all fields of the nested table are visible or editable.
Main Menu: Made visual corrections in the main menu.
Admin Messages: Now if a permanent message (tray app message or main menu message) contains only a link in the message, this link will be opened without showing the popup message.
Search Queries: Made visual corrections to the special operators (AND, OR, etc.) to make them easily identifiable.
PDF Creator: Now PDF printing is compatible with the table view for nested fields.
Fixed
MetadataMapping: Fixed bugs in the metadatamapping when the elements being mapped are within a nested table.
System Tags: Fixed an issue where the frontend attempted to obtain a custom color for system tags when they were displayed in the filter panel.
Tag Icons: Fixed the display of tags that only show an icon in the search results.
Nested Tables: Fixed a bug where if a field within the nested table was read-only, it could cause all fields to be non-editable when adding new elements to the nested table.
Asset Broker: Made visual corrections for assets marked as hires.
Export Groups: Added support in the export manager for asset groups.
"About This" Panel on Main Menu: Updated the "About This" panel in the main menu to require root permissions for display.
Filepicker: Fixed various issues in the filepicker class to make it compatible with fylr. This class is used in plugins like Drupal, Typo3, etc.
ACL Manager: Fixed scaling issues of the ACL popover.
CSV Importer: Fixed a bug where numeric data was not correctly matched when importing multiple rows of a nested table.
Event Poller: Improved the behavior of the WebSocket event poller. Now, if the frontend loses connection with the server, a non-intrusive message will notify the user that it is attempting to reconnect. If the connection is restored, the user can continue using the application normally without needing to reload the web page.
CSV Importer: Fixed a bug where, if indices of a nested element were specified and it didn't have all cells with values, empty values were sent at the end of the array.
CSV Importer: Fixed the search of linked objects when more than one identifier field is given.
Custom Validation Errors: Fixed a bug in custom validation errors check on the frontend.
Script Executer: Fixed the metadata downloader plugin for Script executer. The plugin outputted wrongly formatted strings, producing corrupted CSVs. Also, the filter value feature was not checking metadata values properly.
CSS: Made numerous style corrections in the application.
Default Tags: Fixed the addition of default tags when opening a new object editor and when updating the editor.
Last updated