Rock
Rock copied to clipboard
Forms can break when form field matches on wrong FieldType/Control
Prerequisites
- [X] Put an X between the brackets on this line if you have done all of the following:
- Did you perform a search at https://github.com/issues?q=is%3Aissue+user%3ASparkDevNetwork+-repo%3ARock to see if your bug or enhancement is already reported?
- Can you reproduce the problem on a fresh install or the demo site?
- Did you include your Rock version number and client culture setting?
Description
This just occurred for one of our church's registrations and after looking through the code, it appears there is a problem with how the FieldVisibilityWrapper works. Here is the exception's stack trace that appeared today:
data:image/s3,"s3://crabby-images/d7f0b/d7f0baf016392a11ce361518f7f1d725d87f848f" alt="Screen Shot 2022-09-26 at 3 45 58 PM"
Digging through the code, it appears to me like this is a problem with this section in the FieldVisibilityWrapper.cs file
data:image/s3,"s3://crabby-images/bc647/bc647ca3611132bd29e8bca88539587ba1a6a0b3" alt="Screen Shot 2022-09-26 at 3 47 53 PM"
When an attribute has the same Id as the RegistrationTemplateFormField, it will always grab the attribute's field type and not even consider the actual FormField. This only happens when an attribute exists with the same Id as the RegistrationTemplateFormField, and that attribute's field type has an EditValue that conflicts with the original. This isn't often, but this shouldn't have had a collision in the first place.
For example, one of the Form Fields on our registration was a PersonField; however, there existed a Workflow attribute with a KeyValueFilter Field Type. When Rock accesses that field type's EditValue property, it will stumble onto an exception. The PersonField control doesn't have a "filter" property, so when a method like ToJson()
is called on it, it will create a Null Reference Exception.
I am unconcerned with the Field Type classes and null reference exceptions. What is concerning is that The FieldVisibilityWrapper class will grab an Attribute unassociated with a RegistrationTemplateForm, and continue to use it. Not sure what fixes would solve this issue, but it would be great to see those collisions avoided in the first place. This change has been around for 16 months, but I'm not sure what is the earliest version of Rock that it appears in.
Versions
- Rock Version: [v13]
- Client Culture Setting: [us-en]
A temporary fix on our side was to recreate the Registration Template so that we get new FormField Ids. It took three attempts because we kept colliding with some ValueFilter Field Types. It might be a bigger problem for us due to the number of templates we have. Our odds of collision are probably higher than if you have a small number of templates.
@nlBayside Do you have a little more of the StackTrace and exception info? It sounds like you are getting a Null Value Exception, but I don't see that in the screenshot. If not, I think I can still figure this out, but it might be helpful to see.
Hi @nlBayside Thank you for your submission and partnership. Unfortunately since this issue is produced using a third-party block, we can't provide further assistance. If you are able replicate this issue with the Rock block, please feel free to open a new issue. Thanks again!
@nlBayside Do you have a little more of the StackTrace and exception info? It sounds like you are getting a Null Value Exception, but I don't see that in the screenshot. If not, I think I can still figure this out, but it might be helpful to see.
I sadly don't have anything more than the StackTrace and exception info provided. The server variables and cookies in the exception page would not provide more context unfortunately. I had to walk my way through the code to investigate where the null reference occurred. I will be writing any responses in the reopened issue I created. Thank you for your time
I think this should be reopened again because the FieldVisibilityWrapper class is also used for Workflow Action Form Attributes. The changes here work for Registration Template Forms, but disregard Workflow forms.
data:image/s3,"s3://crabby-images/aba4e/aba4ebf1455e25a43208046a512b876ce221f029" alt="Screen Shot 2022-10-24 at 3 11 38 PM"
data:image/s3,"s3://crabby-images/f69a7/f69a77dd3044b97c8fb5c7edd0cc96b0cc79c057" alt="Screen Shot 2022-10-24 at 3 16 52 PM"
data:image/s3,"s3://crabby-images/32fe6/32fe621089e1f4a9028801fcd4cc9bbeff75b47d" alt="Screen Shot 2022-10-24 at 3 19 39 PM"
I think an additional fix would be to set a Boolean property for FieldVisibilityWrapper every time it's created. So that the code will know whether it's from a Workflow or from a RegistrationTemplate. This would also let us skip checking the RegistrationTemplateCache when it's from a Workflow. Thanks for the hard work! I hope this issue can finally be resolved soon. I'd be okay with opening my own pull request for this as well if that's necessary.