Skip to content
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

Rework: Remove XML storage #55

Open
PhMemmel opened this issue May 19, 2022 · 2 comments
Open

Rework: Remove XML storage #55

PhMemmel opened this issue May 19, 2022 · 2 comments

Comments

@PhMemmel
Copy link
Member

PhMemmel commented May 19, 2022

Currently GGB files are being stored both XML and base64 encoded. Using XML has the disadvantage of not being able to store background images etc.

Therefore, we should verify if the XML is really needed or - whereever it is being used - if it can be subsituted by the base64 encoded content and remove the storage of XML completely. This would also avoid possible inconsistencies as currently we are storing the same data twice.

Removing XML might require an investigation if there is a possibility of questions only stored as XML. In this case we should consider implementing an upgrade step verifying if there is a base64 encoded value and, if not, converting the existing XML to base64 and store it

@PhMemmel
Copy link
Member Author

Looks like we need to keep the XML in the DOM to extract data from the GGB applet from PHP side after form submission. As far as I can tell, we can drop the database field and rely on storing it as base64.

Another approach would be to handle all the extraction of information from the GGB applet by JavaScript and just store the extracted variables into the DOM which then is being extracted by PHP. This would require a complete rework of the validation and parameter saving logic though.

@PhMemmel
Copy link
Member Author

Discussed internally: We are removing XML completely on PHP side and go for the JS approach: Extract all necessary information via GGB JS API, put them into hidden fields and do the verification of these params directly in PHP.

While doing so we need to figure out if there are parameters we need to separately save to the database, eventually we will have to add another field for that. Ideally we can avoid that and save all necessary information directly via question api. As we have stripped off all unnecessary information by avoiding the XML we might be able to do so, will see while implementing.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant