Please upgrade here. These earlier versions are no longer being updated and have security issues.
HackerOne users: Testing against this community violates our program's Terms of Service and will result in your bounty being denied.
Making YAGA work in 2.3rc
data:image/s3,"s3://crabby-images/0a689/0a6899b94bca4d23cb6f07fab5cc4831c623be26" alt="Swennet"
I'm trying to fix some issues with YAGA in 2.3rc2, mainly, some notice errors that are showing up when debug is enabled. See an example below:
Declaration of ActionModel::Get() should be compatible with Gdn_Model::get($OrderFields = '', $OrderDirection = 'asc', $Limit = false, $PageNumber = false) #0 /var/www/html/community/library/core/class.autoloader.php(288): Gdn_ErrorHandler(2, 'Declaration of ...', '/var/www/html/c...', 0, Array) #1 /var/www/html/community/library/core/class.autoloader.php(288): include_once() #2 [internal function]: Gdn_Autoloader::lookup('ActionModel') #3 [internal function]: spl_autoload_call('ActionModel') #4 /var/www/html/community/library/core/class.controller.php(936): class_exists('ActionModel') #5 /var/www/html/community/library/core/class.dispatcher.php(239): Gdn_Controller->getImports() #6 /var/www/html/community/index.php(44): Gdn_Dispatcher->dispatch() #7 {main}
There are lots of similar notice errors shown. "Declaration of .... should be compatible with Gdn_Model..."
Am I right in thinking that ActionModel::Get()
should be the same in it's arguments as Gdn_Model::get($OrderFields.. etc.)
?
So for example, ActionModel should be adjusted to ActionModel::Get($OrderFields = '', $OrderDirection = 'asc', $Limit = false, $PageNumber = false)
?
0
Comments
I just noticed the Addon doesn't work at all and breaks the site upon various actions. Will probably take a lot more work to fix than I anticipated. From what I can tell from my (poor) understanding of Vanilla, they have updated their Database handler in 2.3, which is incompatible with the latest version of YAGA.
I would suggest you report your findings here: https://github.com/hgtonight/Application-Yaga/issues
Maybe you can help fixing some of them (when trying to help, you should work with the newest version you can download from GitHub)
This is not a change in Vanilla, it's a change in PHP7's handing of class compatibility. Whereas it used to produce
E_STRICT
it now producesE_WARNING
when you extend a class and re-declare a method without having the signature stay compatible.Does this mean that I can safely ignore these notice errors? I assumed they were the cause of YAGA not working in 2.3rc2.
Theoretically any warning can be ignored. That said, @hgtonight should probably take a look soon if he can.
It'd be a bit of careful work to repair, but the changes we had to make to accommodate it in core were fairly limited.
@Linc: I had a quick look on Vanillas models and the DiscussionModel seems to have different parameters in its get() method. I would assume changing that would mean a lot of troubles.
I actually got it to work 100% (as far as I know) by doing some fairly basic stuff. In fact, the issue might just have been with my database, but I can't say for sure.
One error I ran into is that YAGA was trying to save an invalid datetime format into my database.
date(DATE_ISO8601)
.A simple search and replace fixed that issue for me. Search:
DATE_ISO8601
, replace with'Y-m-d H:i:s'
.The other issue I ran into had something to do with the MySQL database setting
ONLY_FULL_GROUP_BY
. In phpMyAdmin I ran the following query on my Vanilla database.SET sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''))
, and everything I've tested so far works.Sorry for my inexperience with GitHub, but I noticed there are 4 open Pull Requests. Should I apply these on top of the "Develop" branch? Apparently my previous "solution" had been done, better, by someone else alreadydata:image/s3,"s3://crabby-images/64200/642007e68171b78c68240c7dc0803ccc6be450f0" alt=":p :p"
You are right, I haven't seen that there is already a pull request for the model! I don't think there is anything left to do concerning this. By the way: I think the pull requests shows quite good the advantages of reusable code when sticking to conventions.
You also had problems with the date format and some MySql setting.
I think that the way the date is formatted in YAGA can be improved. Look through the Vanilla code how the DateInserted field is filled:
it is always done with
Gdn_Format::toDateTime();
So you could think about doing a pull request for that. It is always great to see new supporters!
I've only done a very short look at it, but ONLY_FULL_GROUP_BY seems to be the default for MySQL and it didn't worked for you? Then I'd say you should definitely file an issue on GitHub!
I do not have much experience with GitHub myself, so I'm not the best advisor, but the experience I've made by now were all positive: giving feedback is never wrongdata:image/s3,"s3://crabby-images/f6ba2/f6ba2c365bff14e22312b38e83f4c414773e5ad1" alt=";) ;)"
When I'm going to create an emblem, Alvo é requerido.
Comparison é requerido.
When will I register Badge This error:
**
Target is required.
Comparison is required.
vanilla 2.3
@daemoncesar
You can fix this by editing /applications/yaga/controllers/class.badgecontroller.php
Find this block of code:
Replace with this (just comments out unnecessary lines)
https://vanillaforums.org/discussion/comment/244774/#Comment_244774
just aligning the stars just right.
Pragmatism is all I have to offer. Avoiding the sidelines and providing centerline pro-tips.