Transitioning the JavaScript SDK to Semantic Versioning
data:image/s3,"s3://crabby-images/17c3d/17c3d1b6a11c4516a19c37879547556f225a9150" alt="Photo of Sumer Jabri"
Sumer Jabri
data:image/s3,"s3://crabby-images/f9c48/f9c4845b4bc086b55b59af60ea7bed5844c02374" alt=""
Background
Versioning is critical in software development, ensuring developers can confidently manage dependencies and compatibility. Historically, the CrafterCMS JavaScript SDK (JS-SDK) has been versioned alongside the core CrafterCMS platform, which does not follow semantic versioning (SemVer). While this alignment helped track product releases, it introduced challenges for UI tools and package managers that expect strict SemVer compliance. To address this, we are transitioning the JS-SDK to an independent semantic versioning scheme.
Why the Change?
Many UI tools, frameworks, and package managers rely on SemVer to determine compatibility and resolve dependencies correctly. Because CrafterCMS itself does not follow SemVer, the previous approach caused inconsistencies and unnecessary upgrades. By decoupling the JS-SDK from the core product's versioning and adopting SemVer, we aim to:
-
Improve compatibility with JavaScript package managers and UI tooling.
-
Allow independent JS-SDK improvements without unnecessary major version bumps.
-
Provide a predictable and structured upgrade path for developers.
New Versioning Scheme
Starting from JS-SDK version 4.3.0, the CrafterCMS JS-SDK will now follow the standard semantic versioning format:
MAJOR.MINOR.PATCH
How It Works
-
Major (MAJOR): Significant updates that introduce breaking changes.
-
Minor (MINOR): Backward-compatible feature updates and improvements.
-
Patch (PATCH): Backward-compatible bug fixes and maintenance releases.
For example:
-
The latest SDK release, 4.3.0, will remain 4.3.0, following SemVer going forward.
-
If a breaking change occurs in the JS-SDK, the next version would be 5.0.0.
-
If a minor feature update is introduced, the next version would be 4.4.0.
-
If a bug fix is applied, the next version would be 4.3.1.
Benefits of This Approach
This approach allows us to maintain compatibility with SemVer while ensuring logical and structured version increments within CrafterCMS's evolving ecosystem. The benefits include:
-
Clear and structured version increments for package managers.
-
Easier dependency management for developers using the JS-SDK.
-
Decoupled release cycle from the main product, enabling faster JS-SDK iteration.
What to Expect Next?
The new versioning scheme will be implemented in the next release. Developers using the JS-SDK should continue to follow standard package manager upgrade guidelines. We will also update our documentation to reflect these changes.
We welcome feedback from our community to ensure a smooth transition. If you have questions, feel free to reach out on our community Slack..
Related Posts
data:image/s3,"s3://crabby-images/0e9dc/0e9dccf9a36874a8225701b0a5cfa69809af12a3" alt=""
What is an AI CMS?
data:image/s3,"s3://crabby-images/cf1aa/cf1aa0ca2aa375d31b230c692754c5fe2a6352d6" alt="Amanda Lee"
Amanda Lee
data:image/s3,"s3://crabby-images/45fa8/45fa8078ecede2aedd5611f59765809189834c00" alt=""
GenAI and Content Management: Best Practices and an Architectural Roadmap
data:image/s3,"s3://crabby-images/fe712/fe7124855c4334b300c9ce0255c681249ab9a6b8" alt="Sara Williams"
Sara Williams
data:image/s3,"s3://crabby-images/fad3c/fad3cbb8b84260011e3a0fb659adbb7f00ed7d91" alt=""
Multichannel Publishing for Enterprises
data:image/s3,"s3://crabby-images/a15e9/a15e9de45aabfe68e2bb833f408c0af5988bec03" alt="Amanda Jones"
Amanda Jones
data:image/s3,"s3://crabby-images/bbbac/bbbace1cf2d398fe9b838be7fb7639ed56132568" alt=""
Dynamic Content Delivery at Scale with a Decoupled CMS
data:image/s3,"s3://crabby-images/cf1aa/cf1aa0ca2aa375d31b230c692754c5fe2a6352d6" alt="Amanda Lee"
Amanda Lee
Related Resources
-
Personalized Digital Experiences for a Cruise Liner
Webcast
-
Introducing CrafterCMS v4.0
Webcast
-
Modernizing Video Delivery and Content Management at CPAC, A Canadian Nationwide Broadcaster
Webcast
-
Building React Apps on a Headless CMS
White Paper
-
Building OTT Video Experiences with Headless CMS on AWS
White Paper