Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sub 1s loading UI #169

Merged
merged 27 commits into from
Feb 26, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
35d0b99
feat: call db to retrieve permits instead of parsing github
gentlementlegen Feb 17, 2024
7528f3e
chore: issue number now uses the value from git get request
gentlementlegen Feb 17, 2024
2b21d66
Merge branch 'development' into permit-urls-from-db
Feb 17, 2024
655ead5
chore: fixed merged characters
gentlementlegen Feb 17, 2024
72b23f2
Merge remote-tracking branch 'origin/development' into permit-urls-fr…
gentlementlegen Feb 19, 2024
3b7c3d2
Merge remote-tracking branch 'pay.ubiquity/development' into permit-u…
gentlementlegen Feb 19, 2024
2f11234
chore: merged development branch
gentlementlegen Feb 19, 2024
0878552
chore: added Action secrets to the build.yml
gentlementlegen Feb 19, 2024
f5e3a80
feat: sub 1s load time
Keyrxng Feb 20, 2024
ebd54e1
fix: conflicts
Keyrxng Feb 20, 2024
7fab1b4
chore: fetch inside try
Keyrxng Feb 20, 2024
f1ca988
feat: sub 1s load time
Keyrxng Feb 20, 2024
97fb13c
chore: fetch inside try
Keyrxng Feb 20, 2024
2adf64b
fix: revert and pull from head
Keyrxng Feb 20, 2024
a1c6e4b
chore: renamed supabase key to SUPABASE_PUBLIC_ANON_KEY
gentlementlegen Feb 21, 2024
0ba50af
chore: renamed supabase key to SUPABASE_ANON_KEY
gentlementlegen Feb 21, 2024
5a504fd
chore: allow personal repo to be searched
gentlementlegen Feb 21, 2024
ba87b12
chore: renamed supabase env variables
gentlementlegen Feb 21, 2024
53ab0ec
Merge pull request #164 from FernandVEYRIER/permit-urls-from-db
0x4007 Feb 21, 2024
b592128
Merge branch 'fix/perf' into development
0x4007 Feb 21, 2024
c0249df
Merge branch 'ubiquity:development' into speed-improvements
Keyrxng Feb 21, 2024
517dd48
fix: use allnetworkurls
Keyrxng Feb 21, 2024
1fe025d
fix: rpc blacklist
Keyrxng Feb 23, 2024
fd9a8e5
fix: continuous deploys
0x4007 Feb 25, 2024
24284bd
Merge pull request #176 from pavlovcik/fix/cd
0x4007 Feb 25, 2024
6f3bfdf
Merge branch 'ubiquity:development' into speed-improvements
Keyrxng Feb 26, 2024
16a534e
fix: no network resolved
Keyrxng Feb 26, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 10 additions & 11 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,18 @@ on:
pull_request:
workflow_dispatch:

permissions:
contents: read

jobs:
build:
runs-on: ubuntu-22.04
permissions:
contents: read

steps:
- name: Check out repository
uses: actions/checkout@v4
with:
submodules: "recursive" # Ensures submodules are checked out
# with:
# submodules: "recursive" # Ensures submodules are checked out

- name: Set up Node.js
uses: actions/setup-node@v4
Expand All @@ -25,19 +27,16 @@ jobs:
run: |
yarn
yarn build
echo -n $(echo "${{ github.event_name == 'pull_request' && github.event.pull_request.head.sha || github.sha }}" | cut -c1-7) > static/commit.txt
env: # Set environment variables for the build
SUPABASE_URL: "https://wfzpewmlyiozupulbuur.supabase.co"
SUPABASE_ANON_KEY: "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6IndmenBld21seWlvenVwdWxidXVyIiwicm9sZSI6ImFub24iLCJpYXQiOjE2OTU2NzQzMzksImV4cCI6MjAxMTI1MDMzOX0.SKIL3Q0NOBaMehH0ekFspwgcu3afp3Dl9EDzPqs1nKs"

- name: Deploy to Cloudflare
if: env.skip != 'true'
uses: ubiquity/cloudflare-deploy-action@main
with:
cloudflare_api_token: JWo5dPsoyohH5PRu89-RktjCvRN0-ODC6CC9ZBqF # Specifically scoped for public contributors to automatically deploy to our team Cloudflare account
repository: ${{ github.repository }}
production_branch: ${{ github.event.repository.default_branch }}
output_directory: "static"
current_branch: ${{ github.ref_name }}
pull_request_number: ${{ github.event.pull_request.number }}
commit_sha: ${{ github.sha }}
# Add any environment variables you need to pass along here
# SUPABASE_URL: ${{ secrets.SUPABASE_URL }}
# SUPABASE_KEY: ${{ secrets.SUPABASE_KEY }}
commit_sha: ${{ github.event.pull_request.head.sha }}
2 changes: 1 addition & 1 deletion .github/workflows/conventional-commits.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,5 +8,5 @@ jobs:
name: Conventional Commits
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
- uses: ubiquity/action-conventional-commits@master
56 changes: 51 additions & 5 deletions build/esbuild-build.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
// @ts-expect-error - Could not find a declaration file for module
import extraRpcs from "../lib/chainlist/constants/extraRpcs";
import esbuild from "esbuild";
import * as dotenv from "dotenv";
const typescriptEntries = [
"static/scripts/rewards/index.ts",
"static/scripts/audit-report/audit.ts",
Expand All @@ -12,9 +14,35 @@ export const entries = [...typescriptEntries, ...cssEntries];
const allNetworkUrls: Record<string, string[]> = {};
// this flattens all the rpcs into a single object, with key names that match the networkIds. The arrays are just of URLs per network ID.

const blacklist = ["https://xdai-archive.blockscout.com", "https://gnosis.api.onfinality.io/public"];
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This blacklist idea doesn't seem like a robust approach. We can merge it in but it should be handled dynamically. I think I implemented this in an unstable manner on my branch, I vaguely recall.

Copy link
Contributor Author

@Keyrxng Keyrxng Feb 26, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since the issue is that the claim button flickers on a failure then finding out why exactly that's happening because of a failed background call would probs be the best way to handle it I guess, otherwise just try{}catch() and don't log the error? seems hacky we could care less if one or two calls have failed

Copy link
Member

@0x4007 0x4007 Feb 26, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's because the CSS/style logic is implemented poorly. I tore it apart in my refactor but didn't get to put it all together in a totally stable way (mostly the other RPC related functions- I believe the styling code was significantly simplified and stable if I recall correctly).

Unfortunately I'm running very low on code time because I'll need to focus on fundraising starting next week. So I'm just going to be focusing on top priority stuff.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Luckily for me I've got nothing but code time, regretfully it does eventually require that you have review time lmao but I'll keep on pushing forward with things as best I can in the meantime, cheers for the heads up


Object.keys(extraRpcs).forEach((networkId) => {
const officialUrls = extraRpcs[networkId].rpcs.filter((rpc) => typeof rpc === "string");
const extraUrls: string[] = extraRpcs[networkId].rpcs.filter((rpc) => rpc.url !== undefined).map((rpc) => rpc.url);
const officialUrls = extraRpcs[networkId].rpcs.filter((rpc) => {
if (typeof rpc === "string") {
if (blacklist.includes(rpc)) {
return null;
} else {
return rpc;
}
}
});
const extraUrls: string[] = extraRpcs[networkId].rpcs
.filter((rpc) => rpc.url !== undefined)
.map((rpc) => {
if (typeof rpc === "string") {
if (blacklist.includes(rpc)) {
return "";
} else {
return rpc;
}
} else {
if (blacklist.includes(rpc.url)) {
return "";
} else {
return rpc.url;
}
}
});
allNetworkUrls[networkId] = [...officialUrls, ...extraUrls];
});

Expand All @@ -32,9 +60,7 @@ export const esBuildContext: esbuild.BuildOptions = {
".svg": "dataurl",
},
outdir: "static/out",
define: {
extraRpcs: JSON.stringify(allNetworkUrls),
},
define: createEnvDefines(["SUPABASE_URL", "SUPABASE_ANON_KEY"], { allNetworkUrls }),
};

esbuild
Expand All @@ -46,3 +72,23 @@ esbuild
console.error(err);
process.exit(1);
});

function createEnvDefines(envVarNames: string[], extras: Record<string, unknown>): Record<string, string> {
const defines: Record<string, string> = {};
dotenv.config();
for (const name of envVarNames) {
const envVar = process.env[name];
if (envVar !== undefined) {
defines[name] = JSON.stringify(envVar);
} else {
throw new Error(`Missing environment variable: ${name}`);
}
}
for (const key in extras) {
if (Object.prototype.hasOwnProperty.call(extras, key)) {
defines[key] = JSON.stringify(extras[key]);
}
}
defines["extraRpcs"] = JSON.stringify(allNetworkUrls);
return defines;
}
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
"@octokit/plugin-throttling": "^8.1.3",
"@octokit/rest": "^20.0.2",
"@sinclair/typebox": "^0.32.14",
"@supabase/supabase-js": "2.39.7",
"@types/libsodium-wrappers": "^0.7.13",
"@uniswap/permit2-sdk": "^1.2.0",
"axios": "^1.6.7",
Expand Down
19 changes: 12 additions & 7 deletions scripts/typescript/generate-permit2-url.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,13 @@ dotenv.config();

const PERMIT2_ADDRESS = "0x000000000022D473030F116dDEE9F6B43aC78BA3"; // same on all chains

generate().catch((error) => {
generateERC20Permit().catch((error) => {
console.error(error);
verifyEnvironmentVariables();
process.exitCode = 1;
});

async function generate() {
export async function generateERC20Permit(multi = false) {
const provider = new ethers.providers.JsonRpcProvider(process.env.RPC_PROVIDER_URL);
const myWallet = new ethers.Wallet(process.env.UBIQUIBOT_PRIVATE_KEY || "", provider);

Expand Down Expand Up @@ -59,9 +59,14 @@ async function generate() {
];

const base64encodedTxData = Buffer.from(JSON.stringify(txData)).toString("base64");
log.ok("Testing URL:");
console.log(`${process.env.FRONTEND_URL}?claim=${base64encodedTxData}`);
log.ok("Public URL:");
console.log(`https://pay.ubq.fi?claim=${base64encodedTxData}`);
console.log();

if (multi) {
return `${process.env.FRONTEND_URL}?claim=${base64encodedTxData}`;
} else {
log.ok("Testing URL:");
console.log(`${process.env.FRONTEND_URL}?claim=${base64encodedTxData}`);
log.ok("Public URL:");
console.log(`https://pay.ubq.fi?claim=${base64encodedTxData}`);
console.log();
}
}
16 changes: 16 additions & 0 deletions scripts/typescript/multi-permits.t.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import { generateERC20Permit } from "./generate-permit2-url";
import { log, verifyEnvironmentVariables } from "./utils";

export async function generateMultiERC20Permits() {
for (let i = 0; i < 5; i++) {
const url = await generateERC20Permit();
log.ok("Testing URL:");
console.log(url);
}
}

generateMultiERC20Permits().catch((error) => {
console.error(error);
verifyEnvironmentVariables();
process.exitCode = 1;
});
Loading