Skip to content

Commit

Permalink
fix(style): lint changes
Browse files Browse the repository at this point in the history
  • Loading branch information
gabaldon committed Feb 23, 2024
1 parent c233c6e commit 7ee690a
Show file tree
Hide file tree
Showing 13 changed files with 363 additions and 558 deletions.
2 changes: 1 addition & 1 deletion packages/api/readme.md
Original file line number Diff line number Diff line change
@@ -1 +1 @@
# Data Feeds Explorer Api
# Data Feeds Explorer Api
7 changes: 2 additions & 5 deletions packages/api/src/dataFeedsRouter.json
Original file line number Diff line number Diff line change
Expand Up @@ -1438,9 +1438,7 @@
"color": "#66ff00",
"name": "Optimism Goerli (testnet)",
"pollingPeriod": 120000,
"feeds": {

}
"feeds": {}
},
"optimism.mainnet": {
"legacy": true,
Expand Down Expand Up @@ -1774,8 +1772,7 @@
"color": "#66ff00",
"name": "Syscoin Rollux Testnet",
"pollingPeriod": 90000,
"feeds": {
}
"feeds": {}
}
}
},
Expand Down
23 changes: 16 additions & 7 deletions packages/api/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,12 @@ import { MongoManager } from './database'
import { FeedRepository } from './repository/Feed'
import { ResultRequestRepository } from './repository/ResultRequest'
import { createServer } from './server'
import { RouterDataFeedsConfig, Repositories, FeedInfo, NetworksConfig } from './types'
import {
RouterDataFeedsConfig,
Repositories,
FeedInfo,
NetworksConfig
} from './types'
import { Web3Middleware } from './web3Middleware/index'
import { normalizeNetworkConfig } from './utils/index'
import {
Expand All @@ -23,7 +28,9 @@ async function main () {
const configurationFile: RouterDataFeedsConfig = await fetchDataFeedsRouterConfig()
const configuration = new Configuration(configurationFile)

const legacyFeeds: Array<FeedInfo> = normalizeAndValidateDataFeedConfig(configurationFile)
const legacyFeeds: Array<FeedInfo> = normalizeAndValidateDataFeedConfig(
configurationFile
)
const networksConfigPartial: Array<Omit<
NetworksConfig,
'logo'
Expand All @@ -44,15 +51,17 @@ async function main () {
logo: networksLogos[logosToFetch[index]]
}))

const routers = configuration.listNetworksUsingPriceFeedsContract()
const routers = configuration
.listNetworksUsingPriceFeedsContract()
.filter(config => {
if (!config.provider) {
console.warn("No provider found for ", config.key)
console.warn('No provider found for ', config.key)
}
return config.provider
})
.map(networkInfo => new NetworkRouter(configuration, repositories, networkInfo))

.map(
networkInfo => new NetworkRouter(configuration, repositories, networkInfo)
)

const newFeeds: Array<FeedInfo> = []

Expand All @@ -71,7 +80,7 @@ async function main () {
const web3Middleware = new Web3Middleware(
configuration,
{ repositories, Web3: Web3 },
legacyFeeds,
legacyFeeds
)

web3Middleware.listen()
Expand Down
23 changes: 9 additions & 14 deletions packages/api/src/repository/ResultRequest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,13 +66,10 @@ export class ResultRequestRepository {
async getLastResult (
feedFullName: string
): Promise<ResultRequestDbObjectNormalized | null> {
const lastResultRequest = await this.collection.findOne(
{
feedFullName
},
{
sort: {
timestamp: -1
const lastResultRequest = await this.collection
.findOne(
{
feedFullName
},
{
sort: {
Expand All @@ -83,11 +80,11 @@ export class ResultRequestRepository {
numericOrdering: true
}
}
}
).catch(e => {
console.log(`Error in getLastResult: ${feedFullName}`, e)
return null
})
)
.catch(e => {
console.log(`Error in getLastResult: ${feedFullName}`, e)
return null
})
return this.normalizeId(lastResultRequest)
}

Expand All @@ -113,7 +110,6 @@ export class ResultRequestRepository {
async insertIfLatest (
resultRequest: WithoutId<ResultRequestDbObject>
): Promise<ResultRequestDbObjectNormalized | null> {

let storedResult = this.latestResults[resultRequest.feedFullName]
if (!storedResult) {
storedResult = await this.getLastResult(resultRequest.feedFullName)
Expand All @@ -132,7 +128,6 @@ export class ResultRequestRepository {
}
}


private normalizeId (
resultRequest: ResultRequestDbObject
): ResultRequestDbObjectNormalized | null {
Expand Down
4 changes: 2 additions & 2 deletions packages/api/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ export type ConfigByFullName = {
}

export enum Network {
ArbitrumOne = 'arbitrum-one' ,
ArbitrumOne = 'arbitrum-one',
ArbitrumGoerli = 'arbitrum-goerli',
AvalancheMainnet = 'avalanche-mainnet',
AvalancheFuji = 'avalanche-fuji',
Expand Down Expand Up @@ -195,7 +195,7 @@ export type FeedParsedParams = {
}

export type FeedConfig = {
legacy?: boolean,
legacy?: boolean
address: string
blockExplorer: string
hide?: boolean
Expand Down
80 changes: 50 additions & 30 deletions packages/api/src/web3Middleware/Configuration.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,17 @@
import { FeedParamsConfig, Network, NetworksConfig, RouterDataFeedsConfig } from "../types";
import { getNetworksListByChain, sortAlphabeticallyByLabel } from "../utils";
import { NetworkInfo } from "./NetworkRouter";
import { getProvider } from "./provider";
import {
FeedParamsConfig,
Network,
NetworksConfig,
RouterDataFeedsConfig
} from '../types'
import { getNetworksListByChain, sortAlphabeticallyByLabel } from '../utils'
import { NetworkInfo } from './NetworkRouter'
import { getProvider } from './provider'

export class Configuration {
private configurationFile: RouterDataFeedsConfig

constructor(json: RouterDataFeedsConfig) {
constructor (json: RouterDataFeedsConfig) {
this.configurationFile = json
}

Expand Down Expand Up @@ -35,65 +40,80 @@ export class Configuration {
}

// return networks using the new price feeds router contract
public listNetworksUsingPriceFeedsContract(): Array<NetworkInfo> {
public listNetworksUsingPriceFeedsContract (): Array<NetworkInfo> {
return Object.values(this.configurationFile.chains)
.flatMap(chain => Object.entries(chain.networks))
.filter(([_, network])=> network.legacy === false)
.filter(([_, network]) => network.legacy === false)
.map(([networkKey, network]) => {
return {
provider: getProvider(networkKey.replaceAll('.', '-') as Network),
address: network.address,
pollingPeriod: network.pollingPeriod,
key: this.fromNetworkKeyToNetwork(networkKey),
networkName: network.name,
networkName: network.name
}
})
}

public getLegacyConfigurationFile(): RouterDataFeedsConfig {
const chains = Object.entries(this.configurationFile.chains).reduce((acc, [chainKey, chain]) => {

if (chain.hide) {
return acc
}

const networks = Object.entries(chain.networks).reduce((accNetworks, [networkKey, network]) => {
// add the network entry if it's legacy
return network.legacy ? { ...accNetworks, [networkKey]: network } : accNetworks;
}, {})
public getLegacyConfigurationFile (): RouterDataFeedsConfig {
const chains = Object.entries(this.configurationFile.chains).reduce(
(acc, [chainKey, chain]) => {
if (chain.hide) {
return acc
}

return Object.keys(networks).length > 0 ? { ...acc, [chainKey]: { ...chain, networks } } : acc
}, {})
const networks = Object.entries(chain.networks).reduce(
(accNetworks, [networkKey, network]) => {
// add the network entry if it's legacy
return network.legacy
? { ...accNetworks, [networkKey]: network }
: accNetworks
},
{}
)

return Object.keys(networks).length > 0
? { ...acc, [chainKey]: { ...chain, networks } }
: acc
},
{}
)

return {
...this.configurationFile,
chains,
chains
}
}

public getFeedConfiguration(priceFeedName: string, network: Network): FeedParamsConfig {
public getFeedConfiguration (
priceFeedName: string,
network: Network
): FeedParamsConfig {
const defaultFeed = this.configurationFile.feeds[priceFeedName]
const specificFeedConfiguration = this.getNetworkConfiguration(network).feeds[priceFeedName]
const specificFeedConfiguration = this.getNetworkConfiguration(network)
.feeds[priceFeedName]

return { ...defaultFeed, ...specificFeedConfiguration }
}

public isFeedActive(caption: string): boolean {
public isFeedActive (caption: string): boolean {
return Object.keys(this.configurationFile.feeds).includes(caption)
}

public getNetworkConfiguration(network: Network) {
return this.configurationFile.chains[getChain(network)].networks[networkToKey(network)]
public getNetworkConfiguration (network: Network) {
return this.configurationFile.chains[getChain(network)].networks[
networkToKey(network)
]
}

private fromNetworkKeyToNetwork(networkKey: string): Network {
private fromNetworkKeyToNetwork (networkKey: string): Network {
return networkKey.replace('.', '-') as Network
}
}

export function getChain(network: Network) {
export function getChain (network: Network) {
return network.split('-')[0]
}
export function networkToKey(network: Network) {
export function networkToKey (network: Network) {
return network.replaceAll('-', '.')
}
Loading

0 comments on commit 7ee690a

Please sign in to comment.