Skip to content

Sediment is a smart contract library for Solidity and the EVM offering various building-blocks for projects and EVM chains to offer commonly requested functionality.

License

Notifications You must be signed in to change notification settings

Dirt-Road-Development/sediment

Repository files navigation

Sediment

Sediment is a smart contract library for Solidity and the EVM offering various building-blocks for projects and EVM chains to offer commonly requested functionality.

Installation

To add to your project, run:

npm add @dirtroad/sediment

Then important according to each of the modules:

Modules

Authority

Add AccessControl from OpenZeppelin to your contract with some pre-defined roles for authority.

import "@dirtroad/sediment/contracts/authority/Authority.sol";

Leaderboards

Sediment offers three (3) leaderboard options for developers to use:

Default Leaderboard

This leaderboard uses Ethereum addresses as the primary identifier.

import "@dirtroad/sediment/contracts/leaderboard/Leaderboard.sol";
String Leaderboard

This leaderboard uses strings as the primary identifier. This is a great option for using UUID's or other string based ID's from a server.

import "@dirtroad/sediment/contracts/leaderboard/StringLeaderboard.sol";
Bytes Leaderboard

This leaderboard uses bytes32 as the primary identifier.

import "@dirtroad/sediment/contracts/leaderboard/BytesLeaderboard.sol";

Logger

A simple logging smart contract that allows you to add more traditional log types to your contract to help identify specific issues or information.

Automatically hashes the value with the timestamp to ensure Unique Identifiers are created for each log.

import "@dirtroad/sediment/contracts/logger/Logger.sol";

Rate Limit

There are two rate limit contracts offered in Sediment. The first is a basic rate limit that helps ensure that transactions on a specific function are limited. This is great for chains that have low or zero gas fees.

import "@dirtroad/sediment/contracts/rateLimit/RateLimit.sol";

Bot Protection

The second rate limit contract offered by Sediment is geared more towards mitigation against bots. Great for protecting public functions that write state to chain or offer minting; this has configurable limit times coupled with a strike system in addition to an optional blacklist for addresses.

import "@dirtroad/sediment/contracts/rateLimit/BotProtection.sol";

Token Checker

While not a silver bullet; this contract will help identify most tokens by type allowing for dynamic usage of addresses within a Solidity function. This is used internally within the TokenGate contracts, but can be used externally as well.

import "@dirtroad/sediment/contracts/tokenChecker/TokenChecker.sol";

Chain Level Token Gating

The TokenGate contract was designed to be deployed once at the chain level and used by any dApp to do high-level token gating.

import "@dirtroad/sediment/contracts/tokenGate/TokenGate.sol";

Project Level Token Gating

The project level token gates are designed per standard token. With an ERC-20, ERC-721, and ERC-1155 token gate available; these can be deployed with a project to offer specific token gating with slightly more direct features.

/// For ERC-20
import "@dirtroad/sediment/contracts/tokenGate/ERC20.sol";

/// For ERC-721
import "@dirtroad/sediment/contracts/tokenGate/ERC721.sol";

/// For ERC-1155
import "@dirtroad/sediment/contracts/tokenGate/ERC1155.sol";

Security and Liability

The Sediment contracts and code is WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

License

See MIT License.

About

Sediment is a smart contract library for Solidity and the EVM offering various building-blocks for projects and EVM chains to offer commonly requested functionality.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published