-
Notifications
You must be signed in to change notification settings - Fork 297
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use a PHP micro-framework #655
Comments
I'm for using one of these, it's going to help up greatly with the maintenance and code readability when done. About the framework choice, they seem pretty similar. Slim documentation seems to be a bit clearer and complete, so +1 for Slim. |
I'm also in favor of a micro-framework. They are becoming more and more popular and have for most of them a big community which ensures sufficient durability. And clearly the gain would be huge in terms of organisation (also to make it easier for people to help on the code). Although my choice would clearly go for Slim, which I use already a lot (great documentation, already a few security middlewares, nice skeletons, etc.), it might be interesting to gather more information about their performances and communities. I was able to find this comparative study (but I've no idea if it's trustworthy). I also had a look at Google Trends to have an idea of the popularity of those frameworks. |
Some points we might want to take into account to keep Shaarli simple and lightweight:
I'll look into it and post my feedback here |
Good points. I took a look at SLOC and dependencies. SLOC isn't really an indicator about performances, but still, it gives an idea of the project size. I don't think we need to worry too much about test coverage since they're all popular framework (and tested, I didn't look too much into it). Silexrequires PHP 5.5
Dependencies:
Slimrequires PHP 5.5
Flightrequires PHP 5.3
Dependencies: None. Ping #599 - if we want to use Slim or Silex, we need to drop PHP 5.3/4 compatibility first. |
+1, #599 could be shifted to the next milestone
No idea either :)
Such a benchmark can be found here: https://github.com/kenjis/php-framework-benchmark #266 updated as both Slim & Silex provide integrations with HTML template engines:
Hereafter are (in no particular order) some things I noticed while fiddling with the frameworks' sources, documentation and test suites. Silex comes with plenty of dev dependencies, which, in turn, come with even more dependencies. Workspace size after prod+dev dependency resolution:
Coverage:
Note: @ArthurHoaro I think the +1 for using Slim, as:
|
Nope I ran it on Slim subfolder.
We can probably make RainTPL work with Slim. I definitely don't want to switch engine now. |
Yup, my comment was specifically targeting the number and size of test deps (took around 2min with a DSL connection to resolve them for Silex O_o) It should be easy to hook Slim with RainTPL, I'll experiment with it over the weekend (kinda related to #613 as well). |
I like where this is going. +1 for Slim, used it quite a bit in the past. Update: RainTPL was not updated for about two years, might have been abandoned. Should not be a problem today, but might become one in the future. |
@virtualtam Composer update takes me forever anyway with xdebug enabled. @thomaswormann Not really a full rewrite, thanks to everyone work, but a lot of copy-paste, variable/call replace and tests. |
Twig-View and PHP-View projects might be good starting points for creating a RainTPL view. +1 for @thomaswormann point about the current status of RainTPL. But there is no emergencies right now as it still works perfectly with PHP 7. And also because it would completely break compatibility with existing themes and it would require a lot of additional work for the redesign branch. It could be something to keep in mind for when custom themes will be officially supported. |
Closing as we've settled on using Slim for the REST API (and internal routing in the future) |
There has been discussions leading to the proposal of using a PHP micro-framework to improve Shaarli's architecture. See #616 (API) and #631 (using proper controllers).
This framework should be able to handle:
A few have been mentioned:
Pro: this would help us to go further with the refactoring while relying on heavily tested and stable tools (and finally tear down this huge
index.php
).Con: I'm a bit concerned about our current URLs, especially permalinks.
I'd like everyone opinion on this.
The text was updated successfully, but these errors were encountered: