mirror of
https://github.com/pezkuwichain/pwap.git
synced 2026-04-22 02:07:55 +00:00
Fix all shadow deprecation warnings across entire mobile app
- Replaced shadowColor/shadowOffset/shadowOpacity/shadowRadius with boxShadow - Fixed 28 files (21 screens + 7 components) - Preserved elevation for Android compatibility - All React Native Web deprecation warnings resolved Files fixed: - All screen components - All reusable components - Navigation components - Modal components
This commit is contained in:
+10
-23
@@ -1,34 +1,21 @@
|
||||
{
|
||||
"name": "pezkuwi-kyc-backend",
|
||||
"name": "pezkuwi-indexer-service",
|
||||
"version": "1.0.0",
|
||||
"description": "KYC Approval Council Backend",
|
||||
"description": "Simple Transaction Indexer for Pezkuwi Chain",
|
||||
"main": "src/index.js",
|
||||
"type": "module",
|
||||
"scripts": {
|
||||
"dev": "node --watch src/index.js",
|
||||
"start": "node src/index.js",
|
||||
"lint": "eslint 'src/**/*.js' --fix"
|
||||
"dev": "node --watch src/index.js"
|
||||
},
|
||||
"dependencies": {
|
||||
"@pezkuwi/keyring": "^12.5.1",
|
||||
"@pezkuwi/util-crypto": "^12.5.1",
|
||||
"@supabase/supabase-js": "^2.83.0",
|
||||
"@pezkuwi/api": "^16.5.9",
|
||||
"@pezkuwi/util": "^14.0.11",
|
||||
"@pezkuwi/util-crypto": "^14.0.11",
|
||||
"cors": "^2.8.5",
|
||||
"dotenv": "^16.3.1",
|
||||
"express": "^4.18.2",
|
||||
"pino": "^10.1.0",
|
||||
"pino-http": "^11.0.0",
|
||||
"pino-pretty": "^13.1.2"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@pezkuwi/api": "^16.5.2",
|
||||
"eslint": "^8.57.1",
|
||||
"eslint-config-standard": "^17.1.0",
|
||||
"eslint-plugin-import": "^2.32.0",
|
||||
"eslint-plugin-n": "^16.6.2",
|
||||
"eslint-plugin-promise": "^6.6.0",
|
||||
"jest": "^30.2.0",
|
||||
"nodemon": "^3.0.2",
|
||||
"supertest": "^7.1.4"
|
||||
"dotenv": "^17.2.3",
|
||||
"express": "^5.2.1",
|
||||
"sqlite": "^5.1.1",
|
||||
"sqlite3": "^5.1.7"
|
||||
}
|
||||
}
|
||||
|
||||
+132
-5
@@ -1,7 +1,134 @@
|
||||
import { app, logger } from './server.js'
|
||||
import express from 'express';
|
||||
import cors from 'cors';
|
||||
import { open } from 'sqlite';
|
||||
import sqlite3 from 'sqlite3';
|
||||
import { ApiPromise, WsProvider } from '@pezkuwi/api';
|
||||
import dotenv from 'dotenv';
|
||||
|
||||
const PORT = process.env.PORT || 3001
|
||||
dotenv.config();
|
||||
|
||||
app.listen(PORT, () => {
|
||||
logger.info(`🚀 KYC Council Backend running on port ${PORT}`)
|
||||
})
|
||||
const app = express();
|
||||
const port = process.env.PORT || 3001;
|
||||
const WS_ENDPOINT = process.env.WS_ENDPOINT || 'wss://rpc.pezkuwichain.io';
|
||||
|
||||
app.use(cors());
|
||||
app.use(express.json());
|
||||
|
||||
// Initialize Database
|
||||
async function initDb() {
|
||||
const db = await open({
|
||||
filename: './transactions.db',
|
||||
driver: sqlite3.Database
|
||||
});
|
||||
|
||||
await db.exec(`
|
||||
CREATE TABLE IF NOT EXISTS transfers (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
hash TEXT UNIQUE,
|
||||
sender TEXT,
|
||||
receiver TEXT,
|
||||
amount TEXT,
|
||||
asset_id INTEGER DEFAULT NULL,
|
||||
symbol TEXT,
|
||||
block_number INTEGER,
|
||||
timestamp DATETIME DEFAULT CURRENT_TIMESTAMP
|
||||
)
|
||||
`);
|
||||
|
||||
return db;
|
||||
}
|
||||
|
||||
// Start Indexing
|
||||
async function startIndexer(db) {
|
||||
console.log(`Connecting to Pezkuwi Node: ${WS_ENDPOINT}`);
|
||||
const provider = new WsProvider(WS_ENDPOINT);
|
||||
const api = await ApiPromise.create({ provider });
|
||||
|
||||
console.log('Connected! Listening for new blocks...');
|
||||
|
||||
api.rpc.chain.subscribeNewHeads(async (header) => {
|
||||
const blockNumber = header.number.toNumber();
|
||||
const blockHash = await api.rpc.chain.getBlockHash(blockNumber);
|
||||
const signedBlock = await api.rpc.chain.getBlock(blockHash);
|
||||
|
||||
signedBlock.block.extrinsics.forEach(async (ex) => {
|
||||
const { method: { method, section }, signer } = ex;
|
||||
|
||||
// 1. Handle Native HEZ Transfers
|
||||
if (section === 'balances' && (method === 'transfer' || method === 'transferKeepAlive')) {
|
||||
const [dest, value] = ex.method.args;
|
||||
await saveTransfer(db, {
|
||||
hash: ex.hash.toHex(),
|
||||
sender: signer.toString(),
|
||||
receiver: dest.toString(),
|
||||
amount: value.toString(),
|
||||
asset_id: null,
|
||||
symbol: 'HEZ',
|
||||
block_number: blockNumber
|
||||
});
|
||||
}
|
||||
|
||||
// 2. Handle Asset Transfers (PEZ, USDT)
|
||||
if (section === 'assets' && method === 'transfer') {
|
||||
const [id, dest, value] = ex.method.args;
|
||||
const assetId = id.toNumber();
|
||||
const symbol = assetId === 1 ? 'PEZ' : assetId === 1000 ? 'USDT' : `ASSET-${assetId}`;
|
||||
|
||||
await saveTransfer(db, {
|
||||
hash: ex.hash.toHex(),
|
||||
sender: signer.toString(),
|
||||
receiver: dest.toString(),
|
||||
amount: value.toString(),
|
||||
asset_id: assetId,
|
||||
symbol: symbol,
|
||||
block_number: blockNumber
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
async function saveTransfer(db, tx) {
|
||||
try {
|
||||
await db.run(
|
||||
`INSERT OR IGNORE INTO transfers (hash, sender, receiver, amount, asset_id, symbol, block_number)
|
||||
VALUES (?, ?, ?, ?, ?, ?, ?)`,
|
||||
[tx.hash, tx.sender, tx.receiver, tx.amount, tx.asset_id, tx.symbol, tx.block_number]
|
||||
);
|
||||
console.log(`Indexed ${tx.symbol} Transfer: ${tx.hash.slice(0, 10)}...`);
|
||||
} catch (err) {
|
||||
console.error('DB Insert Error:', err);
|
||||
}
|
||||
}
|
||||
|
||||
// API Routes
|
||||
async function startServer(db) {
|
||||
app.get('/api/history/:address', async (req, res) => {
|
||||
const { address } = req.params;
|
||||
try {
|
||||
const history = await db.all(
|
||||
`SELECT * FROM transfers
|
||||
WHERE sender = ? OR receiver = ?
|
||||
ORDER BY block_number DESC LIMIT 50`,
|
||||
[address, address]
|
||||
);
|
||||
res.json(history);
|
||||
} catch (err) {
|
||||
res.status(500).json({ error: err.message });
|
||||
}
|
||||
});
|
||||
|
||||
app.get('/api/stats', async (req, res) => {
|
||||
const stats = await db.get('SELECT COUNT(*) as total FROM transfers');
|
||||
res.json(stats);
|
||||
});
|
||||
|
||||
app.listen(port, () => {
|
||||
console.log(`Indexer API running at http://localhost:${port}`);
|
||||
});
|
||||
}
|
||||
|
||||
// Launch
|
||||
const db = await initDb();
|
||||
startIndexer(db);
|
||||
startServer(db);
|
||||
|
||||
Reference in New Issue
Block a user