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

Typescript CALM Module Refactoring - Visualizer, Doc Publisher, Schema Directory, CALM Model #790

Open
LeighFinegold opened this issue Jan 12, 2025 · 0 comments
Labels
Milestone

Comments

@LeighFinegold
Copy link
Member

LeighFinegold commented Jan 12, 2025

Background

Over recent discussions with developers (@aidanm3341, @oliviajanejohns, @willosborne, @Thels, @Budlee, @YoofiTT96, @Adwoa-Konadu-Appiah), we’ve been reviewing the current CALM codebase and future pull requests around documentation generation, CALM visualisation and the CLI server.

The current structure of the project uses the following organization:

  • Workspaces:
    • shared: Contains submodules like generate, validate, and visualize.
    • cli: Published separately to npm and includes CLI-specific logic.
    • docs: Documentation-related functionality.

Relevant future contributions include:


Refactoring Discussed

  1. Visualizer as a module to remain.:

    • The CALM Visualizer tool is an essential component to help users build CALM documents. It is due to be committed as its own workspace. The current visualiser module under shared was due to be deleted. However, there is consensus that a separate visualizer module should be created to support and integrate with docify workflows. This modular visualizer would allow docify and other tools to leverage visualization capabilities independently of the CLI and the tool and would make Feature Request: Markdown Parser for Inline CALM Document Rendering #782 possible.
    • The translator module, currently written in Java, was also discussed. We agreed it would be imported into the visualizer module
    • It is possible that the visualiser cli endpoint is not needed as will be exposed by document generator commands.
  2. SchemaDirectory Duplication:

    • The SchemaDirectory functionality (responsible for resolving CALM references and obtaining additional related schema files) is duplicated across multiple submodules in shared. The Validator module uses AJV to load schemas. The Generator using the SchemaDirectory to load calm schemas from the file system leveraging document ids to make appropriate guess as to expected file. The Visualizer only supports a file upload currently and does not have any ref resolving and the Docify POC relies on some registering URL links to file locations as to where to resolve referenced documents.
    • We all agreed that the SchemaDirectory should be moved into its own module such that it can be leveraged by multiple modules in the future. The SchemaDirectory should abstract away from Validate and Generator functions about where the CALM references are resolved from e.g. CalmHub vs Local Directory
    • There was also discussion around the term bundling and whether we should remove from liturgy to avoid confusion with typescript bundling.
  3. Introduce a New Doc Publisher Module under shared:

    • We discussed that to reduce dependency, the visualizer and generator should assume already validated documents have been published. We agreed we need to add a new Doc Publisher module.
    • This could be rolled out into two phases:-
      Phase 1: Implement endpoints for publishing CALM documents into the SchemaDirectory (See point1). This would be supported both from the CLI and CLI Server. This would allow for folks to leverage the generator and validator without needing a CALM Hub to get started e.g. they would publish documents first to CLI Server and then call validate on the top level architecture document.
      Phase 2: Extend functionality to support CALM Hub integration, enabling both registry publishing and CALM Hub interaction.
  4. Define one CALM Model under shared:

    • Submodules like generate, validate, and visualize each define their own versions of the CALM model (flows, controls, patterns, etc.).
    • This inconsistency complicates interactions between modules and hinders collaboration.
    • General agreement is that we would consolidate on a typescript model. We would not use generator as discussed on Explore Options for CALM Schema to TypeScript Generation - Library Evaluation #701

Next Steps

  • Review this discussion in the next working group meeting. Discuss when the work above should be prioritised. The General thought is that this would occur after Milestone 1
  • Raise issue for detailed spec issue for the new Doc Publisher Module and CLI Server endpoints. (@Budlee, @Thels )
  • Discussed use of AJV as unclear if plan is to continue to use

The following diagram as drawn to show module interaction during call (#not an official or completed diagram)

Image

@LeighFinegold LeighFinegold changed the title Required Typescript CALM Module Refactoring Typescript CALM Module Refactoring - Visualizer, Doc Publisher, Schema Directory, CALM Model Jan 12, 2025
@Thels Thels modified the milestones: 1.0, 0.1 Jan 23, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants