Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
@uniswap/swap-router-contracts
Advanced tools
This repository contains smart contracts for swapping on the Uniswap V2 and V3 protocols.
This repository is subject to the Uniswap V3 bug bounty program, per the terms defined here.
In order to deploy this code to a local testnet, you should install the npm package
@uniswap/swap-router-contracts
and import bytecode imported from artifacts located at
@uniswap/swap-router-contracts/artifacts/contracts/*/*.json
.
For example:
import {
abi as SWAP_ROUTER_ABI,
bytecode as SWAP_ROUTER_BYTECODE,
} from '@uniswap/swap-router-contracts/artifacts/contracts/SwapRouter02.sol/SwapRouter02.json'
// deploy the bytecode
This will ensure that you are testing against the same bytecode that is deployed to mainnet and public testnets, and all Uniswap code will correctly interoperate with your local deployment.
The swap router contract interfaces are available for import into solidity smart contracts
via the npm artifact @uniswap/swap-router-contracts
, e.g.:
import '@uniswap/swap-router-contracts/contracts/interfaces/ISwapRouter02.sol';
contract MyContract {
ISwapRouter02 router;
function doSomethingWithSwapRouter() {
// router.exactInput(...);
}
}
Some tests use Hardhat mainnet forking and therefore require an archive node.
Either create a .env
file in the workspace root containing:
ARCHIVE_RPC_URL='...'
Or set the variable when running tests:
export ARCHIVE_RPC_URL='...' && npm run test
FAQs
Smart contracts for swapping on Uniswap V2 and V3
The npm package @uniswap/swap-router-contracts receives a total of 52,718 weekly downloads. As such, @uniswap/swap-router-contracts popularity was classified as popular.
We found that @uniswap/swap-router-contracts demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 9 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.