Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
To build or contribute, see CONTRIBUTING.md.
Versatile Data Kit enables data engineers, data scientists and data analysts to develop, deploy, run, and manage data processing workloads (called "Data Job"). A "Data Job" enables Data Engineers to implement automated pull ingestion (E in ELT) and batch data transformation into a database (T in ELT).
Make sure you have python3 installed. It's strongly recommended to use a virtual environment, and also to use a python installer like pyenv or conda. We recommend pyenv.
CICD is managed through gitlab-ci.yml. You can see how to build, run tests, deploy there best. All related CICD scripts are in /cicd/ folder.
All Versatile Data Kit SDK Core releases can be found in PyPI.
Install Versatile Data Kit SDK Core with:
pip install vdk-core
This will install console application called vdk
Then run help to see what it can do:
vdk --help
Plugins are a powerful way of extending or adapting Versatile Data Kit for all kinds of use-cases. For more information see Plugins doc.
Secrets also double as config keys.. At the end of the
initialize_job
hook, the secrets provider is called and all secrets keys are fetched. Any configs that match a
secrets key have their values overridden. However, if a plugin caches some config values in the initialize_job
hook and re-uses them later, those values will not be overridden by secrets.
Example
This will not work
vdk secrets --set-prompt mytoken
@hookimpl
def initialize_job(self, context: JobContext) -> None:
token = context.core_context.configuration.get_value("mytoken") # will be None if not set in config.ini
if token:
myapi.login(token)
# secrets override configs after initialize_job but before run_job
Plugins should do this instead
@hookimpl(hookwrapper=True)
def run_job(self, context: JobContext) -> Optional[ExecutionResult]:
# config is already overridden by secrets
token = context.core_context.configuration.get_value("mytoken")
if token:
myapi.login(token)
This is a limitation on the current implementation, which might change after https://github.com/vmware/versatile-data-kit/issues/3210
Any backwards compatibility guarantees apply only to public interfaces. Public interfaces are modules and packages defined or imported in vdk.api.*. unless the documentation explicitly declares them to be provisional or internal interfaces. Anything else is considered internal. All public interfaces (classes or methods) must have documentation.
FAQs
Versatile Data Kit SDK Core
We found that vdk-core demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.