When a developer hears Duda has a website management API, many times they assume some version of design-by-API functionality, where a highly-polished website can be constructed from a completely blank slate. While there are hints of this functionality available within the Partner API, most of the endpoints are instead focused on the task of publishing similar websites at scale.
The allure of pure-API website design fades once you consider the complexity of design and the limitations of the browser's document object model (DOM). For example, consider the relatively simple concept of adding an image to a page. The API call would need to not only specify a public URL or binary data representing the image, it would need to know the style data associated with that image. Does it have a border? What are the margins? Should it be displayed inline or as a block element? The list goes on-and-on.
Once your design choices are made, there's the issue of actually inserting the element into the DOM. Very rarely can elements be placed without the help of other DOM scaffolding. A tree structure of anchor tags, lists, divs and other elements are used as a layout mechanism to maintain the position of the inserted element. Construction of this object tree via API becomes impractically difficult without immediate visual feedback.
Duda takes the position that design is best done in the visual drag-and-drop editor. While access, lifecycle management, and content injection are functions that can be accomplished via API. Designing site templates or sections within the editor allows visual complexity to be solved within a visual environment. Those templates can then be easily used to create multiple websites based on the underlying design.
With the design decisions made, we can use the API to manage all the other aspects of the website lifecycle:
- Creating a website from a template
- Updating content on the website
- Publishing and unpublishing the website
- Deleting a website when it's no longer needed
Using the API to manage the lifecycle of a website means you can easily manage the state of dozens or hundreds of sites programmatically. If you allow customers the ability to edit their own sites, there are additional endpoints to help automate access to sites:
- Creating and deleting users
- Granting and revoking access to sites
- Authenticating users into the editor
Managing site lifecycle and access allows companies to easily create a DIY or instant website flow for their business. Along with this common functionality, other features are available via API including creating site backups, managing URL rules, and retrieving site analytics. The common theme of these endpoints is they operate on high-level objects and concepts outside of the design of the site. Think of the API as a way to capitalize on the work you've already done within the editor. Once your templates and designs are finalized, the API allows you to quickly scale that work across multiple customers with minimal effort and no manual intervention. For more information on all available endpoints, see the API reference.
Updated 8 months ago