Skip to content

Commit

Permalink
Merge pull request #623 from oceanprotocol/feature/add_getP2pNetworkS…
Browse files Browse the repository at this point in the history
…tats_route

add getP2pNetworkStats route
  • Loading branch information
alexcos20 authored Aug 15, 2024
2 parents 60ecedf + d6557ca commit 548aeac
Show file tree
Hide file tree
Showing 4 changed files with 26 additions and 2 deletions.
1 change: 1 addition & 0 deletions docs/env.md
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ Environmental variables are also tracked in `ENVIRONMENT_VARIABLES` within `src/
- `P2P_AUTODIALCONCURRENCY`: When dialling peers from the peer book to keep the number of open connections, add dials for this many peers to the dial queue at once. Default: 5
- `P2P_MAXPEERADDRSTODIAL`: Maximum number of addresses allowed for a given peer before giving up. Default: 5
- `P2P_AUTODIALINTERVAL`: Auto dial interval (miliseconds). Amount of time between close and open of new peer connection. Default: 5000
- `P2P_ENABLE_NETWORK_STATS`: Enables 'getP2pNetworkStats' http endpoint. Since this contains private informations (like your ip addresses), this is disabled by default

## Additional Nodes (Test Environments)

Expand Down
10 changes: 10 additions & 0 deletions src/components/P2P/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -436,6 +436,16 @@ export class OceanP2P extends EventEmitter {
// }
}

async getNetworkingStats() {
const ret: any = {}
ret.binds = await this._libp2p.components.addressManager.getListenAddrs()
ret.listen = await this._libp2p.components.transportManager.getAddrs()
ret.observing = await this._libp2p.components.addressManager.getObservedAddrs()
ret.announce = await this._libp2p.components.addressManager.getAnnounceAddrs()
ret.connections = await this._libp2p.getConnections()
return ret
}

async getRunningOceanPeers() {
return await this.getOceanPeers(true, false)
}
Expand Down
15 changes: 14 additions & 1 deletion src/components/httpRoutes/getOceanPeers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,22 @@ import express, { Request, Response } from 'express'
import { getDefaultLevel } from '../../utils/logging/Logger.js'
import { P2P_LOGGER } from '../../utils/logging/common.js'
import { hasP2PInterface, sendMissingP2PResponse } from './index.js'

import { getBoolEnvValue } from '../../utils/config.js'
export const getOceanPeersRoute = express.Router()

getOceanPeersRoute.get(
'/getP2pNetworkStats',
async (req: Request, res: Response): Promise<void> => {
// only return values if env P2P_ENABLE_NETWORK_STATS is explicitly allowed
if (hasP2PInterface && getBoolEnvValue('P2P_ENABLE_NETWORK_STATS', false)) {
const stats = await req.oceanNode.getP2PNode().getNetworkingStats()
P2P_LOGGER.log(getDefaultLevel(), `getP2pNetworkStats: ${stats}`, true)
res.json(stats)
} else {
res.status(400).send('Not enabled or unavailable')
}
}
)
getOceanPeersRoute.get(
'/getOceanPeers',
async (req: Request, res: Response): Promise<void> => {
Expand Down
2 changes: 1 addition & 1 deletion src/utils/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ function getIntEnvValue(env: any, defaultValue: number) {
return isNaN(num) ? defaultValue : num
}

function getBoolEnvValue(envName: string, defaultValue: boolean): boolean {
export function getBoolEnvValue(envName: string, defaultValue: boolean): boolean {
if (!(envName in process.env)) {
return defaultValue
}
Expand Down

0 comments on commit 548aeac

Please sign in to comment.