OpenLaw offers a robust toolkit for building and managing commercial relationships. Some of our product offerings include:
To learn more about how you or your business can benefit from integrating OpenLaw's toolkit into your system reach out at hello@openlaw.io.
Go to openlaw.io and click on a link to sign up for OpenLaw. Once you create an account, you will be able to gain access to our legal agreement repository. For step-by-step instructions, please see here or for a video tutorial click here.
OpenLaw is built to be hyper-generic and malleable. With OpenLaw's API, you can effortlessly integrate OpenLaw with your system. If you are interested in integrating OpenLaw, please contact us at hello@openlaw.io.
If you are interested in becoming a member of the OpenLaw community, please join our Community Slack.
We are building a repository of legal agreements on openlaw.io, and we want our members to edit and contribute to the legal agreements on our platform. If you are interested in working on projects on OpenLaw, please create an account on openlaw.io to access our template repository where you will be able to upload new agreements, edit existing agreements, and comment on other OpenLaw members' agreements. Additionally, you can contribute to our work on template conversion at https://conversion.openlaw.io/.
At OpenLaw, we understand that some agreements are meant to be private. Because of this, we've given users the ability to have their own private version of OpenLaw in order to keep agreements out of public view. The documents on Private Instances are not shared on our main public site. To get you started, we can prepopulate Private Instances with a few frequently used agreements such as NDAs and Employee Onboarding agreements.
You can request a private instance by clicking on "Request a Private Instance" in the footer at openlaw.io. Once you click on the link, you will be redirected to a page to request your Private Instance. Click on "Request your private instance" and fill out the relevant information.
If you would like to invite additional users to your Private Instance, you can use the "Invite Members" form right from the home page of your Private Instance. If you are an administrator to the Private Instance, you can also click on the nav menu (found at the top right of any page) and go to "Admin Tools." Then in the "Add Users" page, enter the emails of new users you would like to invite to join the Private Instance.
You can automate your legal agreement by creating a First Draft on OpenLaw. Create a First Draft by: (1) creating a template, (2) marking up the template using our open source markup language, and (3) inserting a smart contract component.
Create a Template
You can create a template by uploading a document or starting a template from scratch. If you would like to upload an existing document, simply click on the nav menu and under "Agreements," click on "Upload a New Agreement." Once you are on the "Upload a New Agreement" page, you will be able to either drag and drop your file or browse your computer to upload the file onto our site. After you upload the file, enter the file name and click "save." At the moment, OpenLaw is compatible with Microsoft Word and plain text, and we are working on giving you the ability to upload PDFs as well.
If you'd prefer to not upload a document, you can create a template by clicking on the nav menu and under "Agreements," click on "Start a New Template." Here you get a blank slate to draft whatever agreement you would like to. You can also copy and paste an agreement in this space.
Mark up your Template
Once you have uploaded your agreement, create your First Draft using our open source markup language. Any word or phrase can be turned into a variable by simply including double brackets around it. For Example, [[Party A Name]] or [[Party A Address: Address]] will allow you to fill in Party A's name and address in the template.
Insert Smart Contract Component
On OpenLaw, you can execute smart contract code by embedding a smart contract call in any template. On the template toolbar (the "</>" icon), you are able to choose from various smart contract calls including a one-time payment call, a token (ERC-20) transfer, an escrow assignment, a recurring payment, an arbitration assignment, or a custom component. To learn more about how to embed and execute smart contracts using OpenLaw's toolkit, click here.
Using OpenLaw's open source markup language, you can also link separate documents together into a "deal." Linking documents allows you to create a document package in which you can fill in variables across multiple templates saving you valuable time. Check out OpenLaw's markup language to learn how to do so.
Our open source markup language provides the tools necessary to create truly programmable legal agreements. Currently, OpenLaw's markup language supports if → then logic, aliasing, multi-variable expressions, hidden variables, and can even perform basic calculations. The markup language provides an easy way for anyone to automate legal prose and trigger an Ethereum-based smart contract to manage contractual promises.
We have designed our markup language to be user-friendly and easy to use. Non-technical members of our team spent a few hours on it and were able to get the hang of it quickly.
Once you upload an agreement, it is saved and available in the nav menu under "All Templates." You can search for the agreement by the name created upon saving the Agreement.
We recommend marking up your agreement on the OpenLaw website. Once an agreement is uploaded onto OpenLaw, you can mark it up by clicking the "Edit" button on the toolbar located at the top of the agreement.
If you prefer to use Microsoft Word, you can mark it up there and then copy and paste that into OpenLaw's website upon completion.
Under the "Manage" tab on the nav menu, click on the "Contract Management" section. The "Contract Management" section gives users the ability to have oversight over what contracts have been executed and recorded on the Ethereum blockchain.
Currently, the contract management tool gives you the following information: contract drafted by the user, the signatories of the contract (including the status of who has signed), and a date and time stamp of when the contract was created. You will also have access to download a Word copy, a PDF copy, and a JSON file of the agreement there as well.
We are working on adding more features to the contract management tool. We plan to automate and provide notifications to contract parties (e.g., send notifications of a contract renewal period, log terms of enforceability, etc.).
Under the "Manage" tab on the nav menu, click on the "Draft Management" section. This section gives users the ability to view drafts of agreements they started. Draft agreements are those that have not been executed by the parties. As of now, the draft management tool gives you the following information: agreement in draft form, the signatories of the agreement, and a date and time stamp of when the draft agreement was created. You also have access to download a JSON file of the agreement as well.
On OpenLaw, agreements can be signed electronically. To do this, include the requisite markup language identity variable in your agreement template. It will likely look like the following: [[Signatory Email: Identity]]. Once a party receives an email notification to sign an agreement, that party will see a button that states "Sign Agreement." There is a drop-down carrot that allows you to "Sign with MetaMask" as well. Once the party clicks on the "Sign Agreement" or "Sign with MetaMask" button, the signature is then recorded in both the agreement and on the Ethereum blockchain.
Right now, OpenLaw confirms identity through email login and password. Eventually we plan to confirm identity by leveraging a third party identity solution.
A contract is represented by a contract definition, which is a JSON object that contains the hash of each template used in the contract, all the parameters, and all of the edited paragraphs. A fully executed contract is a contract definition plus the list of all the events that has happened to it (i.e. signatures, executions, etc.). Each of the PDF, Word, and HTML versions of the contract is a representation of this contract.
An OpenLaw template can incorporate a call into any pre-existing smart contract, including smart contracts to generate a token. To use a pre-existing smart contract, 1) click the "Insert Smart Contract Component" button on the Action Bar (the "</>" icon) 2) select "Custom Component", 3) in the field "Call Name" give a name to the call to be referenced within the OpenLaw template, 4) select the "Network" from the dropdown menu where your smart contract is currently deployed, 5) in the "Contract Address" field, insert the address of the smart contract 6) in the "ABI" field, cut and paste the ABI for the one function on the smart contract you intend to call (Note: you do not need the ABI for the entire contract), 7) in the "Function Name" field, this must exactly match the name of the smart contract call in the ABI field. In the future, OpenLaw has plans to include pre-built smart contract components to forge your own ERC20 and ERC721 tokens within an OpenLaw template.