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

object type in activity settings should not be nested under mapping #1349

Open
1 of 2 tasks
yxuco opened this issue Dec 27, 2020 · 3 comments
Open
1 of 2 tasks

object type in activity settings should not be nested under mapping #1349

yxuco opened this issue Dec 27, 2020 · 3 comments
Assignees

Comments

@yxuco
Copy link

yxuco commented Dec 27, 2020

Environment

How are you running Flogo Web?

  • Docker (Specify the docker image that you're using and the command you used to start the container)
  • Other (Provide details of your environment)

Describe the bug

A clear and concise description of what the bug is.
When a variable in activity settings is of type object or array, and configured as, e.g., { "key": "mykey", "attributes": ["x", "y"]}, this configuration is exported as nested under "mapping" in the app's json file. Since the settings are not object mappings, it should be exported as the configure object as is, similar to what it does for trigger handler settings.

How has this issue affected you? What are you trying to accomplish?
In my implementation of an activity that requires more complex configurations than simple primitive type variables, I would have to manually remove the wrapper of "mapping" in code for any config variable of object/array type. This would not be necessary if Web UI can export the settings without the nested "mapping" wrapper.

Providing context helps us come up with a solution that is most useful in the real world

To Reproduce

Steps to reproduce the behavior:

  1. define a new activity, and in descriptor.json, add a variable of object or array type under settings.
  2. use the activity in a model, and configure the variable in WebUI
  3. export the model, you should see that the configured setting contains an extra wrapper under "mapping"
  4. If in the activity implementation, you use the common function call to extract the configured object, such as metadata.MapToStruct(ctx.Settings(), settings, true). The call will fail, because you have to manually remove the nested "mapping".

Include error logs if applicable.

Expected behavior

export the app model without the extra nesting of "mapping" for activity settings.

A clear and concise description of what you expected to happen.

Screenshots

If applicable, add screenshots to help explain your problem.

Possible Solution

Not obligatory, but suggest a fix/reason for the bug,
or ideas how to implement the addition or change

Additional context

Add any other context about the problem here.

@fcastill
Copy link
Collaborator

fcastill commented Jan 7, 2021

The UI assumes that Flogo allows the use of mappings in the activity settings. It seems that's not case and the UI should prevent the "mapping" wrapper from happening. So definitely a bug.

The other issue here is that the UI is always wrapping objects with the "mapping" props in the inputs section. And although the wrapper doesn't hurt for inputs, it is unnecessary when the object is static. Fixing that will require some work in the mappings parser so the parser can expose when an object is static or not.

@yxuco
Copy link
Author

yxuco commented Jan 8, 2021

I agree that the nesting of "mapping" does not seem necessary even for inputs. I noticed that the Flogo OSS and Enterprise export/import trigger/activity settings differently. OSS actually handles settings and handler-settings better than FE when configured attributes are JSON objects. FE cannot import complex trigger settings, FE also requires fe_metadata for complex activity settings, while fe_metadata is not a standard core metadata attribute. So, I had to write code to convert models between OSS and FE models to support both UIs. I hope that these 2 UIs can get in sync on handling JSON objects in trigger/activity configurations.

@fcastill
Copy link
Collaborator

As noted in Gitter, there are exceptions to the mappings in settings. The "return" type activities do support the mappings in settings so the UI should still support using those in settings for actreply, actreturn and mapper activities.

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

No branches or pull requests

3 participants