Make H5P content libraries deployable

Created on 3 December 2019, almost 6 years ago
Updated 3 July 2023, over 2 years ago

Problem/Motivation

The way content type libraries currently work, they are treated essentially as content (stored in the file system, and in the database.)

This makes it difficult to use them as part of a platform that might need to be deployed through a workflow, or across multiple servers.

It would be great if the libraries could optionally be placed in Drupal core's /libraries directory.

This would allow also for themes and design systems to be tested against known versions, and not have new libraries added in production without going through a normal QA process.

Proposed resolution

Add a setting that allows the module to look in /libraries instead of in the file system, and add whatever logic is necessary to have the database cache of library data updated during code deploys.

Remaining tasks

  1. Agree on approach
  2. Create patch to allow libraries to reside in {DRUPAL_ROOT}/libraries
  3. Add composer.json files to each library on GitHub

User interface changes

API changes

Data model changes

Release notes snippet

✨ Feature request
Status

Needs review

Version

2.0

Component

Code

Created by

πŸ‡ΊπŸ‡ΈUnited States jhedstrom Portland, OR

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • πŸ‡ΊπŸ‡ΈUnited States SocialNicheGuru

    Is there a screenshot of what this new change will look like for the content creator? Is there a change in UI?

  • πŸ‡·πŸ‡ΊRussia ilya.no

    I've noticed, that when we see list of libraries inside iframe in field widget, there is no icon for each library, located in web/libraries folder, because module tries to load it from sites/default folder.
    So, here is the patch with the fix for this and also I've included latest changes from MR.

  • πŸ‡§πŸ‡΄Bolivia vacho Cochabamba

    This patch fixes some issues about js-libraries paths..

  • πŸ‡ΊπŸ‡ΈUnited States jackfoust

    Just an FYI this patch no longer works with commit https://git.drupalcode.org/project/h5p/-/commit/289f5587bbcd3b38a6322b0c...

  • πŸ‡ΊπŸ‡ΈUnited States jackfoust

    In looking at the latest commit, do we simply need to drop the following from the most recent patch here?

    diff --git a/src/Plugin/Field/FieldFormatter/H5PDefaultFormatter.php b/src/Plugin/Field/FieldFormatter/H5PDefaultFormatter.php
    index e1d4bafc..becfb9d2 100644
    --- a/src/Plugin/Field/FieldFormatter/H5PDefaultFormatter.php
    +++ b/src/Plugin/Field/FieldFormatter/H5PDefaultFormatter.php
    @@ -61,7 +61,7 @@ class H5PDefaultFormatter extends FormatterBase {
           $preloaded_dependencies = $core->loadContentDependencies($h5p_content->id(), 'preloaded');
     
           // Load dependencies
    -      $files = $core->getDependenciesFiles($preloaded_dependencies, H5PDrupal::getRelativeH5PPath());
    +      $files = $core->getDependenciesFiles($preloaded_dependencies, H5PDrupal::getH5PLibrariesPath());
     
           $loadpackages = [
             'h5p/h5p.content',
    
  • πŸ‡¬πŸ‡§United Kingdom catch

    @jackfoust yes removing that hunk ought to be fine, the latest changes are trying to rely on the libraries system as much as possible.

    It would be great if you could rebase https://git.drupalcode.org/project/h5p/-/merge_requests/8 with that change and any of the interim ones - hard to follow what people are doing with patches here.

  • πŸ‡¬πŸ‡§United Kingdom catch

    Rebased this. Does not include anything from #35 or #36.

  • Assigned to msandoval
  • Status changed to Needs work about 2 months ago
  • I'll try to look into this today. I'll start with rebasing to remove the merge block, then take a look at the new patches that haven't been included yet.

  • Okay, just as a summary for future work (some of it is obvious but for completeness I'm including it):

    1. I've rebased the commits but am unable to reproduce what others have described in the comments. The suggested value for the new 'h5p_libraries_directory' setting in #9 doesn't follow modern file hierarchy.
    2. Still missing the ability to set the setting through UI.
    3. Still doesn't include patches #35 or #36.

    I'm jumping off of this for now.

Production build 0.71.5 2024