Contribute to the DSpace Development Fund
The newly established DSpace Development Fund supports the development of new features prioritized by DSpace Governance. For a list of planned features see the fund wiki page.
Developers Meeting on Thurs, Sep 5, 2024
Time/Location
from 14:00-15:00 UTC
Location: https://lyrasis.zoom.us/my/dspace?pwd=RTk4QUhISnhPRi9YenVrTFJKbDllQT09 (Meeting ID: 502 527 3040). Passcode: dspace
- More connection options available at DSpace Meeting Room
Agenda
- Discussion Topics - If you have a topic you'd like to have added to the agenda, please just add it.
- DSpace 9.0 release (tentative April 2025)
- 9.0 Board is created: https://github.com/orgs/DSpace/projects/31/
- Early ideas/brainstorms captured at DSpace Release 9.0 Status
- Ongoing Discussions:
- Incentivizing Code Reviews and PR Testing
- High CPU with DSpace 7 SSR: https://github.com/DSpace/dspace-angular/issues/3110
- Using both public/private REST API URLs for better performance: https://github.com/DSpace/dspace-angular/issues/1485 (Assigned to 4Science)
- Simplifying the Installation Process: https://github.com/DSpace/dspace-angular/issues/3184
- (Other topics?)
- DSpace 9.0 release (tentative April 2025)
- Board Review:
- 9.0 Project Board - Review PRs collaboratively or Assign new PRs to volunteers to code review and/or test.
- Backlog Board - Are there any tickets here stuck in the "Triage" column? We'd like to keep this column as small as possible.
- 8.x and 7.6.x Maintenance Board - Known bugs can be found here, along with any backported bug fixes.
- Upcoming Topics: (Let us know if there are topics you want to discuss in future weeks)
- DSpace accepts external identifiers (DOIs and such) from submitters, and manages others (DOIs again, Handles) itself. Should these be stored in separate metadata fields? what fields? what schema? Various bits of DSpace have disagreed on the answers. See also https://github.com/DSpace/DSpace/pull/1006.
- Discussion/proposal around refactoring and simplifying Live Import and External Data frameworks: https://github.com/DSpace/DSpace/issues/9758
(nothing concrete yet but would be great to get thoughts added to this issue and maybe find some collaborators)
Attendees
- Tim Donohue
- Holger Lenz
- Giuseppe Digilio (4Science)
- Paulo Graça
- Mark H. Wood
- Grazia Quercia (4Science)
- Corrado Lombardi (4Science)
- Julian Timal (eScire)
- Martin Walk
- Melissa Anez
- Oliver Goldschmidt
- Hrafn Malmquist
- Pascal-Nicolas Becker
- Pierre Lasou
- Kim Shepherd
- Nicholas Woodward
Current Work
Project Boards
- DSpace 9.0 board: https://github.com/orgs/DSpace/projects/31
- DSpace 8.x and 7.6.x board: https://github.com/orgs/DSpace/projects/29
To quickly find PRs assigned to you for review, visit https://github.com/pulls/review-requested (This is also available in the GitHub header under "Pull Requests → Review Requests")
Goals for 9.0
To be decided by DSpace Steering Group with feedback from Leadership Group.
Early brainstorms at DSpace Release 9.0 Status. Please feel free to add your own brainstorms or link in tickets that you wish to be considered.
Goals for 8.1 / 7.6.3
Deadline is TBD for both 8.1 and 7.6.3. Bug fix releases do not have fixed/scheduled deadlines. Instead, the developer team will determine when to create a release based on the significance of the issues to solve. (e.g. If major issues are fixed, then a bug fix release will occur more rapidly. If minor issues are found, then a bug fix release may be delayed until sufficient fixes have been made to warrant a release)
- Bug/security fixes only. These minor releases will not include any new features.
- New "themeable components" (for dspace-angular) are allowed in bug fix releases, provided that they don't significantly modify component behavior or similar.
- Accessibility fixes are also allowed in bug fix releases, provided they don't significantly modify component behavior or similar.
- Bug fix PRs should be created against "main" branch where possible. The "main" branch has the most strict code style rules. (i.e. PRs created against
dspace-7_x
are becoming more difficult to port forward.) - Per our support policy, bug fixes are only guaranteed to be ported back to 8.x. That said, where possible, we'll try to backport bug fixes (especially significant ones) to 7.6.x.
- Keep in mind, if a specific bug fix is important to you in 7.6.x, then it is best to create two PRs (one for main and one for "dspace-7_x"). If you are able to provide a backport version of the PR, then we will merge it alongside the "main" branch version.
- NOTE: In many scenarios, a backport to "dspace-8_x" should be possible to automate using the "port to [branch]" labels & the "Port merged Pull Request" GitHub Action
Try "Pull Request Trading" for a quicker review
Do you have a PR stuck in "under review" that you really want to see move forward? Or maybe it's someone else's PR but you want to get it more attention?
See Trading reviews on Pull Requests for how to get immediate attention to that PR!
Notes
Updates on ongoing discussion topics
- No updates / news from DSpace governance regarding 9.0 prioritization
- Likely priorities will be
- Easier installation process
- Code cleanup / maintenance
- Performance improvements
- Code Reviews:
- GitHub now has a Contributors action functionality - if anyone wants to investigate feel free to do so
- High CPU with SSR:
- Tim highlighted that there is a new comment in the discussion on ticket #3110
- Message Tim in case you find this solution works well and can be helpful; the more feedback, the better
- Private/Public Rest API:
- No updates, still in process
- Simplifying installation process:
- Progress has been made on #3173 (switching from yarn to npm)
- For build and run commands in connection with 9.0 development, use npm instead of yarn
Presentation from Art: New library for submission forms
- Art presented on a possible solution using the formly library (supports bootstrap by default)
- Advantage: could use this library to easily define a form in JSON (JSON Schema) rather than creating custom forms in HTML
- Summary of Example Code:
- Hardcode the link to one submission step
- Translate that into formly fields
- One costum component, the rest of the code is from the standard formly library
- Map fields to formly properties
- onSubmit: generate patch based on changes in model and translate that in a format that works
- Art Lowel (Atmire) will summarize this presentation and put it into an existing ticket: https://github.com/DSpace/dspace-angular/issues/2216
- Discussion ensued around the question whether we want to use an external library or use improved out-of-the box form features in Angular 18
- Concern that external libraries might not be as well maintained. Currently ng-dynamic-forms library has very little maintenance. Formly seems better at a glance, but also seems to primarily be maintained by one person: https://github.com/ngx-formly/ngx-formly/graphs/contributors
- Challenge with using Angular 18 is that DSpace needs to be upgraded first to Angular 18. Or a basic proof of concept outside of DSpace.
- Need to investigate further what form improvements come with Angular 18
- Tim will create a ticket for the migration to Angular 18 to start planning and look into how to make this achievable. Done: https://github.com/DSpace/dspace-angular/issues/3304
PR Review
- Discussed and reviewed:
- #9659 - Thumbnail with a given page number
- In favor of direction, but open to improvements; needs testing
- #3096 - Change - Metadata field selector, add infinite scroll for data paginated
- tap() may not be appropriate - Art will summarize this observation in a comment
- This is an older PR, may need to ask creator to switch this to main, or create alternate PR for main.
- Question of whether we want to backport this to 7
- #3105 - Fix for User profile (/profile): only 20 group memberships shown instead of all
- Briefly looked at this PR. Code looks reasonable overall, with some minor comments to be added.
- Needs testing
- Each of these three still needs testers
- #9659 - Thumbnail with a given page number