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

Publishing: Low-level dynamic runtime instance creator #691

Draft
wants to merge 7 commits into
base: develop
Choose a base branch
from

Conversation

BigRoy
Copy link
Collaborator

@BigRoy BigRoy commented Jun 24, 2024

Changelog Description

This PR implements an approach to "lower level publishing" (tested in Houdini).
This focuses on PDG/TOPs or any other type of batch creating runtime instances.

  • TOPs/PDG example on accessing AYON api for folders, tasks, workfiles and publish the workfiles in background houdini processes (similar to legacy/old style publishing of workfiles)
  • TOPs/PDG example on low level ingesting of publishes using an in-memory dynamic Creator.

Note that this is Houdini-tested but the "lower level dynamic" publishing is logic that is not Houdini only.

This PR adds a Batch/Dynamic Creator:

Currently, it creates runtime instances (they will disappear once you refresh the publisher)
It doesn't inject any metadata. but it expects you to pass them manually.
Here is an example
https://gist.github.com/MustafaJafar/bd2a388e4a6aa3613d64a186ebb6660c

# The system should end up allowing us to do AYON publishing in a simple way WITH type hinting across the board.
context = ayon.CreateContext()
instance = context.create(
    variant="Main",
    product_type="texture",
    files=["/path/to/texture.exr"],
    traits=[
        FrameRange(start=1001, end=1010, frame_list=[1001, 1005]),
        OCIO(path="ocio.config", colorspace="ACEScg"),
        BurninMetadata(camera_name="XYZ", username="roy"),
        TagsMetadata(),
    ]
)
context.publish()

Additional info

As part of the Ynput Houdini Workgroup sessions I developed this quick prototype to expose a way to batch publish and ingest files. Consider it more of an exploration of what's possible then a "drop it in production now" ready-to-go solution.

TODO

  • Keep in mind this set of goals
  • Move core of logic out of Houdini
  • Expose a simple API with examples
  • Expose examples
  • This PR should solve the issues here

Explainer

Since this PR is separated from #542 some of the logic in the demo provided there is now actually here - in particular to the logic the Houdini TOPs / PDG demos show.

2024-05-22.20-48-11.mov

Demo scene file

The demo scene file:

ynts_char_hero_pdg_v012.zip

Testing notes:

  1. Check out the branch
  2. Check out the explainer video
  3. Test the demo scene file
  4. Comment with great ideas on how to improve

@BigRoy BigRoy requested review from MustafaJafar and moonyuet June 24, 2024 18:34
@ynbot ynbot added host: Houdini type: enhancement Improvement of existing functionality or minor addition size/S labels Jun 24, 2024
@BigRoy BigRoy requested a review from antirotor June 24, 2024 22:38
@moonyuet
Copy link
Member

I tried to create instance with ingest
And it errors out during creating instance where the product type can't be found.

Traceback (most recent call last):
  File "D:\ayon-core\client\ayon_core\pipeline\create\context.py", line 2124, in _create_with_unified_error
    result = creator.create(*args, **kwargs)
  File "D:\ayon-core\server_addon\houdini\client\ayon_houdini\plugins\create\create_dynamic.py", line 53, in create
    product_type = pre_create_data.get("product_type") or instance_data["product_type"]
KeyError: 'product_type'

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
host: Houdini size/S type: enhancement Improvement of existing functionality or minor addition
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants