[ethers.js] ERC20 balance 체크

hardhat task로 만든 ERC20 잔액 확인 태스크

task("balanceERC20", "Check the balance of ERC20 token")
  .addPositionalParam("tokenAddress", "ERC20 Token contract address")
  .addPositionalParam("address", "Address to be checked")
  .setAction(async (taskArgs) => {
    const ERC20 = await ethers.getContractFactory("@openzeppelin/contracts/token/ERC20/ERC20.sol:ERC20");
    const erc20 = await ERC20.attach(taskArgs.tokenAddress);
    console.log(ethers.formatEther(await erc20.balanceOf(taskArgs.address)), await erc20.symbol());
  });

[ethers.js] Transaction details 얻기 및 ERC20 Transfer 정보 얻기

hardhat task로 만든 txHash로 transaction details 얻어서 ERC20 Transfer() 이면 정보 출력.

task("trasactionDetails", "Get the transaction deatils")
  .addPositionalParam("txHash", "Transaction Hash")
  .setAction(async (taskArgs, hre) => {
    const provider = ethers.provider;
    const transaction = await provider.getTransaction(taskArgs.txHash);
    console.log(transaction);
    if (transaction.value === 0n) {
      if (transaction.data.slice(0, 10) === "0xa9059cbb") {
        console.log("---- ERC20 Transfer -------------------------");
        await hre.run("parseERC20TransferData", { data: transaction.data });
      }
    }
  });

task("parseERC20TransferData", "Parsing")
  .addPositionalParam("data", "Transacton Data")
  .setAction(async (taskArgs) => {
    const abiCoder = new ethers.AbiCoder();
    const decodedData = abiCoder.decode(['address', 'uint256'], "0x" + taskArgs.data.slice(10));
    const to = decodedData[0];
    const value = decodedData[1].toString();

    console.log('To Address:', to);
    console.log('Token Amount:', ethers.formatEther(value));
  });

[ethers.js] Contract 시그니처와 hash 확인

const ca = await ethers.getContractFactory("DasomToken");
const cabi = ca.interface;
cabi.format() // Fragments 확인
cabi.forEachFunction((func, index) => { console.log(func.format()); }); // 각 함수의 시그니처 확인
cabi.forEachFunction((func, index) => { console.log(func.format(), ethers.keccak256(ethers.toUtf8Bytes(func.format()))); }); // 시그니처와 해시 값 확인.

WSL Import/Export

Export

wsl.exe --export <DistributionName> <FileName>

WSL 관련 모든 프로그램 닫은 후,

wsl --export Ubuntu-20.04 Ubuntu20.04_dasomoli.wsl

Import

wsl.exe --import <DistributionName> <InstallLocation> <FileName>

Install할 경로 폴더 (C:\Users\dasomoli\AppData\Local\Packages\Ubuntu-20.04-dasomoli)를 만든 후,

wsl --import Ubuntu-20.04-dasomoli C:\Users\dasomoli\AppData\Local\Packages\Ubuntu-20.04-dasomoli Ubuntu20.04-dasomoli.wsl

[git] 추가된 파일이지만 변경은 무시하고 싶은 경우

git에서 repository에 파일은 추가해서 두고 싶지만 해당 파일이 빌드 중 변경되는 등의 이유로 변경은 무시하고 싶은 경우가 있다. 이런 경우 .gitignore에 추가해도 repository에 추가된 파일이므로 변경을 계속 추적하게 된다. 이 변경을 무시하고 싶다면 다음 명령을 주면 된다.

git update-index --assume-unchanged <file>

위 명령을 주면 해당 파일은 변경되어도 git status를 해도 나오지 않고 무시된다. 그러므로 주의해야 한다. 해당 파일을 다시 추적하고 싶다면 다음 명령을 입력한다.

git update-index --no-assume-unchanged <file>

[Javascript] Arrow function 정리

형식

다음은 모두 함수의 선언 혹은 표현식입니다. 마지막 형태가 arrow function입니다.

function dasomoli(arg1, arg2) {}
const dasomoli = function(arg1, arg2) {};
const dasomoli = (arg1, arg2) => {};

function 키워드를 제거하고 “=>” 를 중간에 넣는 형식입니다. 매개 변수 역시 사용 가능합니다.

바로 실행하고 싶은 경우(IIFE: Immediately Invoked Function Expression), 다음과 같이 괄호로 감싸서 실행합니다.

((arg1, arg2) => {
  console.log(arg1);
  console.log(arg2);
})(window, document);

생략 가능 형태

매개 변수가 하나인 경우, ( ) 생략 가능

매개 변수가 하나인 경우 괄호를 생략 가능합니다. 다음은 예제입니다.

const dasomoli = (arg1) => {};
const dasomoli = arg1 => {};

바로 return하는 경우, { }와 return 생략 가능

arrow function이 바로 return 하는 경우, 중괄호 { } 와 return은 생략 가능합니다. 다음은 예제입니다.

const dasomoli = (arg1, arg2) => {
  return arg1 + arg2;
}
const dasomoli = (arg1, arg2) => arg1 + arg2;

바로 { }로 감싼 object를 return 하는 경우, { }와 return은 생략 가능하지만 object를 ( )로 감쌈

예외로 { } 로 감싸는 object를 리턴하는 경우, object 전체를 괄호()로 감싸주어야 합니다. 다음은 예제입니다.

const dasomoli = () => { return { prop1: 1 }; }
// const dasomoli = () => { prop1: 1 } <- 이건 안됩니다.
const dasomoli = () => ({ prop1: 1 });

array는 상관 없습니다.

const dasomoli = () => { return [ v1, v2, v3 ]; }
const dasomoli = () => [ v1, v2, v3 ];

구글의 원온원 템플릿

https://docs.google.com/document/u/0/d/1NZaMq-tA0iksjkhrtqTcopdmoXavbETYWi4w99YI644/mobilebasic

구글의 원온원, 그러니까 1:1 면담을 위한 템플릿이다. 체크리스트처럼 생각하자.

관리자:

휴가 – 팀의 레스토랑 제안은 어떻게 되었나요? [관심 표시]

프로젝트 X의 영향력에 대한 디렉터의 직원 회의에서 칭찬 공유 [빅 픽처]

어떻게 지내셨나요? [체크인/업데이트]

무엇을 도와드릴까요? [장애물/장애물 제거]

예정된 오프사이트 날짜 [관리]

그 밖에 필요한 것이 있나요? [확장]

제가 해드리지 않고 있는 일이 있나요? [효과성 확인]

팀원:

지난주에 제가 한 일: 프로젝트 Y에 대한 업데이트

이번 주에 할 일 프로젝트 X의 v2.0에 대한 디자인 문서 제공

프로젝트 Y의 하위 프로젝트에 지연 가능성 플래그 지정

지난 주 1:1 ABC 토론에 대한 후속 조치 진행

C팀과 프로젝트 수행에 대한 관심 논의

피드백

수평적 관계 피드백: 목적이 동료의 성장을 지원하고 성과를 높이는 수단. 상시 진행 혹은 프로젝트가 종료될 때마다 하는 것이 효과적.

피드백의 틀로써 SBI:

Situation(상황): 피드백을 제공할 행동이 발생한 구체적인 상황을 서술.

Behavior(행동): 피드백의 대상이 되는 행동.

Impact(영향): 피드백의 대상이 되는 행동으로 발생한 영향의 내용을 서술.

지난 주 수요일에(S) Jane님께서 리뷰 전 기획서를 꼼꼼히 읽어주신 덕분에(B) 리뷰 회의 시간을 줄일 수 있었어요(I) Jane님께서 제 기획에 큰 관심을 가져주신 것 같아서 저도 더 열정적으로 임하게 돼요(I) 감사합니다.

비판적 피드백

I화법과 4A 기법

I화법: ‘저는’, ‘제가 느끼기에는’ 등, 내(I) 관점에서 이야기.

Aim to assist(도움에 집중): 도움을 주는 것에 집중. 비난하거나 나무라기 위함이 아님.

Actionable(행동기반): 당장 액션을 취할 수 있는 조언으로 구성.

피드백을 받는 사람이 준 사람에게..

Appreciate(감사하기): 동료에게 감사하기

Aacept or Discord(수용여부 표현하기): 비판적 피드백에 대한 수용 여부는 본인이 판단합니다. 수용하지 않기로 결정했다면 이유와 함께 본인의 대안을 설명합니다.

[Mac] 크롬 브라우저 사용의 몇가지 팁

단축키

  1. Cmd + `: 다른 창 이동
  2. Cmd + W: 탭 닫기
  3. Shift + Cmd + T: 이전에 닫았던 탭을 역순으로 열기
  4. Cmd + Option + 화살표: 탭 간 이동

트랙패드

  1. 두 손가락으로 왼쪽 또는 오른쪽: 이전 혹은 다음
  2. BTT(BetterTouchTool)에서 4 fingers tab을 Cmd + W로 맵핑하면 창 닫기도 터치로 가능

[MySQL] DB auto repair 및 optimize

제공하는 mysqlcheck로 check 및 복구, optimize를 하려면 다음과 같이 한다.

mysqlcheck -u <USER_ID> -p<PASSWORD> --auto-repair <DB_NAME>
mysqlcheck -u <USER_ID> -p<PASSWORD> --optimize <DB_NAME>

예제로 wordpress의 경우, user를 wordpress로 했다면, 다음과 같이 하면 된다.

mysqlcheck -u wordpress -pPASSWORD_HERE --auto-repair wordpress
mysqlcheck -u wordpress -pPASSWORD_HERE --optimize wordpress

근데 wordpress의 경우 테이블을 optimize를 지원하도록 만들지는 않는다…