Standard used by  

alternative
alternative
alternative
alternative
alternative
alternative

About ERC1753

ERC1753 is the Ethereum standard for the issuance of licence, permits and grants (Licences). 

A Licence is a limited and temporary authority, granted to a natural (e.g. you) or legal person (e.g. a corporation), to do something that would otherwise be unlawful pursuant to a legal framework. A public Licence is granted by the government, directly (e.g. by the New South Wales Department of Primary Industries, Australia) or indirectly (e.g. by an agent operating under the government’s authority), and derives its authority from legislation, though this is often practically achieved via delegated legislation such as regulations. This can be contrasted to a private licence – for example, the licence you grant to a visitor who comes onto your property.

A Licence has the following properties:

- Granted personally to the licencee (Licencee), though it may be transferrable to another person or company;

- Conferring a temporary right to the Licencee to own, use or do something that would otherwise be prohibited, without conferring any property interest in the underlying thing. For example, you may be granted a licence to visit a national park without acquiring any ownership in or over the park itself;

- Allowing the government authority responsible for the Licence to amend, revoke, renew, suspend or deny the issuance of the Licence, or to impose conditions or penalties for non-compliance; and

- Usually issued only after the payment of a fee or the meeting of some criteria.

Additionally, a Licence may be granted in respect of certain information. For example, a Licence may be issued in respect of a vehicle registration number and attaching to that specific registered vehicle.

alternative
alternative

Motivation

Governments are responsible for the issuance and management of Licences. However, maintaining and sharing this data can be complicated and inefficient. The granting of Licences usually requires the filing of paper-based application forms, manual oversight of applicable legislation and data entry into registries, as well as the issuance of paper-based Licences. If individuals wish to sight information on Licence registries, they often need to be present at the government office and complete further paper-based enquiry forms in order to access that data (if available publicly). ​

This ERC defines a standard that will allow for the granting and/or management of Licences via Ethereum smart contracts. The motivation is, in essence, to address the inefficiencies inherent in current licencing systems.

Specifications

Method

Notes:

-  The following specifications use syntax from Solidity 0.4.17 (or above)

- Callers MUST handle false from returns (bool success). Callers MUST NOT assume the false is never returned!

name 

Returns the name of the permit - e.g. "MyPermit".

function name() public view returns (string)

totalSupply

Returns the total permit supply.

function totalSupply() external view returns (uint256)

grantAuthority

Adds an ethereum address to a white list of addresses that have authority to modify a permit.

function grantAuthority(address who) external

revokeAuthority

Removes an ethereum address from a white list of addresses that have authority to modify a permit.

function revokeAuthority(address who) external

hasAuthority

Checks to see if the address has authority to grant or revoke permits.

function hasAuthority(address who) external

issue

Issues an ethereum address a permit between the specified date range.

function issue(address who, uint256 from, uint256 to) external

revoke

Revokes a permit from an ethereum address.

function revoke(address who) external

hasValid

Checks to see if an ethereum address has a valid permit.

function hasValid(address who) external view returns (bool)

purchase

Allows a user to self procure a licence.

function purchase(uint256 from, uint256 to) external payable

 

Rationale

The use of smart contracts to apply for, renew, suspend and revoke Licences will free up much needed government resources and allow for the more efficient management of Licences. The ERC also seeks to improve the end user experience of the Licence system. In an era of open government, there is also an increased expectation that individuals will be able to easily access Licence registries, and that the process will be transparent and fair. ​

By creating an ERC, we hope to increase the use of Ethereum based and issued Licences, which will address these issues.

The Ethereum blockchain is adaptable to various Licences and government authorities. It will also be easily translatable into other languages and can be used by other governmental authorities across the world. Moreover, a blockchain will more effectively protect the privacy of Licence-holders’ data, particularly at a time of an ever-increasing volume of government data breaches.

The ERC has been developed following the review of a number of licensing regulations at the national and state level in Australia. The review allowed the identification of the common licence requirements and criteria for incorporation into the ERC. We have included these in the proposed standard but seek feedback on whether these criteria are sufficient and universal.

A Licence has the following properties:

- Granted personally to the licencee (Licencee), though it may be transferrable to another person or company;

- Conferring a temporary right to the Licencee to own, use or do something that would otherwise be prohibited, without conferring any property interest in the underlying thing. For example, you may be granted a licence to visit a national park without acquiring any ownership in or over the park itself;

- Allowing the government authority responsible for the Licence to amend, revoke, renew, suspend or deny the issuance of the Licence, or to impose conditions or penalties for non-compliance; and

- Usually issued only after the payment of a fee or the meeting of some criteria.

Additionally, a Licence may be granted in respect of certain information. For example, a Licence may be issued in respect of a vehicle registration number and attaching to that specific registered vehicle.

alternative
alternative

Test Cases

A real-world example of a Licence is a permit required to camp in a national park in Australia (e.g. Kakadu national park in the Northern Territory of Australia) under the Environment Protection and Biodiversity Conservation Regulations 2000 (Cth) (EPBC Act) and the Environment Protection and Biodiversity Conservation Regulations 2000 (the Regulations). Pursuant to the EPBC Act and the Regulations, the Director of National Parks oversees a camping permit system, which is intended to help regulate certain activities in National Parks. Permits allowing access to National Parks can be issued to legal or natural persons if the applicant has met certain conditions. ​

The current digital portal and application form to camp at Kakadu National Park (the Application) can be accessed at: http://www.environment.gov.au/system/files/resources/b3481ed3-164b-4e72-a9f8-91fc987d90e7/files/kakadu-camping-permit-form-19jan2015-pdf.pdf

The user must provide the following details when making an Application: 

- The full name and contact details of each person to whom the permit is to be issued;

- If the applicant is a company or other incorporated body:

    ~ the name, business address and postal address of the company or incorporated body;

    ~ if the applicant is a company—

- The full name of each of the directors of the company;

- The full name and contact details of the person completing the application form;

- The ACN or ABN of the company or other incorporated body (if applicable);

- Details of the proposed camping purpose (e.g. private camping, school group, etc.);

- A start date and duration for the camping (up to the maximum duration allowed by law);

- Number of campers (up to the maximum allowed by law);

- All other required information not essential to the issuance of the Licence (e.g. any particular medical needs of the campers); and

- Fees payable depending on the site, duration and number of campers.

The Regulations also set out a number of conditions that must be met by licensees when the permit has been issued. The Regulations allow the Director of National Parks to cancel, renew or transfer the licence. The above workflow could be better performed by way of a smart contract.

The key criteria required as part of this process form part of the proposed Ethereum standard. We have checked this approach by also considering the issuance of a Commercial Fishing Licence under Part 8 “Licensing and other commercial fisheries management” of the Fisheries Management (General) Regulation 2010 (NSW) (Fisheries Regulations) made pursuant to the Fisheries Management Act 1994 (NSW) (Fisheries Act).

alternative

Use Cases

Implementation

The issuance and ownership of a Licence can be digitally represented on the Ethereum blockchain.

Smart contracts can be used to embed regulatory requirements with respect to the relevant Licence in the blockchain. The Licence would be available electronically in the form of a token. This might be practically represented by a QR code, for example, displaying the current Licence information. The digital representation of the Licence would be stored in a digital wallet, typically an application on a smartphone or tablet computer. The proposed standard allows issuing authorities or regulators to amend, revoke or deny Licences from time to time, with the result of their determinations reflected in the Licence token in near real-time. Licence holders will therefore be notified almost instantly of any amendments, revocations or issues involving their Licence.

ERC1753 In Action
alternative

Civic Ledger has a proud history of building blockchain and smart contract software for real-world use cases addressing challenges faced by government entities. In so much that we have defined a standard that will allow for the granting and/or management of Licences via Ethereum smart contracts - ERC-1753. Our motivation is, in essence, to address the inefficiencies inherent in current government licencing systems.

Interface

interface ERC1753 {

   string public name;

   uint256 public totalSupply;

   function grantAuthority(address who) external;

   function revokeAuthority(address who) external;

   function hasAuthority(address who) external returns (bool);

 

   function issue(address who, uint256 from, uint256 to) external;

   function revoke(address who) external;

 

   function hasValid(address who) external view returns (bool);

   function purchase(uint256 validFrom, uint256 validTo) public payable;

}