Paywall
The Paywall is a simple JavaScript library which can track state and emits events based on ownership of keys to specified locks. It can be used to trigger a the Checkout for purchasing keys.
You can easily add it to any webpage with the following:
<script>
(function(d, s) {
  var js = d.createElement(s),
    sc = d.getElementsByTagName(s)[0];
  js.src="https://paywall.unlock-protocol.com/static/unlock.latest.min.js";
  sc.parentNode.insertBefore(js, sc); }(document, "script"));
</script>
Configuration
The Paywall shares a configuration object with the Checkout and you can find
everything you need to know in Checkout / Configuration about how to build
out the JSON object you're going use. Then assign it to a global variable unlockProtocolConfig.
<script>
  var unlockProtocolConfig =
  {
    // paywallConfig object
  }
</script>
Events
Once loaded the script will trigger events on the page’s window object.
Registering event listeners.
window.addEventListener("unlockProtocol.eventName", handler);
Status
event unlockProtocol.status
Triggered when unlockProtocol status changes.
handler
Handler event object properties.
| name | Description | values | 
|---|---|---|
| state | Representing whether or not the connected wallet has a valid key. | locked or unlocked string | 
User info
event unlockProtocol.authenticated
Triggered when a user authenticates.
| name | Description | values | 
|---|---|---|
| address | Ethereum address of the connected user | string | 
| signedMessage | the signature perform by the user if your configuration includes a messageToSignoption | string | 
Note: if the event is triggered without any payload, please consider that the user has "logged out".
Transaction status
event unlockProtocol.transactionSent
| name | Description | values | 
|---|---|---|
| hash | the Ethereum transaction | string | 
| lock | the Ethereum address of the lock | string | 
Pessimistic Unlocking
One of the features of the paywall application is that it optimistically unlocks the page. This feature improves the customer experience by immediately emitting the unlocked event when a transaction is sent, as long as the transaction is likely enough to eventually succeed.
In some cases, your application may want to not unlock until the transaction is fully confirmed. For this you should add pessimistic: true to the paywall configuration.
When doing this, you should ensure that your application handles the events such as unlockProtocol.authenticated and unlockProtocol.transactionSent to show valuable feedback to the user. See the "Events" section on this page.