-
Notifications
You must be signed in to change notification settings - Fork 108
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
Task Fail: Get meeting recordings from Zoom: null value in column "recordingtype" violates not-null constraint #619
Comments
I'm not sure what you would ever get a null value for recording type. Here's the critical line of code: moodle-mod_zoom/classes/webservice.php Line 1073 in 6598de0
Zoom's Get meeting recordings API suggests that the As an alternative, the crtiical line of code could be modified to default to a non-null value If you get more information about the problematic data element, we would be very interested to know if this is a valid data element or if there is an issue in Zoom's API. |
Hello, thank you so much for getting back. The problem seems to have auto-magically resolved itself this week and I can't explain what change could have occurred to resolve it. There was no back-end DB updates or configuration changes made. |
I spoke too soon. The errors stopped and the job ran consecutively for a number of days and in checking our sys logs again, we appear to have a new one. Same error, different moodle course, different recording. When we retrieve the actual recording on Zoom.us the type is: Shared screen with speaker view Here is the full stack trace: Scheduled task failed: Get meeting recordings from Zoom (mod_zoom\task\get_meeting_recordings),Error writing to database
|
Hi @smangancap, thanks for your quick response. We have a potential fix: 03c7c3b. If the error is still occurring and you can add the code that will show the structure of the recording object, it may help explain if Zoom's API is behaving differently these days or perhaps has a bug. if (empty($recording->recording_type)) {
var_dump($recording);
} |
I can see how this would be helpful for you to debug, but unfortunately, since we are hosted I don't have permissions to modify the code. |
The last modification to the Zoom plugin v5.2.3 indicates: Regression: recordingtype column was too small for some type strings #605 (thanks @samwitzig, @acquaalta) Could this have anything to do with it? It appears as though the type is: Shared screen with speaker view as per my post above. Update: I checked the details of the last updates and confirmed that characters were increased to 50 for that field in our installation. Odd that this is the same recordingtype it is hiccuping on though. recordingtype | character varying(50) | | not null | ''::character varying |
Another update - just heard back from our vendor and he is willing to update the code to debug for us. |
Can you please confirm which file and this entry goes? Would it be the file that cron is tripping up on or the webservice file? Sorry, I'm not a developer :) /mod/zoom/classes/webservice.php Also, where specifically we should put it. Thank you. |
In moodle-mod_zoom/classes/webservice.php Line 1123 in 8dc452f
|
I couldn't recreate the problem on our development instance so we just updated our production server. Here's the output of the cron job log after inserting that code. I also upped debugging to developer temporarily and checked the server logs and nothing specific to this was logged there. The error still exists for a few of our courses now and is still halting all other recordings from being returned back to moodle. I will continue to work on trying to find some commonality in the zoom meeting configuration for the courses that are returning the error. Get meeting recordings from Zoom
Just as a reminder we are on: |
Thank you @smangancap! It seems that If you are able, please apply the fix from #620. This should allow the data to at least load (and display the type as "null"). When/if the recording_type data becomes available from Zoom, the displayed string should automatically correct itself to match Zoom. I'll try to report the issue to Zoom's API team and hopefully it will stop happening. |
Thank you @jrchamp. To confirm this fix won't be pushed out into an actual release? Our host has a policy to not update core code so I don't think we will be able to apply the fix manually. The only reason they allowed the debugging code is that it wouldn't affect anything negatively on next upgrade whereas a change like this will unless continued to be patched each time. Update: disregard my comment above - we were able to apply the code change. Thank you very much for your quick response to help resolve this. |
A few days ago, we were able to release this fix as part of v5.2.4. Sorry for the delay. ❤️ |
Moodle 4.1.12 (Build: 20240812)
Zoom Meeting v5.2.32024072500
Get meeting recordings from Zoom (mod_zoom\task\get_meeting_recordings) fails with:
Error: null value in column "recordingtype" violates not-null constraint
This is halting all other meeting recording retrievals.
Since the last update had to do with a modification to recordingtype I am wondering if there was a regression. I haven't been able to find any other bug reports or discussions around this specific error yet.
Update: I was able to locate the Zoom meeting activity in Moodle and I can't find anything out of the norm in the settings. It is set up to be a recurring meeting. There have been 4 sessions so far with this particular ID and the previous recordingtype values were set to chat_file.
Also, a breakout room was created but no participants added. I tried to delete the breakout room just for the fun of it but could not. No error, the room just wouldn't delete after I saved the activity. I tried same in a different activity. Checked system logs, no nginx errors. Unsure if any of this could be related to the original problem of the task fail, but thinking more info the better.
Hoping that additional information helps.
The text was updated successfully, but these errors were encountered: