Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add EIP: Tranche Sequence #7169

Closed
wants to merge 19 commits into from
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
185 changes: 185 additions & 0 deletions EIPS/eip-7169.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,185 @@
---
eip: 7169
title: Tranche Sequence
description: A tranche sequence refers to a series of payment opportunities that occur at specified time intervals.
author: Anwar Alruwaili (@pcanwar) <[email protected]>, Shaun Cole (@secole1), Michelle Conroy (@missmshel)
discussions-to: https://ethereum-magicians.org/t/library-for-time-management-on-chain-tranche-sequence/14571
status: Draft
type: Standards Track
category: ERC
created: 2020-05-15
---

## Abstract

This concept is extended through a library that builds on [ERC-20](./eip-20.md), [ERC-721](./eip-721.md), and other standards, offering a transparent and structured approach to on-chain time management. With the help of additional functions, the library enables stakeholders to define time milestones and a sequence of opportunities to evaluate and decide on the next steps.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Your abstract should be a terse technical summary that gives readers a high level understanding of what the proposal does. I haven't read further down yet, but perhaps something like:

Building on [ERC-20](./eip-20.md), [ERC-721](./eip-721.md), and other standards this proposal
defines a transparent and structured approach to on-chain time management using tranche
sequences. A tranche sequence is a **this is where I would put a definition of a tranche sequence
if I knew what it was**.


## Motivation

The motivation behind this library is to overcome the challenges of managing multi-stage projects or use cases on utility tokens or NFTs while providing a fair and transparent approach to on-chain time management. This structured approach facilitates effective smart contract management and enables stakeholders to progress and make informed decisions. The library can be applied to various use cases, such as salary negotiations, project funding, or resource allocation, promoting trust and collaboration among stakeholders. The library's flexibility and transparency can result in a fairer and more effective decision-making process for all parties involved.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
The motivation behind this library is to overcome the challenges of managing multi-stage projects or use cases on utility tokens or NFTs while providing a fair and transparent approach to on-chain time management. This structured approach facilitates effective smart contract management and enables stakeholders to progress and make informed decisions. The library can be applied to various use cases, such as salary negotiations, project funding, or resource allocation, promoting trust and collaboration among stakeholders. The library's flexibility and transparency can result in a fairer and more effective decision-making process for all parties involved.
The motivation behind this proposal is to overcome the challenges of managing multi-stage projects or use cases on utility tokens or NFTs while providing a fair and transparent approach to on-chain time management. This structured approach facilitates effective smart contract management and enables stakeholders to progress and make informed decisions. This proposal can be applied to various use cases, such as salary negotiations, project funding, or resource allocation, promoting trust and collaboration among stakeholders. Its flexibility and transparency can result in a fairer and more effective decision-making process for all parties involved.


The following properties make tranche sequences an effective tool for managing multi-stage use cases and projects on utility tokens or NFTs in a structured and transparent manner:

Comment on lines +21 to +22
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can uncomment this when ready

Suggested change
The following properties make tranche sequences an effective tool for managing multi-stage use cases and projects on utility tokens or NFTs in a structured and transparent manner:
<!-- The following properties make tranche sequences an effective tool for managing multi-stage use cases and projects on utility tokens or NFTs in a structured and transparent manner: -->

## Specification

Library
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This section needs to be better organized. I recommend using a single code block for the interface, followed by sections describing each function in detail. For example:

## Specification

```solidity
interface Tranche {
    function initialize(uint256[] memory sequence) public;
}
```

### Functions

#### `initialize`

The initialize function floops the flob.

### Events

...


NOTE:

The following specifications use syntax from Solidity 0.7.0 (or above).

InitMileStone function should be init in the smart contract constructor and also after reset the milestone

initTranches

Initializes the tranches with a sequence of timestamps.

```js
function initTranches(uint256[] memory _sequence) public
```

addTranche
Adds a new tranche to the sequence.

```js
function addTranche(uint256 _timestamp) public returns (bool success)

```

extendTranche
Extends the time of a particular tranche.

```js
function extendTranche(uint256 _index, uint256 _additionalTime) public returns (bool success)
```

listMissingTimestamps

Lists all the missing timestamps from the last completed milestone.

```js
function listMissingTimestamps() public view returns (uint256[] memory)
```

nextMilestone
Returns the timestamp of the next milestone.

```js
function nextMilestone() public view returns (uint256)
```

isCurrentMilestone
Checks if the current timestamp is within a milestone.

```js
function isCurrentMilestone(uint256 _timestamp) public view returns (bool)
```

isMilestoneStarted
Checks if a milestone has started.

```js
function isMilestoneStarted(uint256 _index) public view returns (bool)
```

isMilestoneExpired

Checks if a milestone has expired.

```js
function isMilestoneExpired(uint256 _index) public view returns (bool)

```

forceMilestone
Forcibly advance to the next milestone.

```js
function forceMilestone(uint256 _index) public
```

### Events

TrancheAdded
MUST trigger when a new tranche is added.

```js
event TrancheAdded(uint256 _timestamp)
```

TrancheExtended
MUST trigger when a tranche is extended.

```js
event TrancheExtended(uint256 _index, uint256 _additionalTime)

```

MilestoneForced
MUST trigger when a milestone is forcibly advanced.

```js
event MilestoneForced(uint256 _index)

```

Features

Flexible Time Units: The library allows you to define time in various units: minutes, hours, days, and weeks. This enables flexibility when dealing with different periods.

Customizable Tranches: The library is built around tranches or blocks of time that can be used to represent milestones. These tranches can be initialized according to your needs.

Dynamic Time Sequencing: It enables dynamic time sequencing. The time sequence can be increased based on the existing series in the smart contract.

Rest Time Inclusion: The library includes a feature for a rest time on the sequence. This offers flexibility for stakeholders, allowing for pauses or intervals between different time sequences.

Time Extension: The library allows for the time of a particular sequence to be increased if needed. This is particularly useful when an ongoing event or process needs an extended time duration.

Immutable Time Entries: Once a timestamp is added, it cannot be removed or modified. This feature offers immutability for time entries, ensuring the integrity and reliability of the time sequences.

Milestone Tracking: The library provides utilities to track milestones and understand their progress. You can get the number of completed and missed milestones, check if the current timestamp is within a milestone, and even forcibly advance to the next milestone.

Timestamp Reporting: The library provides utilities for reporting missed timestamps, getting the start and end times of the current milestone, and listing all missing timestamps since the last completed milestone.

Force Increase of Milestones: If needed, milestones can be forcibly advanced manually, regardless of whether they're currently extendable.

Start Time Customization: The library allows the initialization of milestones with a custom start time instead of the current block timestamp, which can be helpful for specific project timelines.

Effective Milestone Management: Functions such as resetMileStone, isCurrentMilestone, isMilestoneStarted, and isMilestoneExpired provide the ability to effectively manage milestones, including initiating, resetting, tracking, and identifying the completion of a milestone.

Precision and Accuracy: The library uses block.timestamp for timekeeping, which ensures precise and accurate timestamps for all operations. This accuracy is essential for a fair and accurate representation of project progress.
Comment on lines +126 to +150
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

EIPs don't usually contain lists of features. Instead, you should convert these into requirements (eg. "The contract MUST ...", or "Implementations SHOULD ...") or explanations in your rationale.


## Rationale

This library is intended to provide a standardized and efficient way to manage time-based milestones in smart contracts, enabling developers to easily integrate this functionality into a variety of applications.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This first line of your rationale should be moved to the motivation section. The rationale section should describe technical decisions made within the EIP itself, while the motivation section justifies the EIP as a whole.

Update, getter, initialization, modification, query, and helper functions provide a set of tools for managing time based milestones and offer the ability to create, manage, update, and query milestones flexibly and efficiently.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a truth, but it doesn't really offer much in the way of explanation. Please expand it or reword it so that it answers a "why" question.

The library provides replay protection and ensures security by enforcing time boundaries for each milestone and providing the ability to extend time sequences if necessary.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Again, this is true, but it doesn't explain why it is necessary to provide replay protection.


## Backwards Compatibility

No backward compatibility issues found. Thus, the library is designed with high compatibility while aligning with existing contracts' structures and logic, so its design allows for usage in diverse contexts.

## Test Cases

The test cases presented in the src directory.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You can link to any file in the /assets/eip-7169/ directory (but not the whole directory.) It's pretty common to include a README.md file, and link to that from the EIP.


## Security Considerations

Considering the security considerations when using this library, you can mitigate potential risks and ensure a secure deployment:

Accurate Timekeeping: As the library relies heavily on timestamps for operation, accurate timekeeping is paramount. The blockchain's block.timestamp is used, which provides an accurate and secure time reference. However, it's still crucial to understand that validators could have a small discretion over its exact value.
Solidity Overflow and Underflow: The library must ensure that it correctly handles overflow and underflow conditions that might occur during arithmetic operations. This is particularly relevant during timestamp and tranche calculations.

Smart Contract Permissions: It's crucial to control who can call functions that modify the state of the library, such as extending time sequences, resetting milestones, etc. These functions should be restricted to avoid misuse by unauthorized entities.

Reentrancy Attacks: While the library functions provided in the given code snippet are not prone to reentrancy attacks, it's still important to consider this when further developing the library or integrating it with other contracts.

Testing and Auditing: Any developed smart contracts using this library should be thoroughly tested and audited to ensure no vulnerabilities could be exploited. This should include both automated testing and manual code review.

Gas Optimization: Functions should be optimized to consume as little gas as possible, reducing the cost for users and mitigating the possibility of transactions failing due to exceeding gas limits.

The provided functions in the library involve looping structures (`listMissingTimestamps`) but aren't expected to cause a DoS vulnerability based on how it's implemented. However, as a best practice, developers should always be mindful of potential DoS situations in the broader context when designing and implementing smart contracts.

## Copyright

Copyright and related rights waived via [CC0](../LICENSE.md).