TS-SDK introduction
The SDK is currently in beta. Future breaking changes may happen, and caution should be taken before use in production.
The Marlowe TypeScript SDK (TS-SDK) consists of JavaScript and TypeScript libraries, available as npm packages. TS-SDK is engineered to support DApp developers with the tools they need to build and integrate with the Marlowe smart contract ecosystem on the Cardano blockchain.
Features at a glance
- Smart contract toolkit: Craft and manage Marlowe smart contracts on Cardano with the tools and libraries in the TS-SDK:
- Integration with Marlowe Playground: TS-SDK works well with Marlowe Playground, an online interface dedicated to designing, simulating, and testing Marlowe contracts.
- Wallet connectivity: With built-in modules (
CIP-30
,Lucid
adapters), TS-SDK promotes smooth interactions with various wallet extensions, such as Lace, Nami, and Eternl. This ensures easy access to wallet data and the efficient integration of Marlowe contracts with a variety of wallet interfaces. (See @marlowe.io/wallet). - Integration with Runtime: TS-SDK aims to provide a Runtime Rest Client which has one-to-one feature parity with
marlowe-runtime-web
, so you can benefit from all the Runtime features in a JavaScript and TypeScript environment. (See @marlowe.io/runtime-rest-client). - Coordination between wallets and Runtime: TS-SDK provides abstractions over the Runtime Rest Client and the wallets that remove the 'plumbing' logic and allow you to focus on your core business logic. Building, signing and submitting a transaction over Cardano has never been simpler! This package eases the deployment and lifecycle management of your contracts. (See @marlowe.io/runtime-lifecycle).
- Prototype DApp examples: You can embark on your DApp journey using the TS-SDK's distilled prototype examples. These prototypes serve as launching pads for your customized applications.
Getting started
To get started, see this Marlowe TS-SDK Readme. The Readme includes examples, detailed documentation, and tools, providing a concise overview of Marlowe TS-SDK and its capabilities.
Your feedback and participation
Marlowe TypeScript SDK (TS-SDK) is released under an open-source license. You can read, use, deploy, customize, improve, and fork it at will. Look at different parts of the GitHub repository and especially the discussions section. Your feedback and participation are highly encouraged as they play a crucial role in influencing the development of the project.
Marlowe contract examples
Contract examples are released under an open-source license within the npm package @marlowe.io/language-examples. You can read, customize, improve, and fork them at will. Your feedback and active participation are encouraged.
- Module vesting: A vesting contract implementation is available in TS-SDK. It supports the Token Plans prototype and gives you a full implementation of the Marlowe contract used in a TypeScript web-based DApp environment.
- Atomic swap using open roles feature (coming soon): This Marlowe contract allows two participants (a seller and a buyer) to atomically exchange some token
A
against some tokenB
without knowing the buyer in advance.
Open-source prototypes using the TS-SDK
These prototypes are released under an open-source license. You can read, deploy, customize, improve, and fork them at will. Your feedback and participation are encouraged.
- Payouts DApp: This prototype is an example of a DApp designed to help users discover, track, and withdraw tokens from Marlowe smart contracts that use role tokens. It enables holders of role tokens in Marlowe smart contracts to withdraw the received funds, simplifying the process of tracking and withdrawing their payouts.
- Token Plans DApp GitHub repository: This prototype is a demonstration of how to build DApps powered by Marlowe with well-known mainstream web technologies such as
TypeScript
andReact Framework
. It is a use case of a vesting contract developed and available in the Marlowe TS-SDK. It allows you to create ada Token Plans over Cardano. Ada Token Plans can be created by a 'token provider.' The token provider will deposit a given amount of ada with a time-based scheme defining how to release these funds to a 'claimer' participant. - Order book swap prototype: This prototype demonstrates the new Marlowe open roles feature by using a new atomic swap contract.