Refactor repository

This commit is contained in:
HeesungB 2022-12-14 16:52:05 +09:00
parent 01be54ee28
commit 75d50bbe89
9 changed files with 136 additions and 65 deletions

View File

@ -4,9 +4,13 @@ import color from "../../styles/color";
import { Flex1 } from "../../styles/flex-1"; import { Flex1 } from "../../styles/flex-1";
import styled from "styled-components"; import styled from "styled-components";
import Image from "next/image"; import Image from "next/image";
import { SELECTED_WALLET_KEY, WalletType } from "../../constants/wallet"; import {
SELECTED_WALLET_KEY,
WALLET_INSTALL_URL,
WalletType,
} from "../../constants/wallet";
import { getKeplrFromWindow, KeplrWallet } from "../../wallets"; import { getKeplrFromWindow, KeplrWallet } from "../../wallets";
import { loginWithTwitter } from "../../constants/twitter"; import { loginWithTwitter } from "../../repository";
interface Props { interface Props {
wallet: WalletType; wallet: WalletType;
@ -32,8 +36,7 @@ export const WalletItem: FunctionComponent<Props> = (props: Props) => {
const keplr = await getKeplrFromWindow(); const keplr = await getKeplrFromWindow();
if (keplr === undefined) { if (keplr === undefined) {
window.location.href = window.location.href = WALLET_INSTALL_URL;
"https://chrome.google.com/webstore/detail/keplr/dmkamcknogkgcdfhhbddcghachkejeap";
} }
if (keplr) { if (keplr) {

View File

@ -1,3 +1,5 @@
export const MainChainId = "osmo-test-4";
export const RPC_URL = ""; export const RPC_URL = "";
export const REST_URL = "https://lcd.testnet.osmosis.zone"; export const REST_URL = "https://lcd.testnet.osmosis.zone";

View File

@ -1,5 +1,3 @@
import { TwitterAuthUrlResponse } from "../types";
export const twitterOAuthBaseUrl = "https://twitter.com/i/oauth2/authorize"; export const twitterOAuthBaseUrl = "https://twitter.com/i/oauth2/authorize";
export const twitterOAuthScopes = [ export const twitterOAuthScopes = [
@ -9,11 +7,3 @@ export const twitterOAuthScopes = [
]; ];
export const twitterApiBaseUrl = "https://api.twitter.com/2"; export const twitterApiBaseUrl = "https://api.twitter.com/2";
export const loginWithTwitter = async () => {
const { authUrl }: TwitterAuthUrlResponse = await (
await fetch("/api/twitter-auth-url")
).json();
window.location.href = authUrl;
};

View File

@ -3,8 +3,9 @@ import { StaticImageData } from "next/image";
import KeplrIcon from "../public/images/svg/keplr-icon.svg"; import KeplrIcon from "../public/images/svg/keplr-icon.svg";
import CosmostationIcon from "../public/images/svg/cosmostation-icon.svg"; import CosmostationIcon from "../public/images/svg/cosmostation-icon.svg";
export const WALLET_INSTALL_URL =
"https://chrome.google.com/webstore/detail/keplr/dmkamcknogkgcdfhhbddcghachkejeap";
export const SELECTED_WALLET_KEY = "SELECTED_WALLET_KEY"; export const SELECTED_WALLET_KEY = "SELECTED_WALLET_KEY";
export const MainChainId = "osmo-test-4";
export type WalletName = "Keplr" | "Cosmostation"; export type WalletName = "Keplr" | "Cosmostation";
export interface WalletType { export interface WalletType {
@ -25,3 +26,8 @@ export const WalletList: WalletType[] = [
isReady: false, isReady: false,
}, },
]; ];
export const ContractFee = {
denom: "uosmo",
amount: "500000",
};

View File

@ -8,8 +8,32 @@ import color from "../../styles/color";
import AlertCircleOutlineIcon from "../../public/images/svg/alert-circle-outline.svg"; import AlertCircleOutlineIcon from "../../public/images/svg/alert-circle-outline.svg";
import TwitterIcon from "../../public/images/svg/twitter-icon.svg"; import TwitterIcon from "../../public/images/svg/twitter-icon.svg";
import { useRouter } from "next/router";
import { useEffect } from "react";
import { TendermintTxTracer } from "@keplr-wallet/cosmos";
export default function CompletePage() { export default function CompletePage() {
const router = useRouter();
useEffect(() => {
const { txHash } = router.query;
if (txHash) {
traceTX(txHash as string);
}
}, []);
const traceTX = async (txHash: string) => {
const txTracer = new TendermintTxTracer(
"https://rpc.testnet.osmosis.zone",
"/websocket",
);
const result = await txTracer.traceTx(Buffer.from(txHash, "hex"));
console.log(result);
};
return ( return (
<Container> <Container>
<Logo /> <Logo />

View File

@ -21,11 +21,12 @@ import { PrimaryButton } from "../../components/primary-button";
import { TwitterProfile } from "../../components/twitter-profile"; import { TwitterProfile } from "../../components/twitter-profile";
import { ChainList } from "../../components/chain-list"; import { ChainList } from "../../components/chain-list";
import { useRouter } from "next/router"; import { useRouter } from "next/router";
import { MainChainId } from "../../constants/wallet"; import { ContractFee } from "../../constants/wallet";
import { import {
getKeplrFromWindow, getKeplrFromWindow,
KeplrWallet, KeplrWallet,
makeCosmwasmExecMsg, makeCosmwasmExecMsg,
sendMsgs,
simulateMsgs, simulateMsgs,
} from "../../wallets"; } from "../../wallets";
import { ChainIdHelper } from "@keplr-wallet/cosmos"; import { ChainIdHelper } from "@keplr-wallet/cosmos";
@ -34,11 +35,14 @@ import AllChainsIcon from "../../public/images/svg/all-chains-icon.svg";
import { AllChainsItem } from "../../components/chain-list/all-chains-item"; import { AllChainsItem } from "../../components/chain-list/all-chains-item";
import { SearchInput } from "../../components/search-input"; import { SearchInput } from "../../components/search-input";
import { import {
MainChainId,
REGISTRAR_ADDRESS, REGISTRAR_ADDRESS,
RESOLVER_ADDRESS, RESOLVER_ADDRESS,
REST_URL, REST_URL,
} from "../../constants/icns"; } from "../../constants/icns";
import { fetchTwitterInfo } from "../../repository";
export default function VerificationPage() { export default function VerificationPage() {
const router = useRouter(); const router = useRouter();
const [twitterAuthInfo, setTwitterAuthInfo] = const [twitterAuthInfo, setTwitterAuthInfo] =
@ -53,39 +57,44 @@ export default function VerificationPage() {
const [allChecked, setAllChecked] = useState(false); const [allChecked, setAllChecked] = useState(false);
const [searchValue, setSearchValue] = useState(""); const [searchValue, setSearchValue] = useState("");
const fetchUrlQueryParameter = (): { state: string; code: string } => {
// Twitter state, auth code check
const [, state, code] =
window.location.search.match(
/^(?=.*state=([^&]+)|)(?=.*code=([^&]+)|).+$/,
) || [];
return {
state,
code,
};
};
useEffect(() => { useEffect(() => {
const handleVerification = async () => { const init = async () => {
if (window.location.search) { if (window.location.search) {
// Twitter Login Error Check
if (window.location.search.match("error")) { if (window.location.search.match("error")) {
await router.push("/"); await router.push("/");
return; return;
} }
const twitterInfo = await fetchTwitterInfo(); const { state, code } = fetchUrlQueryParameter();
// Fetch Twitter Profile
const twitterInfo = await fetchTwitterInfo(state, code);
setTwitterAuthInfo(twitterInfo); setTwitterAuthInfo(twitterInfo);
// Initialize Wallet
await initWallet(); await initWallet();
setIsLoading(false); setIsLoading(false);
} }
}; };
handleVerification(); init();
}, []); }, []);
const fetchTwitterInfo = async (): Promise<TwitterAuthInfoResponse> => {
const [, state, code] =
window.location.search.match(
/^(?=.*state=([^&]+)|)(?=.*code=([^&]+)|).+$/,
) || [];
const newTwitterAuthInfo = await request<TwitterAuthInfoResponse>(
`/api/twitter-auth-info?state=${state}&code=${code}`,
);
return newTwitterAuthInfo;
};
const initWallet = async () => { const initWallet = async () => {
const keplr = await getKeplrFromWindow(); const keplr = await getKeplrFromWindow();
@ -96,27 +105,12 @@ export default function VerificationPage() {
}; };
useEffect(() => { useEffect(() => {
// After Wallet Initialize
if (wallet) { if (wallet) {
fetchAllChains();
fetchChainList(); fetchChainList();
} }
}, [wallet]); }, [wallet]);
const fetchAllChains = async () => {
if (wallet) {
const chainNames = (await wallet.getChainInfosWithoutEndpoints()).map(
(chainInfo) => chainInfo.chainName,
);
setAllChains({
chainId: "all chains",
prefix: `all chains(${chainNames.length})`,
address: chainNames.join(", "),
chainImageUrl: AllChainsIcon,
});
}
};
const fetchChainList = async () => { const fetchChainList = async () => {
if (wallet) { if (wallet) {
const chainIds = (await wallet.getChainInfosWithoutEndpoints()).map( const chainIds = (await wallet.getChainInfosWithoutEndpoints()).map(
@ -130,6 +124,7 @@ export default function VerificationPage() {
(chainInfo) => { (chainInfo) => {
return { return {
chainId: chainInfo.chainId, chainId: chainInfo.chainId,
chainName: chainInfo.chainName,
prefix: chainInfo.bech32Config.bech32PrefixAccAddr, prefix: chainInfo.bech32Config.bech32PrefixAccAddr,
chainImageUrl: `https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/${ chainImageUrl: `https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/${
ChainIdHelper.parse(chainInfo.chainId).identifier ChainIdHelper.parse(chainInfo.chainId).identifier
@ -138,7 +133,7 @@ export default function VerificationPage() {
}, },
); );
const chainArray: ChainItemType[] = []; const chainArray = [];
for (let i = 0; i < chainKeys.length; i++) { for (let i = 0; i < chainKeys.length; i++) {
chainArray.push({ chainArray.push({
address: chainKeys[i].bech32Address, address: chainKeys[i].bech32Address,
@ -147,8 +142,28 @@ export default function VerificationPage() {
} }
// remove duplicated item // remove duplicated item
const filteredChainList = chainArray.filter((chain, index, self) => { const filteredChainList = chainArray.filter((nextChain, index, self) => {
return index === self.findIndex((t) => chain.prefix === t.prefix); return (
index ===
self.findIndex((prevChain) => {
const isDuplicated = prevChain.prefix === nextChain.prefix;
if (isDuplicated && prevChain.chainName !== nextChain.chainName) {
console.log(
`${nextChain.chainName} has been deleted due to a duplicate name with ${prevChain.chainName}`,
);
}
return isDuplicated;
})
);
});
setAllChains({
chainId: "all chains",
prefix: `all chains(${filteredChainList.length})`,
address: chainInfos.map((chainInfo) => chainInfo.chainName).join(", "),
chainImageUrl: AllChainsIcon,
}); });
setChainList(filteredChainList); setChainList(filteredChainList);
@ -159,7 +174,7 @@ export default function VerificationPage() {
if (wallet) { if (wallet) {
const key = await wallet.getKey(MainChainId); const key = await wallet.getKey(MainChainId);
const icnsVerificationList = ( return (
await request<IcnsVerificationResponse>("/api/icns-verification", { await request<IcnsVerificationResponse>("/api/icns-verification", {
method: "post", method: "post",
headers: { headers: {
@ -171,8 +186,6 @@ export default function VerificationPage() {
}), }),
}) })
).verificationList; ).verificationList;
return icnsVerificationList;
} }
}; };
@ -184,20 +197,19 @@ export default function VerificationPage() {
(chain) => (chain as ChainItemType).chainId, (chain) => (chain as ChainItemType).chainId,
); );
const adr36Infos = await wallet.signICNSAdr36( return await wallet.signICNSAdr36(
MainChainId, MainChainId,
RESOLVER_ADDRESS, RESOLVER_ADDRESS,
key.bech32Address, key.bech32Address,
twitterAuthInfo.username, twitterAuthInfo.username,
chainIds, chainIds,
); );
return adr36Infos;
} }
}; };
const onClickRegistration = async () => { const onClickRegistration = async () => {
const twitterInfo = await fetchTwitterInfo(); const { state, code } = fetchUrlQueryParameter();
const twitterInfo = await fetchTwitterInfo(state, code);
const adr36Infos = await checkAdr36(); const adr36Infos = await checkAdr36();
@ -228,12 +240,7 @@ export default function VerificationPage() {
}), }),
}, },
}, },
[ [ContractFee],
{
denom: "uosmo",
amount: "500000",
},
],
); );
const addressMsgs = adr36Infos.map((adr36Info) => { const addressMsgs = adr36Infos.map((adr36Info) => {
@ -280,7 +287,24 @@ export default function VerificationPage() {
}, },
); );
console.log("simulated", simulated); const txHash = await sendMsgs(
wallet,
chainInfo,
key.bech32Address,
{
amino: aminoMsgs,
proto: protoMsgs,
},
{
amount: [],
gas: Math.floor(simulated.gasUsed * 1.5).toString(),
},
);
router.push({
pathname: "complete",
query: { txHash: Buffer.from(txHash).toString("hex") },
});
} }
}; };

0
repository/icns.ts Normal file
View File

1
repository/index.ts Normal file
View File

@ -0,0 +1 @@
export * from "./twitter";

21
repository/twitter.ts Normal file
View File

@ -0,0 +1,21 @@
import { TwitterAuthInfoResponse, TwitterAuthUrlResponse } from "../types";
import { request } from "../utils/url";
export const loginWithTwitter = async () => {
const { authUrl }: TwitterAuthUrlResponse = await (
await fetch("/api/twitter-auth-url")
).json();
window.location.href = authUrl;
};
export const fetchTwitterInfo = async (
state: string,
code: string,
): Promise<TwitterAuthInfoResponse> => {
const newTwitterAuthInfo = await request<TwitterAuthInfoResponse>(
`/api/twitter-auth-info?state=${state}&code=${code}`,
);
return newTwitterAuthInfo;
};