UNPKG

@decaf-ts/fabric-weaver

Version:
165 lines 23.8 kB
import express from "express"; import { DEFAULT_PORT, MiddlewareRoutes } from "../constants/peer-middleware"; import { Logging, LogLevel } from "@decaf-ts/logging"; // import { info, mkdir, rm } from "@aeon/fabric-integration"; // import * as express from "express"; // import * as fs from "fs"; // import * as path from "path"; // import { Express } from "express"; // import { execSync } from "child_process"; // import { peerBootConfig } from "../utils/types"; // import { copyAndOverrideYaml } from "../utils/genesis"; // import * as bodyParser from "body-parser"; // import { MiddlewareRoutes } from "../../shared"; export class PeerMiddleware { constructor(port) { //Change later mock security this.accessKeys = []; // Mock security, replace with actual access keys this.app = express(); this.port = port || DEFAULT_PORT; this.log = Logging.for(PeerMiddleware); this.log.setConfig({ level: LogLevel.debug, }); // this.app.use(bodyParser.json({ limit: '50mb' })); // Adjust the size as needed // this.app.use(bodyParser.urlencoded({ limit: '50mb', extended: true })); // Middleware to parse JSON this.app.use(express.json()); // Route Setup this.routes(); } routes() { const methodNames = Object.getOwnPropertyNames(Object.getPrototypeOf(this)).filter((name) => name !== "constructor" && typeof this[name] === "function" && name !== "routes" && name !== "listen"); for (const methodName of methodNames) { try { this[methodName](); } catch (error) { this.log.error(`Error calling method ${methodName}: ${error}`); } } } addAccessKey() { this.log.info("Adding access key endpoint registered"); const addKey = (req, res) => { this.log.info("Received request to add access key"); const body = req.body; this.log.debug(`Received access key: ${body.accessKey}`); if (!body.accessKey) { return res.status(400).send({ error: "Missing access key" }); } if (this.accessKeys.includes(body.accessKey)) { return res.status(409).send({ error: "Access key already exists" }); } this.accessKeys.push(body.accessKey); this.log.debug(`Access keys: ${this.accessKeys.join(", ")}`); res .status(201) .contentType("application/json") .send({ message: "Access key added successfully" }); }; this.app.post(`${MiddlewareRoutes.ACCESS_KEY}`, addKey); } hello() { this.app.get("/", (req, res) => { res.send("Hello, world!"); }); } healthcheck() { this.log.info("Healthcheck endpoint registered"); const healthcheck = (req, res) => { res.status(200).contentType("application/json").send({ message: "OK" }); }; this.app.get(`${MiddlewareRoutes.HEALTZ}`, healthcheck); } // private handleOrganizationEnroll(req: express.Request, res: express.Response): void{ // const orgDetails = req.body // try { // mkdir('./temp/'); // const replacements = { // ORG_NAME: orgDetails.name, // ORG_MSPID: orgDetails.id, // ORG_MSPDIR: "/aeon/temp/ca/peers/peer-0/client/msp" // } // copyAndOverrideYaml('./configs/orgtx.yaml', './temp/configtx.yaml', replacements) // fs.writeFileSync('./temp/mspdir.tar.gz', Buffer.from(orgDetails.mspdir)); // execSync('tar -xvf ./temp/mspdir.tar.gz -C ./temp'); // execSync(`peer channel fetch config ./temp/config_block.pb \ // --channelID '${this.config.channel.name}' \ // --orderer '${this.config.channel.ordererEndpoint}' \ // --tls \ // --cafile '${this.config.tls.tls}'`); // execSync(`configtxlator proto_decode --input ./temp/config_block.pb \ // --type common.Block \ // --output ./temp/config_block.json`); // execSync(`jq .data.data[0].payload.data.config ./temp/config_block.json > ./temp/config.json`); // execSync(`cd temp && configtxgen -printOrg ${orgDetails.name} > ./org.json`) ; // execSync( `jq -s '.[0] * {"channel_group":{"groups":{"Application":{"groups": {"${orgDetails.name}":.[1]}}}}}' \ // ./temp/config.json \ // ./temp/org.json > ./temp/modified_config.json`); // execSync(`configtxlator proto_encode \ // --input ./temp/config.json \ // --type common.Config \ // --output ./temp/config.pb`); // execSync( `configtxlator proto_encode \ // --input ./temp/modified_config.json \ // --type common.Config \ // --output ./temp/modified_config.pb`); // execSync(`configtxlator compute_update \ // --channel_id aeon-main \ // --original ./temp/config.pb \ // --updated ./temp/modified_config.pb \ // --output ./temp/org_update.pb`); // execSync(`configtxlator proto_decode \ // --input ./temp/org_update.pb \ // --type common.ConfigUpdate \ // --output ./temp/org_update.json`); // execSync(`echo '{"payload":{"header":{"channel_header":{"channel_id":"'${this.config.channel.name}'", "type":2}},"data":{"config_update":'$(cat ./temp/org_update.json)'}}}' \ // | jq . > ./temp/org_update_in_envelope.json`); // execSync( `configtxlator proto_encode \ // --input ./temp/org_update_in_envelope.json \ // --type common.Envelope \ // --output ./temp/org_update_in_envelope.pb`); // execSync(`cd temp && peer channel signconfigtx \ // -f ./org_update_in_envelope.pb`); // execSync(`peer channel update \ // -f ./temp/org_update_in_envelope.pb \ // -c ${this.config.channel.name} \ // -o ${this.config.channel.ordererEndpoint} \ // --tls \ // --cafile ${this.config.tls.tls}`); // res.status(200).send({success:true}) // } catch(e:unknown) { // res.status(500).send(e) // } finally { // rm("./temp"); // } // } // private handleOrganizationPeerAnchor(req: express.Request, res: express.Response): void{ // const body = req.body // try { // mkdir('./temp/'); // fs.writeFileSync(path.join(process.cwd(), "temp/anchor_update_in_envelope.pb"), Buffer.from(body.block)) // execSync(`peer channel update \ // -f /aeon/temp/anchor_update_in_envelope.pb \ // --channelID ${this.config.channel.name} \ // --orderer ${this.config.channel.ordererEndpoint} \ // --tls \ // --cafile ${this.config.channel.ordererCaFile}`); // res.status(200).send({success:true}) // } catch (e: unknown) { // res.status(500).send(e) // } finally { // rm("./temp"); // } // } listen() { this.app.listen(this.port, () => { this.log.info(`Peer Middleware running on port: ${this.port}`); }); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PeerMiddleware.js","sourceRoot":"","sources":["../../../../src/core/middlewares/PeerMiddleware.ts"],"names":[],"mappings":"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","sourcesContent":["import { Express, Response, Request } from \"express\";\nimport express from \"express\";\nimport { DEFAULT_PORT, MiddlewareRoutes } from \"../constants/peer-middleware\";\nimport { Logger, Logging, LogLevel } from \"@decaf-ts/logging\";\n// import { info, mkdir, rm } from \"@aeon/fabric-integration\";\n// import * as express from \"express\";\n// import * as fs from \"fs\";\n// import * as path from \"path\";\n// import { Express } from \"express\";\n// import { execSync } from \"child_process\";\n// import { peerBootConfig } from \"../utils/types\";\n// import { copyAndOverrideYaml } from \"../utils/genesis\";\n// import * as bodyParser from \"body-parser\";\n// import { MiddlewareRoutes } from \"../../shared\";\n\nexport class PeerMiddleware {\n  private readonly app: Express;\n  private readonly port: number;\n  private readonly log: Logger;\n\n  //Change later mock security\n  private accessKeys: string[] = []; // Mock security, replace with actual access keys\n\n  constructor(port: number) {\n    this.app = express();\n    this.port = port || DEFAULT_PORT;\n    this.log = Logging.for(PeerMiddleware);\n\n    this.log.setConfig({\n      level: LogLevel.debug,\n    });\n\n    //    this.app.use(bodyParser.json({ limit: '50mb' })); // Adjust the size as needed\n    // this.app.use(bodyParser.urlencoded({ limit: '50mb', extended: true }));\n\n    // Middleware to parse JSON\n    this.app.use(express.json());\n\n    // Route Setup\n    this.routes();\n  }\n\n  private routes(): void {\n    const methodNames = Object.getOwnPropertyNames(\n      Object.getPrototypeOf(this)\n    ).filter(\n      (name) =>\n        name !== \"constructor\" &&\n        typeof this[name as keyof PeerMiddleware] === \"function\" &&\n        name !== \"routes\" &&\n        name !== \"listen\"\n    );\n\n    for (const methodName of methodNames) {\n      try {\n        this[methodName as keyof PeerMiddleware]();\n      } catch (error) {\n        this.log.error(`Error calling method ${methodName}: ${error}`);\n      }\n    }\n  }\n\n  private addAccessKey(): void {\n    this.log.info(\"Adding access key endpoint registered\");\n\n    const addKey = (req: Request, res: Response) => {\n      this.log.info(\"Received request to add access key\");\n\n      const body = req.body;\n\n      this.log.debug(`Received access key: ${body.accessKey}`);\n\n      if (!body.accessKey) {\n        return res.status(400).send({ error: \"Missing access key\" });\n      }\n      if (this.accessKeys.includes(body.accessKey)) {\n        return res.status(409).send({ error: \"Access key already exists\" });\n      }\n      this.accessKeys.push(body.accessKey);\n\n      this.log.debug(`Access keys: ${this.accessKeys.join(\", \")}`);\n      res\n        .status(201)\n        .contentType(\"application/json\")\n        .send({ message: \"Access key added successfully\" });\n    };\n\n    this.app.post(`${MiddlewareRoutes.ACCESS_KEY}`, addKey);\n  }\n\n  private hello(): void {\n    this.app.get(\"/\", (req, res) => {\n      res.send(\"Hello, world!\");\n    });\n  }\n\n  private healthcheck(): void {\n    this.log.info(\"Healthcheck endpoint registered\");\n    const healthcheck = (req: Request, res: Response) => {\n      res.status(200).contentType(\"application/json\").send({ message: \"OK\" });\n    };\n\n    this.app.get(`${MiddlewareRoutes.HEALTZ}`, healthcheck);\n  }\n\n  // private handleOrganizationEnroll(req: express.Request, res: express.Response): void{\n  //     const orgDetails = req.body\n\n  //     try {\n  //         mkdir('./temp/');\n\n  //         const replacements = {\n  //             ORG_NAME: orgDetails.name,\n  //             ORG_MSPID: orgDetails.id,\n  //             ORG_MSPDIR: \"/aeon/temp/ca/peers/peer-0/client/msp\"\n  //         }\n\n  //         copyAndOverrideYaml('./configs/orgtx.yaml', './temp/configtx.yaml', replacements)\n\n  //         fs.writeFileSync('./temp/mspdir.tar.gz', Buffer.from(orgDetails.mspdir));\n\n  //         execSync('tar -xvf ./temp/mspdir.tar.gz -C ./temp');\n\n  //         execSync(`peer channel fetch config ./temp/config_block.pb \\\n  //             --channelID '${this.config.channel.name}' \\\n  //             --orderer '${this.config.channel.ordererEndpoint}' \\\n  //             --tls \\\n  //             --cafile '${this.config.tls.tls}'`);\n\n  //         execSync(`configtxlator proto_decode --input ./temp/config_block.pb \\\n  //             --type common.Block \\\n  //             --output ./temp/config_block.json`);\n\n  //         execSync(`jq .data.data[0].payload.data.config ./temp/config_block.json > ./temp/config.json`);\n\n  //         execSync(`cd temp && configtxgen -printOrg ${orgDetails.name} > ./org.json`) ;\n\n  //         execSync( `jq -s '.[0] * {\"channel_group\":{\"groups\":{\"Application\":{\"groups\": {\"${orgDetails.name}\":.[1]}}}}}' \\\n  //             ./temp/config.json \\\n  //             ./temp/org.json > ./temp/modified_config.json`);\n\n  //         execSync(`configtxlator proto_encode \\\n  //             --input ./temp/config.json \\\n  //             --type common.Config \\\n  //             --output ./temp/config.pb`);\n\n  //         execSync( `configtxlator proto_encode \\\n  //             --input ./temp/modified_config.json \\\n  //             --type common.Config \\\n  //             --output ./temp/modified_config.pb`);\n\n  //         execSync(`configtxlator compute_update \\\n  //             --channel_id aeon-main \\\n  //             --original ./temp/config.pb \\\n  //             --updated ./temp/modified_config.pb \\\n  //             --output ./temp/org_update.pb`);\n\n  //         execSync(`configtxlator proto_decode \\\n  //             --input ./temp/org_update.pb \\\n  //             --type common.ConfigUpdate \\\n  //             --output ./temp/org_update.json`);\n\n  //         execSync(`echo '{\"payload\":{\"header\":{\"channel_header\":{\"channel_id\":\"'${this.config.channel.name}'\", \"type\":2}},\"data\":{\"config_update\":'$(cat ./temp/org_update.json)'}}}' \\\n  //             | jq . > ./temp/org_update_in_envelope.json`);\n\n  //         execSync( `configtxlator proto_encode \\\n  //             --input ./temp/org_update_in_envelope.json \\\n  //             --type common.Envelope \\\n  //             --output ./temp/org_update_in_envelope.pb`);\n\n  //         execSync(`cd temp && peer channel signconfigtx \\\n  //             -f ./org_update_in_envelope.pb`);\n\n  //         execSync(`peer channel update \\\n  //             -f ./temp/org_update_in_envelope.pb \\\n  //             -c ${this.config.channel.name} \\\n  //             -o ${this.config.channel.ordererEndpoint} \\\n  //             --tls \\\n  //             --cafile ${this.config.tls.tls}`);\n\n  //         res.status(200).send({success:true})\n\n  //     } catch(e:unknown) {\n  //         res.status(500).send(e)\n  //     } finally {\n  //         rm(\"./temp\");\n  //     }\n  // }\n\n  // private handleOrganizationPeerAnchor(req: express.Request, res: express.Response): void{\n  //     const body = req.body\n\n  //     try {\n  //         mkdir('./temp/');\n\n  //         fs.writeFileSync(path.join(process.cwd(), \"temp/anchor_update_in_envelope.pb\"), Buffer.from(body.block))\n\n  //         execSync(`peer channel update \\\n  //             -f /aeon/temp/anchor_update_in_envelope.pb \\\n  //             --channelID ${this.config.channel.name} \\\n  //             --orderer ${this.config.channel.ordererEndpoint} \\\n  //             --tls \\\n  //             --cafile ${this.config.channel.ordererCaFile}`);\n\n  //         res.status(200).send({success:true})\n  //     } catch (e: unknown) {\n  //         res.status(500).send(e)\n  //     } finally {\n  //         rm(\"./temp\");\n  //     }\n  // }\n\n  listen(): void {\n    this.app.listen(this.port, () => {\n      this.log.info(`Peer Middleware running on port: ${this.port}`);\n    });\n  }\n}\n"]}