Repository: LaqiraProtocol/Laqira-Token-Faucet
Branch: main
Commit: 10251c805ac9
Files: 7
Total size: 6.9 KB
Directory structure:
gitextract_l3up3fbz/
├── .gitignore
├── contracts/
│ ├── LaqiraTokenFaucet.sol
│ └── Migrations.sol
├── migrations/
│ └── 1_initial_migration.js
├── package.json
├── test/
│ └── .gitkeep
└── truffle-config.js
================================================
FILE CONTENTS
================================================
================================================
FILE: .gitignore
================================================
node_modules
build
================================================
FILE: contracts/LaqiraTokenFaucet.sol
================================================
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
interface IBEP20 {
function transfer(address recipient, uint256 amount) external returns (bool);
}
contract LaqiraTokenFaucet {
address private owner;
address private laqiraTokenAddress;
uint256 private withdrawalAmount;
mapping(address => uint256) private withdrawTimestamp;
constructor(address _laqiraToken) {
owner = msg.sender;
laqiraTokenAddress = _laqiraToken;
withdrawalAmount = 10000000000000000000000;
}
function setWithdrawalAmount(uint256 _amount) public onlyOwner {
withdrawalAmount = _amount;
}
function getWithdrawalAmount() public view returns (uint256) {
return withdrawalAmount;
}
function transferAnyBEP20() public returns (bool) {
require(block.timestamp - withdrawTimestamp[msg.sender] > 1 days, 'You have reached daily withdrawal limit');
IBEP20(laqiraTokenAddress).transfer(msg.sender, withdrawalAmount);
withdrawTimestamp[msg.sender] = block.timestamp;
return true;
}
function getLaqiraTokenAddress() public view returns (address) {
return laqiraTokenAddress;
}
function getUserTimestamp() public view returns (uint256) {
return withdrawTimestamp[msg.sender];
}
modifier onlyOwner {
require(msg.sender == owner);
_;
}
}
================================================
FILE: contracts/Migrations.sol
================================================
// SPDX-License-Identifier: MIT
pragma solidity >=0.4.22 <0.9.0;
contract Migrations {
address public owner = msg.sender;
uint public last_completed_migration;
modifier restricted() {
require(
msg.sender == owner,
"This function is restricted to the contract's owner"
);
_;
}
function setCompleted(uint completed) public restricted {
last_completed_migration = completed;
}
}
================================================
FILE: migrations/1_initial_migration.js
================================================
const Migrations = artifacts.require("Migrations");
module.exports = function (deployer) {
deployer.deploy(Migrations);
};
================================================
FILE: package.json
================================================
{
"name": "LaqiraTokenFaucet",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC"
}
================================================
FILE: test/.gitkeep
================================================
================================================
FILE: truffle-config.js
================================================
/**
* Use this file to configure your truffle project. It's seeded with some
* common settings for different networks and features like migrations,
* compilation and testing. Uncomment the ones you need or modify
* them to suit your project as necessary.
*
* More information about configuration can be found at:
*
* trufflesuite.com/docs/advanced/configuration
*
* To deploy via Infura you'll need a wallet provider (like @truffle/hdwallet-provider)
* to sign your transactions before they're sent to a remote public node. Infura accounts
* are available for free at: infura.io/register.
*
* You'll also need a mnemonic - the twelve word phrase the wallet uses to generate
* public/private key pairs. If you're publishing your code to GitHub make sure you load this
* phrase from a file you've .gitignored so it doesn't accidentally become public.
*
*/
// const HDWalletProvider = require('@truffle/hdwallet-provider');
//
// const fs = require('fs');
// const mnemonic = fs.readFileSync(".secret").toString().trim();
module.exports = {
/**
* Networks define how you connect to your ethereum client and let you set the
* defaults web3 uses to send transactions. If you don't specify one truffle
* will spin up a development blockchain for you on port 9545 when you
* run `develop` or `test`. You can ask a truffle command to use a specific
* network from the command line, e.g
*
* $ truffle test --network <network-name>
*/
networks: {
// Useful for testing. The `development` name is special - truffle uses it by default
// if it's defined here and no other network is specified at the command line.
// You should run a client (like ganache-cli, geth or parity) in a separate terminal
// tab if you use this network and you must also set the `host`, `port` and `network_id`
// options below to some value.
//
// development: {
// host: "127.0.0.1", // Localhost (default: none)
// port: 8545, // Standard Ethereum port (default: none)
// network_id: "*", // Any network (default: none)
// },
// Another network with more advanced options...
// advanced: {
// port: 8777, // Custom port
// network_id: 1342, // Custom network
// gas: 8500000, // Gas sent with each transaction (default: ~6700000)
// gasPrice: 20000000000, // 20 gwei (in wei) (default: 100 gwei)
// from: <address>, // Account to send txs from (default: accounts[0])
// websocket: true // Enable EventEmitter interface for web3 (default: false)
// },
// Useful for deploying to a public network.
// NB: It's important to wrap the provider as a function.
// ropsten: {
// provider: () => new HDWalletProvider(mnemonic, `https://ropsten.infura.io/v3/YOUR-PROJECT-ID`),
// network_id: 3, // Ropsten's id
// gas: 5500000, // Ropsten has a lower block limit than mainnet
// confirmations: 2, // # of confs to wait between deployments. (default: 0)
// timeoutBlocks: 200, // # of blocks before a deployment times out (minimum/default: 50)
// skipDryRun: true // Skip dry run before migrations? (default: false for public nets )
// },
// Useful for private networks
// private: {
// provider: () => new HDWalletProvider(mnemonic, `https://network.io`),
// network_id: 2111, // This network is yours, in the cloud.
// production: true // Treats this network as if it was a public net. (default: false)
// }
},
// Set default mocha options here, use special reporters etc.
mocha: {
// timeout: 100000
},
// Configure your compilers
compilers: {
solc: {
version: "0.8.0", // Fetch exact version from solc-bin (default: truffle's version)
// docker: true, // Use "0.5.1" you've installed locally with docker (default: false)
// settings: { // See the solidity docs for advice about optimization and evmVersion
// optimizer: {
// enabled: false,
// runs: 200
// },
// evmVersion: "byzantium"
// }
}
},
// Truffle DB is currently disabled by default; to enable it, change enabled:
// false to enabled: true. The default storage location can also be
// overridden by specifying the adapter settings, as shown in the commented code below.
//
// NOTE: It is not possible to migrate your contracts to truffle DB and you should
// make a backup of your artifacts to a safe location before enabling this feature.
//
// After you backed up your artifacts you can utilize db by running migrate as follows:
// $ truffle migrate --reset --compile-all
//
// db: {
// enabled: false,
// host: "127.0.0.1",
// adapter: {
// name: "sqlite",
// settings: {
// directory: ".db"
// }
// }
// }
};
gitextract_l3up3fbz/ ├── .gitignore ├── contracts/ │ ├── LaqiraTokenFaucet.sol │ └── Migrations.sol ├── migrations/ │ └── 1_initial_migration.js ├── package.json ├── test/ │ └── .gitkeep └── truffle-config.js
Condensed preview — 7 files, each showing path, character count, and a content snippet. Download the .json file or copy for the full structured content (8K chars).
[
{
"path": ".gitignore",
"chars": 18,
"preview": "node_modules\nbuild"
},
{
"path": "contracts/LaqiraTokenFaucet.sol",
"chars": 1391,
"preview": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBEP20 {\n function transfer(address recipient, uin"
},
{
"path": "contracts/Migrations.sol",
"chars": 419,
"preview": "// SPDX-License-Identifier: MIT\npragma solidity >=0.4.22 <0.9.0;\n\ncontract Migrations {\n address public owner = msg.sen"
},
{
"path": "migrations/1_initial_migration.js",
"chars": 126,
"preview": "const Migrations = artifacts.require(\"Migrations\");\n\nmodule.exports = function (deployer) {\n deployer.deploy(Migrations"
},
{
"path": "package.json",
"chars": 231,
"preview": "{\n \"name\": \"LaqiraTokenFaucet\",\n \"version\": \"1.0.0\",\n \"description\": \"\",\n \"main\": \"index.js\",\n \"scripts\": {\n \"te"
},
{
"path": "test/.gitkeep",
"chars": 0,
"preview": ""
},
{
"path": "truffle-config.js",
"chars": 4900,
"preview": "/**\n * Use this file to configure your truffle project. It's seeded with some\n * common settings for different networks "
}
]
About this extraction
This page contains the full source code of the LaqiraProtocol/Laqira-Token-Faucet GitHub repository, extracted and formatted as plain text for AI agents and large language models (LLMs). The extraction includes 7 files (6.9 KB), approximately 2.0k tokens. Use this with OpenClaw, Claude, ChatGPT, Cursor, Windsurf, or any other AI tool that accepts text input. You can copy the full output to your clipboard or download it as a .txt file.
Extracted by GitExtract — free GitHub repo to text converter for AI. Built by Nikandr Surkov.