Mmmm tempting but dangerous indeed.

I'd say plugins in a software must be additions of features, modifying features is forking.

Best regards,

Le 11/11/2020 à 23:41, dc...@prosentient.com.au a écrit :
I wouldn't say impossible to maintain, but that's a good point about competing 
plugins trying to override the same modules.

Your critique of my @INC idea would also apply to giving plugins access to the 
Mojolicious router though. Overriding via plugins is probably not a sensible 
solution.

I am somewhat familiar with Mojolicious plugins, and that's an interesting 
idea, although those should really be set at app startup time. (I have been 
wondering how we could improve the Koha plugin experience by getting all 
Starman workers to reload to include new plugin code...)

I think both the Mojolicious plugins and modifying @INC could be useful for 
sysadmins but probably not Koha end users - now that I think about it more.

Speaking of Mojolicious, feel free to add your CC to Bug 26791, Julian. I 
haven't posted my patches yet, but I'm sure your feedback will be useful when I 
do. I'm planning to replace the export.pl script with a Mojolicious controller. 
I just need to find some time to finish it off.

David Cook
Software Engineer
Prosentient Systems
72/330 Wattle St
Ultimo, NSW 2007
Australia

Office: 02 9212 0899
Online: 02 8005 0595

-----Original Message-----
From: Koha-devel <koha-devel-boun...@lists.koha-community.org> On Behalf Of 
Julian Maurice
Sent: Wednesday, 11 November 2020 9:46 PM
To: koha-devel@lists.koha-community.org
Subject: Re: [Koha-devel] Location of plugins in @INC

Le 11/11/2020 à 01:17, dc...@prosentient.com.au a écrit :
Hi all,

I was talking about how we could override default Koha modules with
customized versions by just making sure those modules were located
earlier in @INC.

That got me thinking… at the moment we put Koha Plugins at the bottom
of @INC, but we could actually put them at the start of @INC.

They would be more dangerous as they’d be able to override any Perl
module… but they would also be more powerful.

More powerful, and quite impossible to maintain, as every change to the module 
would have to be done in the plugin as well :/ Also, two plugins overriding the 
same module... It just won't work.


In the context of a Koha where controllers are Perl modules (e.g.
Mojolicious controllers) rather than Perl scripts, a plugin could
override any controller in Koha. That could make for very powerful and
seamless customizations.

For this particular use case I think there are better options, like giving 
plugins access to the Mojolicious router, which allows to override some routes.
Also note that Mojolicious has its own plugin system that can be used as well. 
For now the list of plugins used by Mojolicious applications is static, but it 
certainly can be made dynamic without much effort.


--
Fridolin SOMERS <fridolin.som...@biblibre.com>
Software and system maintainer 🦄
BibLibre, France
_______________________________________________
Koha-devel mailing list
Koha-devel@lists.koha-community.org
https://lists.koha-community.org/cgi-bin/mailman/listinfo/koha-devel
website : http://www.koha-community.org/
git : http://git.koha-community.org/
bugs : http://bugs.koha-community.org/

Reply via email to