EIPs/EIPS/eip-801.md

79 lines
1.9 KiB
Markdown
Raw Normal View History

---
2018-03-21 12:51:05 +00:00
eip: 801
title: ERC-801 Canary Standard
author: ligi <ligi@ligi.de>
type: Standards Track
2018-03-21 12:51:05 +00:00
category: ERC
status: Draft
created: 2017-12-16
---
2017-12-17 03:46:58 +01:00
## Simple Summary
A standard interface for canary contracts.
## Abstract
The following standard allows the implementation of canaries within contracts.
This standard provides basic functionality to check if a canary is alive, keeping the canary alive and optionally manage feeders.
## Motivation
The canary can e.g. be used as a [warrant canary](https://en.wikipedia.org/wiki/Warrant_canary).
A standard interface allows other applications to easily interface with canaries on Ethereum - e.g. for visualizing the state, automated alarms, applications to feed the canary or contracts (e.g. insurance) that use the state.
## Specification
### Methods
#### isAlive()
2017-12-19 11:58:50 +01:00
Returns if the canary was fed properly to signal e.g. that no warrant was received.
2017-12-17 03:46:58 +01:00
``` js
function isAlive() constant returns (bool alive)
```
2017-12-19 11:58:50 +01:00
#### getBlockOfDeath()
2017-12-17 03:46:58 +01:00
2017-12-19 11:58:50 +01:00
Returns the block the canary died.
Throws if the canary is alive.
2017-12-17 03:46:58 +01:00
``` js
2017-12-19 11:58:50 +01:00
function getBlockOfDeath() constant returns (uint256 block)
2017-12-17 03:46:58 +01:00
```
2017-12-19 11:58:50 +01:00
#### getType()
2017-12-17 03:46:58 +01:00
2017-12-19 11:58:50 +01:00
Returns the type of the canary:
2017-12-17 03:46:58 +01:00
2017-12-19 11:58:50 +01:00
* `1` = Simple (just the pure interface as defined in this ERC)
* `2` = Single feeder (as defined in ERC-TBD)
* `3` = Single feeder with bad food (as defined in ERC-TBD)
* `4` = Multiple feeders (as defined in ERC-TBD)
* `5` = Multiple mandatory feeders (as defined in ERC-TBD)
* `6` = IOT (as defined in ERC-TBD)
2017-12-17 03:46:58 +01:00
2017-12-22 11:24:31 +01:00
`1` might also be used for a special purpose contract that does not need a special type but still wants to expose the functions and provide events as defined in this ERC.
2017-12-17 03:46:58 +01:00
``` js
2017-12-19 11:58:50 +01:00
function getType() constant returns (uint8 type)
2017-12-17 03:46:58 +01:00
```
### Events
2017-12-19 11:58:50 +01:00
#### RIP
2017-12-17 03:46:58 +01:00
2017-12-22 11:24:31 +01:00
MUST trigger when the contract is called the first time after the canary died.
2017-12-17 03:46:58 +01:00
``` js
2017-12-19 11:58:50 +01:00
event RIP()
2017-12-17 03:46:58 +01:00
```
## Implementation
TODO
## Copyright
Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/).