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

[Discuss][seatunnel-api] How can a user-defined ConfigShade class load external files #8494

Open
2 of 3 tasks
wntp opened this issue Jan 10, 2025 · 3 comments
Open
2 of 3 tasks

Comments

@wntp
Copy link
Contributor

wntp commented Jan 10, 2025

Search before asking

  • I had searched in the feature and found no similar feature requirement.

Description

In our scenario, we need to override ConfigShade to implement our custom encryption and decryption methods. However, while simple encryption and decryption can be achieved by overriding ConfigShade, we have found that if the encryption and decryption tools depend on external decryption files, there is currently no particularly effective way to load these decryption files.

Usage Scenario

No response

Related issues

No response

Are you willing to submit a PR?

  • Yes I am willing to submit a PR!

Code of Conduct

@wntp wntp changed the title [Feature][seatunnel-api] How can a user-defined ConfigShade class load external files [Discuss][seatunnel-api] How can a user-defined ConfigShade class load external files Jan 10, 2025
@litiliu
Copy link
Contributor

litiliu commented Jan 13, 2025

Could you give an example of your use case? Does the external decryption files mean local file? If yes, you should be able to read it in the encrypt/decrypt method using the FileInputStream.

@wntp
Copy link
Contributor Author

wntp commented Jan 13, 2025

Could you give an example of your use case? Does the external decryption files mean local file? If yes, you should be able to read it in the encrypt/decrypt method using the FileInputStream.

When dealing with encryption and decryption methods, the current issue is figuring out a particularly elegant way to pass file paths.

@litiliu
Copy link
Contributor

litiliu commented Jan 15, 2025

I think we can add a param named shade.props in the values env block, like this
"env": { "jobMode": "batch", "parallelism": 1, "shade.identifier": "base64", "shade.props": { "userKey1": "userValue1", "userKey2": "userValue2" } },

and call method to load the shade.props before decrypt/encrypt

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

No branches or pull requests

2 participants