Release Notes
The list below shows the latest releases and the respective features/improvements to Axinom Mosaic.
R113 (January 16, 2025)β
Generalβ
π§Ή Dependency spring cleanupβ
In this release we updated quite a few dependencies to address security vulnerabilities and to keep the services up-to-date. We raised dedicated PRs for each CVE that was addressed. You can find the full list of PRs on the GitHub repository. With this we tried to make it easier for you to apply the changes to the copy of the services in your repository. You can also use the CVE number to find out more about the vulnerability to make your own decission if and how to fix it best for your situation.
We strongly advice to enable vulnerability scanning also on your own repositories to get notified about security issues in your dependencies and not only rely on the updates we provide, as these would e.g. not cover dependencies that are only used in your custom services.
π‘οΈ Support for custom IDPs in the Management Systemβ
It is now possible to add a 'Custom' identity provider on the Identity Service configuration that allows using any other OIDC compliant identity provider.
You can find more information on how to configure a custom identity provider in the Identity Service documentation.
π‘οΈ Improved support for Microsoft Entra ID IDP in the Management Systemβ
It now takes even less steps to enable the Microsoft Entra ID
provider for the Mosaic Management System. With a simple toggle you can allow all users with a Microsoft work or school account to authenticate to the Management System. You can read more about this option under the ID Provider configuration documentation
π·οΈ Improved Select
and Tags
componentsβ
We changed the Select
and Tags
components to allow the users to type the value they are looking for and the component will automatically filter the options to match the input. This makes it easier to find the right value, especially in long lists of options.
Of course it will still only be possible to select values that are part of the list of options.
The styles also got updated to make the components more aligned with the rest of the UI components.
In many cases this update is just a drop-in replacement that will not require any changes in your code. However, in some cases it might require some small code adjustments:
- The type definitions of
onChange
,onBlur
, andonFocus
have been changed from(event: [FormEvent<HTMLSelectElement>) => void
to(event: ChangeEvent<HTMLInputElement>) => void
- Any CSS styles that are targeting the
select
element will need to be refactored to target theinput
element. - The
Select
is now a controlled component. Therefore, thevalue
property needs to be provided.
Librariesβ
- @axinom/mosaic-ui: Fixing an issue that made the the DynamicDataList stop rendering the action column when
allowEditing
was set totrue
andallowNewData
was set tofalse
. - @axinom/mosaic-ui: Fixing an issue with
SingleLineText
where inputs were ignored whenisSet
was set totrue
. - @axinom/mosaic-ui: Improved the placeholder text for the
FileUpload
component to make it more clear that the user can drop files there.
Managed Servicesβ
- Video Service: The encoding history was moved from a decicated station to a tab on the video details station.
- Image Service: Fixed an issue with focal point selection in quick edit mode.
Customizable Servicesβ
- Media Service: Fixed an issue where the ingest items would disappear when the user stays on the page and the jobs complete in the background. #396
- Media Service: Fixed a broken unit tests caused by additional properties that Image and Video service started to send. #401
- Media Service: Adding a uniqueness check for geners to the genere stations, to not only rely on the database constraints. #354
- Media & Channel Service: Adding quick edit to all publishing related stations #388
R110 (November 21, 2024)β
Librariesβ
- @axinom/mosaic-service-common: The
setupMonitoring
method of@axinom/mosaic-service-common
now accepts an optional express app as a configuration option (passed in via themonitoringOptions
parameter). This enables the metrics middleware to be mounted on an existing express app instead of always mounting it on a new app in a separate port. - @axinom/mosaic-ui: Fixed two issues where the
data-test-id
of columns inList
components were not correctly applied. - @axinom/mosaic-ui: Fixed an issue that prevented validation errors on
DynamicDataList
entry components created usingcreateSelectRenderer
from being displayed correctly.
Managed Servicesβ
- Hosting Service: Added a more prominent station message to the detail station of services "Owned by Axinom" that makes it more clear, how much time is left until the service will be automatically terminated. Keep in mind, that it is possible to extend that time by redeploying the service.
- Localization Service: Adding Quickedit to the stations genrated by the localization generator.
- Image Service: The
ensure_image_exists_image_created_event
as well as theensure_image_exists_already_existed_event
now also contains the sourceimage_location
. - Video Service: The
ensure_video_exists_creation_started_event
as well as theensure_video_exists_already_existed_event
now also contains the sourcevideo_location
. - Identity Service: Fixed an issue where the default display values for the IDP confgurations were not always correctly set.
- Identity Service: Hide the "Sign in with Axinom" option when running the solution locally. Currently the Axinom IDP does not support authentication for local development environments.
Customizable Servicesβ
- Media Template: Bumped versions of
loader-utils
to address security vulnerabilities. #376 #377 - Media Template: Improved the
open-test-coverage
script to address a potential vulnerability. #378 - Media Service: Adding three more default Movie and TV Show genres. #381
- Media Service: Adding the
alt_text
provided by the Image Service to the published data of entities. #379 - Media Service: Adding QuickEdit to Channel Workflows, Media License- and Ingest-Stations. #384
R108 (October 22, 2024)β
Generalβ
In this iteration of authentication improvements for the Management System, we added support to configure Custom Branding for the Identity Providers that are used by the Management System. This means you will be able to control the Display Name
, Display Icon
as well as the display order
for the external Identity Providers. As part of the same initiative, we've now improved the User Experience of the Admin Portal to find all Identity Provider related configuration under a single station.
To find out more about the new settings, check out the Identity Provider Settings documentation.
Librariesβ
- @axinom/mosaic-ui:
InfoImage
now also accepts all properties ofImageLoader
.
Managed Servicesβ
- Image Service: Adding an "Alt Text" property to images. This property can be used to provide a textual description of the image content.
- User Service: Rolling out quick edit to user workflows.
- Video Service: Rolling out quick edit to profile management workflows.
- Image Service: Rolling out quick edit to image workflows.
- Localization Service: Rolling out quick edit to localization workflows.
R106 (September 26, 2024)β
Librariesβ
- @axinom/mosaic-ui: Truncated titles on
PageHeader
components now show a tooltip with the full title when hovered over. - @axinom/mosaic-ui: Fixing an issue that can cause incorrect text wrapping when using custom renderers on
List
components. - @axinom/mosaic-ui: Fixing issues with unneccesary re-renderes of the Quick Edit components.
- @axinom/mosaic-ui: Fixing an issue with actions on the
Explorer
header sometimes not always rendering with correct spacing. - @axinom/mosaic-ui: Fixing an issue that could cause station messages of a FromStation to render with wrong size.
- @axinom/mosaic-id-link: Fixing a few visual issues on the new Login Screen.
Managed Servicesβ
- ID Service: Adding Quick Edit to the Access Management workflows.
- AxAuth Service: Fixing an issue with the token renewal not working correctly.
Customizable Servicesβ
- Media Service: Fixing an issue where the 'Open' button on the Collection's 'Manage Entity' Quick Edit station was not leading to the appropriate station. #368
R105 (September 09, 2024)β
Quick Editβ
With this release we're launching our new Quick Edit feature! π
This feature allows editing entities directly from inside the Explorer station. This will make it easier to quickly change values of individual entities, e.g. from a filtered result, without having to navigate to the Details station of each entity.
We designed the feature to be very easily adaptable to your custom services, allowing to reuse your existing detail stations for quick editing. The majority of the feature is provided by the UI library. Make sure you update to the latest version, to gain access to this feature. You can see the changes required to enable the feature on a customized Explorer station on the PR with which we introduced the feature to the media template: #359 & #362
We're going to add Quick Edit support to more stations in the future, so stay tuned for more updates!
To find out more about Quick Edit and how to integrate it into your own workflows, check out the Quick Edit documentation.
Authentication Improvementsβ
We're planning a series of improvements related to user authentication into the Management System that will be released gradually.
As part of this initiative, The Mosaic Identity Service now received support for a new Identity Provider.
You may now enable the new Axinom IDP
under the ID Service configuration of the Admin Portal
, and doing so would allow you to use your existing Axinom credentials in a Single Sign-On manner to Sign In into the Management System. No need for any 3rd party account or additional registration to access the Management System.
With this release we're also unveiling a reworked UI for our AxAuth
IDP. This is the Mosaic own Open ID Connect compliant identity provider for email & password based authentication. This provider, if enabled, will directly show email & password fields on the login masks, making it more natural to use while maintaining the same level of security.
When you're doing local development, and running workflows, if you notice a warning signalling your @axinom/mosaic-portal
dependency can be upgraded, the management-system authentication of the localhost
application will not work until you perform this upgrade step. If not, you may see a Configuration not valid
error in the management system running on localhost
.
Librariesβ
- @axinom/mosaic-ui: Added the
quickEditRegistrations
property that can be used to register the Quick Edit stations the Explorer should provide. If there is at least one registered Quick Edit, a new Header action will be shown to enable Quick Edit mode and switch between the different Quick Edit stations. - @axinom/mosaic-ui: Added support for the
FormStation
component for getting rendered as Quick Edit component. Apart from some visual changes (hiding the actions and info panel to gain more space and optionally displaying an action to navigate to the Details station), theFormStation
also makes sure that saving and error handling works correctly also in Quick Edit mode. This means, that if you have a FormStation that is registered as a Quick Edit station, you can use the same FormStation for both Quick Edit and Details mode. - @axinom/mosaic-ui: The Filter Panel can now be hidden using a Header action button, to provide additional space. Switching to Quick Edit mode will hide the Filter Panel by default.
- @axinom/mosaic-ui: We moved the 'Save' button into the header of the
FormStation
component, to make it visually more clear that this button is used to save the form. Forms will still be saved also automatically when the user is leaving the station.tipTo avoid inconsistencies between managed and custom workflows, we recommend to update the UI library to the latest version.
warningThe global save indicator is still supported for backward compatibility, but it is deprecated and will be removed in the future.
Managed Servicesβ
- All: Unique constraint errors throw by all managed services now have an error code
UNIQUE_CONSTRAINT_ERROR
. Previously they were thrown withDATABASE_VALIDATION_FAILED
code. This will allow front-ends to better narrow the reasons for backend exceptions that are thrown due to duplicate keys. - Video Service: Added Quick Edit views for Video Details, Video Preview and Cue Point Management.
Customizable Servicesβ
- Media Service: Added Quick Edit views for Details and Assignment in Movies, TV Shows, Seasons, Episodes and Collections. #359 & #362
- Catalog Service: Fixing an issue where entities were returned without values, when localization was enabled and the default locale was not named 'default'. #357
R103 (August 22, 2024)β
Librariesβ
- @axinom/mosaic-ui: The
FreeTextFilter
now automatically selects the previous value when the user clicks on the filter to change the value. This makes it easier to replace the previous value with a new one. - @axinom/mosaic-workflow-integration: Added a
TileNames
enum that contains the names the managed services use to register their tiles and navigation entries.
Managed Servicesβ
- Video Service: Adding support for Visible Video Watermarking to the Video Service. This feature allows you to add a visible watermark to your videos during the encoding process. The service offers a workflow for defining watermarking profiles. These profiles can then be selected on an encoding job to apply the watermark to the video. The feature is available through the Video Service API as well as the management system.
- Video Service: Audio representations can now be defined in the processing profile.
In the Encoding Service API, all the fields in the audio representations are optional β if they are omitted, the default values are set by the service. - Hosting Service: Enhanced Error Reporting. When a deployment fails due to a misconfiguration (e.g., missing environment variables), the Mosaic Hosting Service will now display the logs that were produced by the failing service. These logs will be visible in the 'Deployment Logs' station under the
K8sDeploymentErrorEvent
type in your Admin Portal (inside the 'Hosting Service' area). This will now help you identify causes for the failing service and attempt to fix them with a new deployment more easily. - Video Service: Changed the DRM Settings -> Management API URL to a select field with predefined values for the production and test environments of the Axinom DRM service.
- Video Service: Fixed a problem with duplication validation of cue point timestamps.
Customizable Servicesβ
- Catalog Service: Changing the way how catalog service handles localized values to make it more performant and versatile. #317
- Channel Service: Removing the publish validation check for possible DRM protection of videos added to a playlist. Before it was considering the playlist invalid if a DRM protected asset was added to a channel that doesn't have DRM protection enabled. Now publishing is possible independent of the asset's and channel's DRM configuration. #344
- Channel Service: Fixing an issue that reverted a channel to 'changed' state after a successful publish. #345
R101 (July 29, 2024)β
Generalβ
The Mosaic Channel Service allows the management of channels and playlists to stream linear videos. It allows for scheduling media entities (movies and episodes) with their videos into playlists and inserting ad breaks and scheduled videos. Channels can be used to provide VOD-to-Live playback via streaming providers like Unified Streaming.
Starting with this release, the Channel Service is available as a customizable service included in the media template. This allows complete customizability of all aspects of the FAST solution.
To find out more about the service, check out the documentation.
Librariesβ
- @axinom/mosaic-workflow-integration: We changed the way how the library gets initialized.
Instead of having different
set...
functions to provide the app object to the library, there is now a centralinitializeIntegrationLib
function to initialize all functions of the library at once. The new initialization process allows us to also improve the usabiltiy of the Thumbnail renderer and Video Cue point functions. To find out more, please check the documentation of the library. - @axinom/mosaic-ui: We removed the
BulkActions
property on the thePageHeaderProps
and the component now expects all actions being declared via theactions
prop, which now has the ability to definePageHeaderActionGroup
as well asPageHeaderSpacer
items. When using thePageHeader
through any of the station components (Explorer
,Create
,Details
) nothing will change. But it allows for more 'BulkAction-like' groups to be defined in thePageHeader
component itself. - @axinom/mosaic-ui: Added a new prop to
List
,Explorer
andDynamicDataList
for control thetextWrap
. When set totrue
, it will make the content of the cell wrap to the next line instead of truncating it. - @axinom/mosaic-ui: Fixed an issue where the content alignment props on
DynamicDataList
were not working correctly.
Managed Servicesβ
-
Identity Service: The service will publish the
ServiceAccountPermissionChanged
event whenever a service-accountβs permissions are changed (Added/Removed).This would enable more use-cases for custom-services developers to cache JWTs produced by service-accounts for longer durations (i.e. using the
generateLongLivedToken
function), and listen to the above event to understand the correct point-in-time to invalidate the cached JWT of a service-account. -
Video Service: Added support for specfiying the "Required Media" in the Processing Profiles. This can be used for example for audio-only encodings.
Customizable Servicesβ
- Media Service: Fixed an issue where the last modified date on Move/TVShow Genre pages was showing a wrong value. (https://github.com/Axinom/mosaic-media-template/pull/312 )
- Media Service: Adjusted the workflows to use the new APIs from the
@axinom/mosaic-workflow-integration
library mentionied above. (https://github.com/Axinom/mosaic-media-template/pull/320 ) - Channel Service: This service was added to the media template. (https://github.com/Axinom/mosaic-media-template/pull/308 )
R99 (June 25, 2024)β
Librariesβ
-
@axinom/mosaic-ui: It is now possible to unselect items after the "select all" option was used. The checkboxes on the data rows will get enabled, once the data is exhausted (meaning there are no more pages to load). If the list is not exhausted yet, the checkboxes will stay disabled as in this case actions are expected to be performed on the whole list (including potentially unloaded items). Once the list is exhausted, the selection event will switch to a mode where it will enumerate the individual selected items to perform the action on.
The
Explorer
component uses that mode by default, wheneverenableSelectAll
is set totrue
. ForList
components the behavior can be enabled by setting theenableSelectAllDeselect
totrue
.
Managed Servicesβ
- Video Service: Videos can now be deleted. To delete a video, the user role or service account that is used must have
Videos: Edit
ANDVideos: Delete
permission, or justAdmin
permission for the Video Service.- Deletion can be done via the UI (from the video details station or the video explorer station) or directly via the GraphQL API (
deleteVideo
andstartVideosDeletion
mutations). - You can also send a
DeleteVideo
command. If the video was found and was successfully deleted aDeleteVideoFinished
event will be sent that you can subscribe to. If the video deletion failed aDeleteVideoFailed
event will be sent. If an attempt to delete a video is made, but this video does not exist (anymore) the operation will still succeed, but no events will be sent.
- Deletion can be done via the UI (from the video details station or the video explorer station) or directly via the GraphQL API (
Customizable Servicesβ
- Media Messages: Weβve extended the doc types on the message payloads defined in the media-messages library to include information about the used aggregate-id and type. This will make it easier for consumers and producers of the messages to understand the values expected for each message. https://github.com/Axinom/mosaic-media-template/pull/315
- Media Service: Fixed an issue with genre localizations not always being synchronized correctly https://github.com/Axinom/mosaic-media-template/pull/310
- Media Service: Fixed an issue where the TV show genres station was not rendering successfully when the genre list was empty. https://github.com/Axinom/mosaic-media-template/pull/311
R98 (June 6, 2024)β
Generalβ
Media Template Bootstrappingβ
With this release weβre introducing a new, improved way to bootstrap custom solutions based on our media template. This process is powered by the Mosaic CLI and will guide users through the setup process, allowing to customize the experience to their needs. Weβre planning to add further improvements to this process in the future, so stay tuned for more updates.
If youβre new and want to setup a new custom solution, please follow the instructions documented in the getting started section on the media template introduction docs.
If you want to learn more about the command and itβs options check out the mosaic-cli documentation.
Postgres 16.2β
We now support Postgres v16.2 as the database version for Media Template. Please follow the below steps to migrate your existing local environment to the new version (your data will be preserved):
- Make sure your media-template repository is up to date with the latest changes. Especially the changes from this PR
- Run
yarn run env-cmd --silent -f .env ts-node scripts/create-data-dump.ts
from Media Template root. - Run
yarn infra:down
- Delete the Docker volume related to Postgres (
docker volume rm infra_postgres_data
) - Run
yarn infra:up --build
- Run
yarn db:reset
- Run
yarn run env-cmd --silent -f .env ts-node scripts/import-pg-dump.ts
from Media Template root.
Librariesβ
-
@axinom/mosaic-cli: Fixing some commands that were not crrectly returing a non-zero exit code in case there was an error. This will make it easier to use the CLI in automated scripts.
-
@axinom/mosaic-message-bus: We have made adjustments to the
@axinom/mosaic-message-bus
library to create the delay queues of Quorum type instead of Classic type. This will ensure the messages in those queues will have higher reliability and fault tolerance.However itβs not possible to simply change the type of a RabbitMQ queue from Classic to Quorum. Therefore, weβve changed the name of the delay queues from
delay:10sec
,delay:30sec
todelay:10s
,delay:30s
. After upgrading to the latest message-bus library, the services will start using the newly named queues, and the older queues will remain unused/unconsumed.The services will not need any changes, however the remaining unused queues (
delay:10sec
,delay:30sec
) can be deleted via the RabbitMQ Management UI.
Managed Servicesβ
- Image Service: Images can now be deleted. To delete an image, the user or token that is used must have
Images: Edit
ANDImages: Delete
permission, or justAdmin
permission for the Image Service.- Deletion can be done via UI (from Image Details station or Images Explorer station) or directly via the GraphQL API (
deleteImage
andstartImagesDeletion
mutations), - You can also send a
DeleteImage
command. If the image was found and and successfully deleted aDeleteImageFinished
event will be sent that you can subscribe to. If the image deletion failed aDeleteImageFailed
event will be sent. If an attempt to delete an image is made, but this image does not exist - not found - the operation will still succeed, but no events will be sent.
- Deletion can be done via UI (from Image Details station or Images Explorer station) or directly via the GraphQL API (
- Image Service: Fixed an issue that prevented the Altair client to work correctly.
- Localization Service: Fixed an issue with the validation of language tags in Localization settings.
- Localization Service: Fixed a racing condition where localization values created immediately after the source entity registration were sometimes not saved correctly.
Customizable Servicesβ
- Media Service: We improved the ingest process to be more resilient on large ingests, able to handle more entities at once, improved the progress reporting, and have improved error handling. (https://github.com/Axinom/mosaic-media-template/pull/291 , https://github.com/Axinom/mosaic-media-template/pull/293 , and https://github.com/Axinom/mosaic-media-template/pull/295 )
- Media Service: Messages the service uses to send to itself (e.g. during ingest) are now directly stored in the inbox table and wonβt do a detour over the RMQ anymore (https://github.com/Axinom/mosaic-media-template/pull/292 )
- Media Service: We updated the version of the Altair package (https://github.com/Axinom/mosaic-media-template/pull/303 )
- Media Service: We updated the version of the pg-transactional-outbox package (https://github.com/Axinom/mosaic-media-template/pull/307 )
R96 (May 6, 2024)β
Breaking Changesβ
Removed APIsβ
We now have removed the deprecated events from the ID Service:
UserDeleted
UserRoleDeleted
ServiceAccountDeleted
Please refer to Planned Deprecations page to see the new events you may use instead.
Librariesβ
- @axinom/mosaic-cli: A new CLI command
mosaic service purge-permissions
is introduced, which can be used to purge permissions from ID Service for a given Mosaic Service. More info can be found in the @axinom/mosaic-cli documentation. - @axinom/mosaic-ui: We introduced a new
Tabs
component. This component can be used to structure the fields on detail pages. To find more about the control and some general things to keep in mind when designing workflows using this component, check out the Storybook.
Managed Servicesβ
-
Video Service: The
video-select-field
microfrontend extension now has a new optional propertypredefinedFilterValues
that can be used to specify additional filters that should be applied to the list of videos that users can pick from. -
Video Service: The preview station now contains an optional video player allowing to preview videos directly in the management system. This feature can be configured in the video service settings on the admin portal.
-
Hosting Service: Hosting Service now supports assigning custom DNS labels to services hosted by it that makes it possible to have more predictable URLs for the deployed services. You can find the new field in the details station of your customizable service. Please note that the custom DNS labels are globally unique, and therefore will be assigned on a first-used basis.
-
Management System Service: Added an option to replace the welcome message on the home screen as well as the logo on the top right of the management system shell with a custom component. To find out how, check out the documentation
Customizable Servicesβ
- Media Service: We updated the piral package to version 1.5.2, which matches the version the Mosaic Portal is using. This update should not have any impact on the existing services, but it is recommended to update the piral package in your services to the latest version to avoid any potential issues. (https://github.com/Axinom/mosaic-media-template/pull/287 & https://github.com/Axinom/mosaic-media-template/pull/288 )
- Media Service: We added a new environment variable
IS_LOCALIZATION_ENABLED
to the media workflow package. This variable will affect whether the localization sub stations on the entity details will be shown or not. (https://github.com/Axinom/mosaic-media-template/pull/284 ) - Media Service: We removed the unnecessary permission check for the events the service receives as answer for the LocalizeEntity command which complicated the process when trying to setup the service from the scratch. (https://github.com/Axinom/mosaic-media-template/pull/277 )
- Media Service: Message handlers in the media service are using a database clients with the owner permissions to be able to change also those values that cannot be changed via the login database role. The field names in the handler suggested incorrectly, that the database login pool is used in message handler. We changed the argument names to "ownerClient" to avoid confusion. (https://github.com/Axinom/mosaic-media-template/pull/278 )
R94 (April 10, 2024)β
Generalβ
With this release weβre launching our new Localization Service! π
This service enables you to manage the different localizations of the metadata of your entities and ultimately shipping them to your users. To learn more about the service check out its documentation here.
We integrated support for it into the Media and Catalog Service (more details below), but the service is not limited to these services. If you want to use it in your custom service, please check out the this article that explains how to extend your entities with localizations.
Librariesβ
- @axinom/mosaic-ui: Fixed an issue with the Dynamic Data List, where changes to the position of an item using the text input were not applied correctly.
- @axinom/mosaic-ui: Explorers in selection mode now reset their selection when the filters are changed.
Managed Servicesβ
- Hosting Service: When storage credentials are regenerated through the Admin Portal, the Hosting Service now emits an event
ObjectStorageCredentialsRegenerated
. Interested services can listen to this event and update any stored management tokens etc. using Hosting Service GraphQL API to keep the storage credentials up-to date. - Hosting Service: Now the services deployed via the Hosting Service will receive a performance boost during executing DB Queries that uses
ILIKE
statement (such as when using filter queries for text fields) since they are able to use existing GIN INDEXes for improving query performance when Row Level Security is enabled. This is achieved by automatically marking thepg_catalog.texticlike
function asLEAKPROOF
. - Hosting Service: The Mosaic Hosting Service no longer grants the
policymaker
role to RMQ Users it generates and instead will grant themanagement
role. If you require specific policies to be configured for your RMQ vhosts, please get in touch with our support team, so we can help you out.
Customizable Servicesβ
-
Media & Catalog Service: We added localization support for all publishable entities (Movie, TV Show, Season, Episode, Collection, Movie Genre, TV Show Genre).
We changed the Catalog Service by moving localizable properties into a separate related table, e.g. title, description, and synopsis are no longer part of the
movie
table, but are moved tomovie_localizations
related table. The GraphQL API remains unchanged, as dedicated views are implemented to expose localizable properties on the level of parent entity.Localization is an optional feature in the Media Service and can be enabled/disabled using the
LOCALIZATION_IS_ENABLED
environment variable. When disabled, entity definitions and changes from the Media Service will not be synced with the Localization Service, and only base values will be published instead of base values and localizations.noteIn order for localizations to be enabled, the Localization Service must be enabled on the environment and the
LOCALIZATION_IS_ENABLED
environment variable needs to be set totrue
.After these changes are applied to an existing media-template repository and there is an intention to enable localizations, the following migration steps must be done:
-
The existing media-service service account must be adjusted to include "Source Entities: Edit!, "Entity Definitions: Edit", "Localized Entities: Edit", and "Localized Entities: Review" permissions of the Localization Service. For a local development, this can be done by running `yarn setup`` script to (re)create the service account.
-
Once the Localization Service is enabled in both Admin Portal and Media Service (via the
LOCALIZATION_IS_ENABLED
env var) and successfully launched, the previously existing entities can be migrated to become localizable using a dedicated migration script located atservices\media\service\src\_manual-repair-scripts\register-localization-sources.ts
The majority of the changes were added via PR https://github.com/Axinom/mosaic-media-template/pull/164
- The support for ingesting localized values was added with PR https://github.com/Axinom/mosaic-media-template/pull/211
-
-
Media Service: We added a refetch configuration to the mutations on the detail stations to make sure the form data also updates correctly when the save is performed by an action that does not navigate the user away from the page. (https://github.com/Axinom/mosaic-media-template/pull/269 )
-
Media Service: We adjusted the titles of some Explorer stations to be more consistent (https://github.com/Axinom/mosaic-media-template/pull/267 )
-
Media, Catalog, Entitlement, Vod-to-Live Service: The services were updated to use the latest
service-common
library, specifically now we use the updatedsetupMonitoring
method of this library that will ensure if there will be any errors of a single metric during its collection, the other successfully collected metrics will be available in the registry. Instead an error log will be generated to be investigated separately. (https://github.com/Axinom/mosaic-media-template/pull/263 )
R93 (March 25, 2024)β
Generalβ
With this release weβre introducing a new pattern on how the media, catalog and entitlement service handle messages. The services are now using a Transactional Inbox/Outbox pattern. The classical way of processing messages is in general still supported, but we encourage the use of the new pattern to get a more reliable and consistent message processing. We have a more detailed explanation of the pattern in the Messaging documentation, but here are the sections that describe the general idea:
Transactional Outbox
In Mosaic, the transactional outbox pattern is utilized for reliable message sending from one service to itself or other external systems. When a service needs to publish an event or command, it first writes the message details to its outbox table within the same database transaction as the business logic. This ensures the messageβs atomicity and durability together with the associated business data. The message publisher of that service polls then this outbox table and sends the messages via the actual RabbitMQ messaging broker.Transactional Inbox
On the receiving end, services in Mosaic employ the transactional inbox pattern to process incoming messages reliably and efficiently. Messages are retrieved from the RabbitMQ queue and stored exactly once in the inbox database table. The associated business logic is then executed within the same database transaction that marks the inbox message as processed. This guarantees that the message is processed exactly once, even in the event of failures or system restarts.
The very changes to the three services on the media template can be seen on PR https://github.com/Axinom/mosaic-media-template/pull/219 .
Librariesβ
- @axinom/mosaic-ui: The UI library will now be smarter about the
<style/>
elements it injects into the DOM. A UI library instance will only add the styles if they were not already added by another instance. Different versions of the library will still define styles that differ individually. This change makes the DOM more lightweiht and improves the developer experience when trying to tweak styles on the fly using the browserβs developer tools. - @axinom/mosaic-portal: When pressing the save button in the management system, the application will not create another entry in the browser history. This will make it easier to navigate back to the previous page after saving a form.
- @axinom/mosaic-service-common: The service-common library now includes an express handler to add the Axinom Mosaic
favicon.ico
to express applications. This can be done viaapp.use(mosaicFavicon);
- @axinom/mosaic-service-common: The
assertError
helper function is deprecated in favor of a newensureError
helper function.
Before |
After |
---|---|
|
|
Managed Servicesβ
- Video Service: The Video Service message handlers for bulk archiving and bulk unarchiving videos send out an
ArchiveVideosFailedEvent
andUnarchiveVideosFailedEvent
message in case the (un)archiving fails. The import custom videos message handler will now send anImportCustomVideoFinishedEvent
message when the import is successfully done and anImportCustomVideoFailedEvent
in case the import fails. - Image Service: When the
ArchiveImagesCommand
or theUnarchiveImagesCommand
Image Service fails to handle the archive/unarchive message they send out the correspondingArchiveImagesFailedEvent
andUnarchiveImagesFailedEvent
messages.
Customizable Servicesβ
-
Entitlement Service: Maxmind has introduced a daily download limit for their GEO IP databases. If your entitlement service is deployed in a scalable way or deployed/restarted often that limit can be exceeded. To avoid this limit Maxmind suggests downloading their database with your license key to some shared repository or setting up a proxy cache from where your services download the database.
You can set the URL of such a proxy in the environment variable
GEOLITE2_DOWNLOAD_URL
for your Entitlement Service. https://github.com/Axinom/mosaic-media-template/pull/261 -
Entitlement Service: We bumped the
geoip-country
package version to fixed a bug that caused entitlement-service to crash shortly after start-up. This was caused due to a change in the MaxMind API and the library which accesses the API to fetch the geoip-country list not being updated to handle the changed API. https://github.com/Axinom/mosaic-media-template/pull/256
R92 (March 13, 2024)β
Generalβ
- This release implements a few improvements around the way how data is saved in the management system workflows. You can find a more detailed description of concept for saving in the Saving article.
- The management system browser tab title now dynamically adapts to the page that is currently open. This makes it easier to distinguish between different tabs when you have multiple tabs open in the same browser window.
Out of the box it will use thetitle
that is being set on thePageHeader
component of the station. Stations can also set a custom page title by using thesetTitle
method on thePiralAPI
object. To make it not conflict with a potentialPageHeader
, the automatic setting of the page title by thePageHeader
can be disabled by settingsetTabTitle
tofalse
.
To enable that feature for your custom workflows you need to update the UI library to the latest version. - We improved the user experience when configuring profiles on video and image service that are using storages coming from the hosting service. If you have hosting service storages already enabled, you can directly pick the container from the containers available on your storage. If you have not enabled the hosting service storages yet, the UI will guide you through the process of enabling them. To find out more, check out the hosting service documentation.
Librariesβ
- @axinom/mosaic-ui: The
FormStation
components will now add an asterisk to the page title, if the form has unsaved changes, making it easier to understand whether a from is dirty or not. This will also be reflected in the browser tab title. - @axinom/mosaic-ui: Added a toast notification when a form was saved successfully. This will help users to better understand when a saving operation was happening, e.g. when navigating away from a dirty form.
- @axinom/mosaic-ui: Added a new
FormGrid
component. This can be used to replicate the styles applied to the children of theFormStation
. - @axinom/mosaic-graphql-common: Weβve added a new Express middleware
forwardToGraphiQl
, which will redirect browsers requesting the/
as well as/graphql
route of a service to the/graphiql
endpoint. This will make it easier to access the GraphiQL interface of a service. We added this middleware to all our managed services as well as the services in the media template (see https://github.com/Axinom/mosaic-media-template/pull/250 ).
Managed Servicesβ
- Management System Service: We tweaked the look and feel of the save indicator to make it more clear what the state of the from and saving process is.
- Management System Service: We changed the favicon of the Management system to the Mosaic logo.
- Image Service: Previously, if you would request an image of a specific width and height from the `/transform`` API, and these values exceeded the size of an original image the returned image would have been up-scaled. This is no longer happening. If at least one of the requested dimensions is greater than the same dimension of the original image, the returned image will be transformed to match the aspect ratio of the requested dimensions, but will not exceed the original image. If upscaling was previously expected to happen by the image service, it should not be handled by other means. E.g. browsers built-in upscaling mechanisms.
- Image Service: Adding the image transformation base url to the image details station making it easier obtainable for users of the management system.
- Image Service: If an image with a name that is longer then 100 characters is uploaded or imported using the
EnsureImageExits
message, the image service will now truncate the image title to 100 characters instead of failing the import. - Image Service: Fixed an issue with the preview of the image transformation in the focal point stations for images that have the default focal point set.
- Hosting Service: The Mosaic Hosting Service now grants the
policymaker
role to all RMQ Users it generates. This shall offer greater control over defining message policies such as setting Message TTL, Max length, etc. via the RMQ Management Portal for the user.
Customizable Servicesβ
- Media Template: We discovered that some services are missing their required deps in the package.json. Since we are in a monorepo, these deps were supplied by other services, and therefore everything appears to work well. But when we try to build a service in isolation, the missing deps would produce build errors. We added the missing dependencies to all services in PR https://github.com/Axinom/mosaic-media-template/pull/246 .
R91 (February 28, 2024)β
Generalβ
Weβve now introduced a strongly typed eventKey
property in GraphQL Subscriptions that generates payloads for event changes in our Managed Services. If you happen to consume such subscriptions in your custom services, you may now use the eventKey
field over the event
field to have better type safety and to avoid any potential issues in the future.
Details
An example difference in payload formats before and after:
Old |
New |
---|---|
|
|
Librariesβ
- @axinom/mosaic-id-guard: When a custom-service is configured to use a specific tenant/environment but receives a JWT that was issued to a different tenant/environment, the displayed error message will contain better instructions to troubleshoot the issue.
- @axinom/mosaic-ui: Live suggestion styles are adjusted to have better padding.
- @axinom/mosaic-ui: Added new icon for
In Progress
.
Managed Servicesβ
- Identity Service: A bug was fixed when the
UserRoleAssignmentChanged
event was fired for a User Role that was removed from a User, the correct User Role information was not included in the event payload. Now the payload includes the correct User Role name and ID. - Hosting Service: A bug was fixed when a Custom Service was redeployed with a changed DNS label (via the DNS-port-mappings in the deployment-manifest YAML), the new label was not pointing to the service port.
- Video Service: The Cue Points station was updated by removing the "Row Number" column from the Cue Points to avoid any confusion regarding the ordering. The Cue Points are always ordered by the
Timestamp
.
Customizable Servicesβ
- Media Messages: The media-messages library was updated and the corresponding services (Media, Catalog & Entitlement) were aligned to now use the updated GraphQL Subscription payload format where the
eventKey
strongly typed property is favoured over the now deprecatedevent
property. See more details in this PR (https://github.com/Axinom/mosaic-media-template/pull/235 ). - Media Service: Improved the look & feel of the workflows which contained the "Archive" & "Delete" actions to be more consistent with the remaining actions by removing the icon and only having the label.
R90 (February 12, 2024)β
Breaking Changesβ
Deprecationsβ
The format of GraphQL errors returned by Mosaic services has changed to conform with GraphQL standards.
Deprecated properties are timestamp
, code
, and details
.
For backward compatibility, the old properties are still returned, but they will be removed in the future. For more details, see the Planned Deprecations page.
Details
How to access these properties with new format:
Deprecated | New |
---|---|
error.timestamp | error.extensions.timestamp |
error.code | error.extensions.exception.code |
error.details.someDetailsProperty | error.extensions.someDetailsProperty |
Old |
New |
---|---|
|
|
Removed APIsβ
- With this release we removed backwards compatibility on our Video Service for the deprecated APIs that still used the
Encoding Service
name. - We also dropped support for the following properties on Video service:
drmKeyIds
,qualityLevels
,durationInSeconds
on Videos.bandwidthInBps
andinitialFile
onVideoStreams
. - We removed the
NodeId
based fields from the graphql schemas of all managed services.
Please refer to the Planned Deprecations page for more information.
Librariesβ
-
@axinom/mosaic-cli: A new CLI command
mosaic service sync-permissions
is introduced, which can be used to synchronize permissions with ID Service for a given Mosaic Service by giving apermissions.json
file. More info can be found in the Documentation of the CLI package. -
@axinom/mosaic-id-guard: Now the
AxGuard
plugin generates apermission-definition.json
file that serializes the permission-definition of the service. This can be helpful when you need to perform out-of-band permission synchronization to the Mosaic ID Service before the service is started.See this PR (https://github.com/Axinom/mosaic-media-template/pull/223 ) & Library Documentation for the change required on the custom-service. The generated file can be used by the new
mosaic service sync-permissions
command of the Mosaic CLI (see above) to seed the permissions into the ID service. -
@axinom/mosaic-portal: Changed the link to the
/about
page on the side panel footer to now show the portal version anymore to avoid confusions. The footer still links to the/about
page. The full list of versions of all components running on the management system can be found there. -
@axinom/mosaic-ui: Changed the
ImageLoader
component, to not do requests to./undefined
if theimgSrc
is not defined. -
@axinom/mosaic-service-common: Removed deprecated error handling classes in favour of MosaicError.
Managed Servicesβ
- Identity Service: Now when a customizable-service synchronizes the permissions to the Identity Service, the system-defined
Administrator
role of the corresponding environment will be immediately updated with the changed permissions. Previously this happened only when a Management Super Admin would sign-in to the management system. This new change will keep the Administrator role up to date in a more timely manner. - Hosting Service: The Pilet Artifacts Explorer now shows most recently updated pilets first.
- Image Service: New property
image_type
added to the Image Upload Webhook request payload. - Channel Service: Fixed an issue where the publish validations for channels and playlists would include the publish hash even if there were errors. The publish hash is now correctly null when any validation reported an error.
- Monetization Grants Service: Fixed an issue where the publish validations for claim sets would include the publish hash even if there were errors. The publish hash is now correctly null when any validation reported an error.
- Subscription Monetization Service: Fixed an issue where the publish validations for subscription plans would include the publish hash even if there were errors. The publish hash is now correctly null when any validation reported an error.
Customizable Servicesβ
- Media, Catalog and Entitlement Service: Added pg lock timeout config on Postgres PoolConfig level. This setting helps to resolve deadlock situations when two competing transactions wait for each other to release their locks. This can happen when a client runs multiple mutations within a single GraphQL request or with other database related work. (https://github.com/Axinom/mosaic-media-template/pull/207 )
Documentationβ
Weβre now publishing the TypeDocs for our libraries at https://mosaic-typedocs.axinom.net/. This will allow you to see the TypeScript type definitions of our libraries in a more user-friendly way.
More release notes can be found here.