{"version":3,"sources":["../../src/commands/buildCommand.ts","../../src/services/GithubService.ts","../../src/services/Service.ts","../../src/services/GitlabService.ts","../../src/utils/getDirs.ts"],"sourcesContent":["import { Err } from '@lskjs/err';\nimport { log } from '@lskjs/log/log';\nimport { getComment, jsonToFile } from '@lskjs/stringify';\nimport { map, mapSeries } from 'fishbird';\nimport { existsSync } from 'fs';\nimport { mkdir, unlink } from 'fs/promises';\n\nimport { GithubService } from '../services/GithubService';\nimport { GitlabService } from '../services/GitlabService';\nimport { Service } from '../services/Service';\nimport { getDirs } from '../utils/getDirs';\n// import { getFiles } from '../utils/getFiles';\n\nexport async function buildCommand(serviceDirname, options: any = {}) {\n  const buildDirDir = options.buildDir || `${serviceDirname}/build`;\n\n  let config;\n  const configPath = `${serviceDirname}/config.js`;\n  try {\n    // eslint-disable-next-line import/no-dynamic-require\n    config = require(configPath);\n  } catch (err) {\n    if (err.code === 'MODULE_NOT_FOUND') {\n      log.error(`${configPath} not found`);\n      return;\n    }\n    throw err;\n  }\n\n  await unlink(`${buildDirDir}`).catch(() => {});\n  await mkdir(buildDirDir, { recursive: true });\n\n  const serviceName = config.service?.serviceName;\n  if (!serviceName) throw new Err('!serviceName');\n\n  let service: Service;\n  if (serviceName === 'github') {\n    service = new GithubService({\n      ...config.service,\n      ...options,\n    });\n  } else if (serviceName === 'gitlab') {\n    service = new GitlabService({\n      ...config.service,\n      ...options,\n    });\n  } else {\n    throw new Err('incorrect serviceName', { serviceName });\n  }\n\n  const { files = [] } = config;\n  await mapSeries(files, async (fileOptions: any) => {\n    const { type, filename, handler } = fileOptions;\n    const res = await handler(fileOptions, config);\n    const comment = getComment({\n      filename,\n      values: [\n        ['Server', service.getServiceLink()],\n        ['Project', service.getProjectPath()],\n        ['Project ID', service.getProjectId()],\n        ['Project Url', service.getProjectUrl()],\n        ['CI/CD Setting', service.getProjectCICDSettingURL()],\n      ],\n      footer:\n        service.getProjectCredsUrl() &&\n        `\nAuto generated by ${service.getProjectCredsUrl()}\nIf you want to change something, please contact admin repo.\n      `.trim(),\n    });\n    await jsonToFile(`${buildDirDir}/${filename}`, res, {\n      type,\n      compare: !options.force,\n      comment,\n    });\n    log.info(`[build] ${service.getProjectPath()} (${filename})`);\n  });\n}\nexport async function buildDeepCommand(dirname, options = {}) {\n  const rawFiles = await getDirs(dirname);\n  const files = (\n    await map(rawFiles, async (rawFile) => {\n      const { filename } = rawFile;\n      if (!(await existsSync(`${filename}/config.js`))) return null;\n      return rawFile;\n    })\n  ).filter(Boolean);\n\n  return mapSeries(files, async ({ filename }) => {\n    await buildCommand(filename, options).catch((err) => {\n      log.error(`Build error ${filename}: `, err);\n    });\n  });\n}\n","import { Err } from '@lskjs/err';\nimport _sodium from 'libsodium-wrappers';\n\nimport { Service } from './Service';\n\nexport class GithubService extends Service {\n  checkConfig() {\n    if (!this.token) throw new Err('!token');\n  }f\n  getBaseUrl() {\n    const server = this.server || 'api.github.com';\n    return `https://${server}/repos/${this.getProjectPath()}`;\n  }\n  getHeaders() {\n    return {\n      Accept: 'application/vnd.github+json',\n      Authorization: `Bearer ${this.token}`,\n      'X-GitHub-Api-Version': '2022-11-28',\n    };\n  }\n  getServiceLink() {\n    return 'github.com';\n  }\n  getProjectUrl() {\n    return `https://${this.getServiceLink()}/${this.projectName}`;\n  }\n  getProjectCICDSettingURL() {\n    return `${this.getProjectUrl()}/settings/secrets/actions`;\n  }\n  async uploadSecret(key, content) {\n    const { data: publicKeyData } = await this.client({\n      method: 'get',\n      url: `/actions/secrets/public-key`,\n    }).catch((err) => {\n      // TODO: сделать такой интерцептор\n      throw new Err(err.message, { data: err?.response?.data });\n      // console.log(err.response.data);\n    });\n    // console.log({ publicKeyData });\n\n    if (!publicKeyData?.key) throw new Err('!publicKey');\n    if (!publicKeyData?.key_id) throw new Err('!publicKeyId');\n\n    await _sodium.ready;\n    const sodium = _sodium;\n    const binkey = sodium.from_base64(publicKeyData.key, sodium.base64_variants.ORIGINAL);\n    const binsec = sodium.from_string(content);\n    const encBytes = sodium.crypto_box_seal(binsec, binkey);\n    const output = sodium.to_base64(encBytes, sodium.base64_variants.ORIGINAL);\n\n    await this.client({\n      method: 'put',\n      url: `/actions/secrets/${key}`,\n      data: {\n        encrypted_value: output,\n        key_id: publicKeyData.key_id,\n      },\n    });\n  }\n  async uploadVariable(key, content) {\n    const { data: varData, status } = await this.client({\n      method: 'get',\n      url: `/actions/variables/${key}`,\n      // eslint-disable-next-line @typescript-eslint/no-empty-function\n    }).catch((err) => err?.response);\n    if (status === 404) {\n      await this.client({\n        method: 'post',\n        url: `/actions/variables`,\n        data: {\n          name: key,\n          value: content,\n        },\n      });\n    }\n    if (status === 200 && varData.name.toLowerCase() === key.toLowerCase()) {\n      await this.client({\n        method: 'patch',\n        url: `/actions/variables/${key}`,\n        data: {\n          name: key,\n          value: content,\n        },\n      });\n    }\n  }\n  uploadHook(): Promise<void> {\n    throw new Err('Github hooks not supported yet');\n  }\n}\n","import { Err } from '@lskjs/err';\nimport { log } from '@lskjs/log/log';\nimport axios from 'axios';\nimport { map } from 'fishbird';\n\ntype SecretFile = {\n  name: string;\n  filename: string;\n  credType?: string;\n  content?: string;\n  handler: (any) => Record<string, any>;\n};\ntype Secrets = {\n  secrets?: Record<string, string>;\n  variables?: Record<string, string>;\n  files?: Array<SecretFile>;\n  hooks?: Array<any>;\n};\n\nexport class Service {\n  projectId?: string;\n  projectName?: string;\n  projectPath?: string;\n  projectCredsUrl?: string;\n\n  token: string;\n  server: string;\n  force: boolean;\n\n  client: axios.AxiosInstance;\n\n  constructor(options) {\n    Object.assign(this, options);\n    this.checkConfig();\n    const clientOptions = {\n      baseURL: this.getBaseUrl(),\n      headers: this.getHeaders(),\n    };\n    this.client = axios.create(clientOptions);\n    // TODO: сделать такой интерцептор\n    // .catch((err) => {\n    //   throw new Err(err.message, { data: err?.response?.data });\n    //   // console.log(err.response.data);\n    // });\n  }\n\n  checkConfig() {\n    throw new Err('NOT_IMPLEMENTED');\n  }\n  getBaseUrl() {\n    return null;\n  }\n  getHeaders() {\n    return {};\n  }\n  getServiceLink() {\n    return null;\n  }\n  getProjectName() {\n    return this.projectName;\n  }\n  getProjectId() {\n    return this.projectId;\n  }\n  getProjectPath() {\n    return this.projectPath;\n  }\n  getProjectUrl() {\n    return null;\n  }\n  getProjectCredsUrl() {\n    return this.projectCredsUrl;\n  }\n  getProjectCICDSettingURL() {\n    return null;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async uploadSecret(key: string, content: string) {\n    throw new Err('NOT_IMPLEMENTED');\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async uploadVariable(key: string, content: string) {\n    throw new Err('NOT_IMPLEMENTED');\n  }\n\n  async removeOldHooks() {}\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async uploadHook(dataHook: any) {}\n\n  async uploadHooks(env: Secrets): Promise<void> {\n    if (!env) throw new Err('!env');\n    const { hooks = [] } = env;\n    try {\n      await this.removeOldHooks();\n    } catch (e) {\n      log.error(`[ERR] Old hooks removing failed:`, e.message);\n    }\n\n    await map(hooks, async (dataHook, index) => {\n      try {\n        await this.uploadHook(dataHook);\n        log.info(`[OK] Hook ${index} uploaded`);\n      } catch (e) {\n        log.error(`[ERR] Hook ${index} not uploaded:`, e.message);\n      }\n    });\n  }\n\n  async uploadAll(env: Secrets) {\n    if (!env) throw new Err('!env');\n    const { secrets = {}, variables = {}, files = [] } = env;\n    await this.uploadHooks(env);\n    await map(Object.entries(secrets), async ([key, value]) => {\n      try {\n        await this.uploadSecret(key, value);\n        log.info(`[OK] Secret ${key} uploaded`);\n      } catch (e) {\n        log.error(`[ERR] Secret ${key} not uploaded, because`, e.message);\n        log.error(e);\n      }\n    });\n    await map(Object.entries(variables), async ([key, value]) => {\n      try {\n        await this.uploadVariable(key, value);\n        log.info(`[OK] Variable ${key} uploaded`);\n      } catch (e) {\n        log.error(`[ERR] Variable ${key} not uploaded, because`, e.message);\n        // log.error(e);\n      }\n    });\n    await map(files, async ({ name, credType, content }: any) => {\n      const key = name;\n      const value = content;\n      try {\n        if (credType === 'variable') {\n          await this.uploadVariable(key, value);\n        } else if (credType === 'secret') {\n          await this.uploadSecret(key, value);\n        } else if (credType === 'skip') {\n          log.debug(`[SKIP] File ${key} uploaded as ${credType}`);\n          return;\n        } else {\n          throw new Err('unknown credType', { credType });\n        }\n        log.info(`[OK] File ${key} uploaded as ${credType}`);\n      } catch (e) {\n        log.error(`[ERR] File ${key} not uploaded as ${credType}, because`, e.message);\n        // log.error(e);\n      }\n    });\n  }\n}\n","import { Err } from '@lskjs/err';\nimport { log } from '@lskjs/log/log';\nimport { map } from 'fishbird';\n\nimport { Service } from './Service';\n\nexport class GitlabService extends Service {\n  checkConfig() {\n    if (!this.server) throw new Err('!server');\n    if (!this.projectId) throw new Err('!projectId');\n    if (!this.token) throw new Err('!token');\n  }\n  getBaseUrl() {\n    return `https://${this.server}/api/v4/projects/${this.getProjectId()}`;\n  }\n  getHeaders() {\n    return {\n      'PRIVATE-TOKEN': this.token,\n    };\n  }\n  getServiceLink() {\n    return this.server;\n  }\n  getProjectUrl() {\n    return `https://${this.getServiceLink()}/${this.getProjectPath()}`;\n  }\n  getProjectCICDSettingURL() {\n    return `${this.getProjectUrl()}/-/settings/ci_cd`;\n  }\n  async uploadSecret(key, content) {\n    const { data: varData } = await this.client({\n      method: 'get',\n      url: `/variables/${key}`,\n    }).catch((err) => {\n      if (!this.force) throw err;\n      return { data: { value: '@lskjs/creds' } };\n    });\n\n    if (varData.value && varData.value.indexOf('@lskjs/creds') === -1 && !this.force) {\n      log.warn(`[IGNORE] Project ${this.projectId} ${key}`);\n      return;\n    }\n\n    await this.client({\n      method: 'delete',\n      url: `/variables/${key}`,\n      // eslint-disable-next-line @typescript-eslint/no-empty-function\n    }).catch(() => {});\n\n    await this.client({\n      method: 'post',\n      url: '/variables',\n      data: {\n        key,\n        variable_type: 'file',\n        value: content,\n        protected: true,\n        // masked: true,\n      },\n    });\n  }\n  async uploadVariable() {\n    log.warn(\"GitLab uploading variable doesn't supported\");\n    throw new Err('NOT_IMPLEMENTED');\n  }\n  async uploadEnv() {\n    log.warn(\"GitLab uploading env doesn't supported\");\n    throw new Err('NOT_IMPLEMENTED');\n  }\n\n  async removeOldHooks() {\n    const { data: hooksList } = await this.client({\n      method: 'get',\n      url: `/hooks`,\n    }).catch((err) => {\n      if (!this.force) throw err;\n      return { data: { value: '@lskjs/creds' } };\n    });\n    await map(hooksList, async ({ id: hookId }) => {\n      await this.client({\n        method: 'delete',\n        url: `/hooks/${hookId}`,\n      });\n    });\n  }\n  async uploadHook(hook) {\n    await this.client({\n      method: 'post',\n      url: '/hooks',\n      data: hook,\n    });\n  }\n}\n","import { map } from 'fishbird';\nimport { readdir } from 'fs/promises';\nimport { resolve } from 'path';\n\nexport async function getDirs(dir) {\n  const dirents = await readdir(dir, { withFileTypes: true });\n  const files = await map(dirents, async (dirent) => {\n    if (!dirent.isDirectory()) return [];\n\n    return [\n      { name: dirent.name, dir: resolve(dir), filename: resolve(dir, dirent.name) },\n      ...(await getDirs(resolve(dir, dirent.name))),\n    ];\n  });\n  return files.flat();\n\n  // // TODO: иногда возвращает странность\n  // const dirents = await readdir(dir, { withFileTypes: true });\n  // const files = await Promise.all(\n  //   dirents.map((dirent) => {\n  //     const filename = resolve(dir, dirent.name);\n  //     if (!dirent.isDirectory()) return [];\n  //     return getDirs(filename)\n\n  //     return dirent.isDirectory()\n  //       ? getDirs(filename)\n  //       : { name: dirent.name, dir: resolve(dir), filename };\n  //   }),\n  // );\n  // return Array.prototype.concat(...files);\n}\n"],"mappings":"oUAAA,OAASA,OAAAA,MAAW,aACpB,OAASC,OAAAA,MAAW,iBACpB,OAASC,cAAAA,EAAYC,cAAAA,MAAkB,mBACvC,OAASC,OAAAA,EAAKC,aAAAA,MAAiB,WAC/B,OAASC,cAAAA,MAAkB,KAC3B,OAASC,SAAAA,EAAOC,UAAAA,MAAc,cCL9B,OAASC,OAAAA,MAAW,aACpB,OAAOC,MAAa,qBCDpB,OAASC,OAAAA,MAAW,aACpB,OAASC,OAAAA,MAAW,iBACpB,OAAOC,MAAW,QAClB,OAASC,OAAAA,MAAW,WAgBb,IAAMC,EAAN,KAAMA,CAnBb,MAmBaA,CAAAA,EAAAA,gBACXC,UACAC,YACAC,YACAC,gBAEAC,MACAC,OACAC,MAEAC,OAEAC,YAAYC,EAAS,CACnBC,OAAOC,OAAO,KAAMF,CAAAA,EACpB,KAAKG,YAAW,EAChB,IAAMC,EAAgB,CACpBC,QAAS,KAAKC,WAAU,EACxBC,QAAS,KAAKC,WAAU,CAC1B,EACA,KAAKV,OAASW,EAAMC,OAAON,CAAAA,CAM7B,CAEAD,aAAc,CACZ,MAAM,IAAIQ,EAAI,iBAAA,CAChB,CACAL,YAAa,CACX,OAAO,IACT,CACAE,YAAa,CACX,MAAO,CAAC,CACV,CACAI,gBAAiB,CACf,OAAO,IACT,CACAC,gBAAiB,CACf,OAAO,KAAKrB,WACd,CACAsB,cAAe,CACb,OAAO,KAAKvB,SACd,CACAwB,gBAAiB,CACf,OAAO,KAAKtB,WACd,CACAuB,eAAgB,CACd,OAAO,IACT,CACAC,oBAAqB,CACnB,OAAO,KAAKvB,eACd,CACAwB,0BAA2B,CACzB,OAAO,IACT,CAGA,MAAMC,aAAaC,EAAaC,EAAiB,CAC/C,MAAM,IAAIV,EAAI,iBAAA,CAChB,CAGA,MAAMW,eAAeF,EAAaC,EAAiB,CACjD,MAAM,IAAIV,EAAI,iBAAA,CAChB,CAEA,MAAMY,gBAAiB,CAAC,CAGxB,MAAMC,WAAWC,EAAe,CAAC,CAEjC,MAAMC,YAAYC,EAA6B,CAC7C,GAAI,CAACA,EAAK,MAAM,IAAIhB,EAAI,MAAA,EACxB,GAAM,CAAEiB,MAAAA,EAAQ,CAAA,CAAE,EAAKD,EACvB,GAAI,CACF,MAAM,KAAKJ,eAAc,CAC3B,OAASM,EAAG,CACVC,EAAIC,MAAM,mCAAoCF,EAAEG,OAAO,CACzD,CAEA,MAAMC,EAAIL,EAAO,MAAOH,EAAUS,IAAAA,CAChC,GAAI,CACF,MAAM,KAAKV,WAAWC,CAAAA,EACtBK,EAAIK,KAAK,aAAaD,CAAAA,WAAgB,CACxC,OAASL,EAAG,CACVC,EAAIC,MAAM,cAAcG,CAAAA,iBAAuBL,EAAEG,OAAO,CAC1D,CACF,CAAA,CACF,CAEA,MAAMI,UAAUT,EAAc,CAC5B,GAAI,CAACA,EAAK,MAAM,IAAIhB,EAAI,MAAA,EACxB,GAAM,CAAE0B,QAAAA,EAAU,CAAC,EAAGC,UAAAA,EAAY,CAAC,EAAGC,MAAAA,EAAQ,CAAA,CAAE,EAAKZ,EACrD,MAAM,KAAKD,YAAYC,CAAAA,EACvB,MAAMM,EAAIhC,OAAOuC,QAAQH,CAAAA,EAAU,MAAO,CAACjB,EAAKqB,CAAAA,IAAM,CACpD,GAAI,CACF,MAAM,KAAKtB,aAAaC,EAAKqB,CAAAA,EAC7BX,EAAIK,KAAK,eAAef,CAAAA,WAAc,CACxC,OAASS,EAAG,CACVC,EAAIC,MAAM,gBAAgBX,CAAAA,yBAA6BS,EAAEG,OAAO,EAChEF,EAAIC,MAAMF,CAAAA,CACZ,CACF,CAAA,EACA,MAAMI,EAAIhC,OAAOuC,QAAQF,CAAAA,EAAY,MAAO,CAAClB,EAAKqB,CAAAA,IAAM,CACtD,GAAI,CACF,MAAM,KAAKnB,eAAeF,EAAKqB,CAAAA,EAC/BX,EAAIK,KAAK,iBAAiBf,CAAAA,WAAc,CAC1C,OAASS,EAAG,CACVC,EAAIC,MAAM,kBAAkBX,CAAAA,yBAA6BS,EAAEG,OAAO,CAEpE,CACF,CAAA,EACA,MAAMC,EAAIM,EAAO,MAAO,CAAEG,KAAAA,EAAMC,SAAAA,EAAUtB,QAAAA,CAAO,IAAO,CACtD,IAAMD,EAAMsB,EACND,EAAQpB,EACd,GAAI,CACF,GAAIsB,IAAa,WACf,MAAM,KAAKrB,eAAeF,EAAKqB,CAAAA,UACtBE,IAAa,SACtB,MAAM,KAAKxB,aAAaC,EAAKqB,CAAAA,UACpBE,IAAa,OAAQ,CAC9Bb,EAAIc,MAAM,eAAexB,CAAAA,gBAAmBuB,CAAAA,EAAU,EACtD,MACF,KACE,OAAM,IAAIhC,EAAI,mBAAoB,CAAEgC,SAAAA,CAAS,CAAA,EAE/Cb,EAAIK,KAAK,aAAaf,CAAAA,gBAAmBuB,CAAAA,EAAU,CACrD,OAASd,EAAG,CACVC,EAAIC,MAAM,cAAcX,CAAAA,oBAAuBuB,CAAAA,YAAqBd,EAAEG,OAAO,CAE/E,CACF,CAAA,CACF,CACF,EDrJO,IAAMa,EAAN,cAA4BC,CAAAA,CALnC,MAKmCA,CAAAA,EAAAA,sBACjCC,aAAc,CACZ,GAAI,CAAC,KAAKC,MAAO,MAAM,IAAIC,EAAI,QAAA,CACjC,CAACC,EACDC,YAAa,CAEX,MAAO,WADQ,KAAKC,QAAU,gBACZA,UAAgB,KAAKC,eAAc,CAAA,EACvD,CACAC,YAAa,CACX,MAAO,CACLC,OAAQ,8BACRC,cAAe,UAAU,KAAKR,KAAK,GACnC,uBAAwB,YAC1B,CACF,CACAS,gBAAiB,CACf,MAAO,YACT,CACAC,eAAgB,CACd,MAAO,WAAW,KAAKD,eAAc,CAAA,IAAM,KAAKE,WAAW,EAC7D,CACAC,0BAA2B,CACzB,MAAO,GAAG,KAAKF,cAAa,CAAA,2BAC9B,CACA,MAAMG,aAAaC,EAAKC,EAAS,CAC/B,GAAM,CAAEC,KAAMC,CAAa,EAAK,MAAM,KAAKC,OAAO,CAChDC,OAAQ,MACRC,IAAK,6BACP,CAAA,EAAGC,MAAOC,GAAAA,CAER,MAAM,IAAIrB,EAAIqB,EAAIC,QAAS,CAAEP,KAAMM,GAAKE,UAAUR,IAAK,CAAA,CAEzD,CAAA,EAGA,GAAI,CAACC,GAAeH,IAAK,MAAM,IAAIb,EAAI,YAAA,EACvC,GAAI,CAACgB,GAAeQ,OAAQ,MAAM,IAAIxB,EAAI,cAAA,EAE1C,MAAMyB,EAAQC,MACd,IAAMC,EAASF,EACTG,EAASD,EAAOE,YAAYb,EAAcH,IAAKc,EAAOG,gBAAgBC,QAAQ,EAC9EC,EAASL,EAAOM,YAAYnB,CAAAA,EAC5BoB,EAAWP,EAAOQ,gBAAgBH,EAAQJ,CAAAA,EAC1CQ,EAAST,EAAOU,UAAUH,EAAUP,EAAOG,gBAAgBC,QAAQ,EAEzE,MAAM,KAAKd,OAAO,CAChBC,OAAQ,MACRC,IAAK,oBAAoBN,CAAAA,GACzBE,KAAM,CACJuB,gBAAiBF,EACjBZ,OAAQR,EAAcQ,MACxB,CACF,CAAA,CACF,CACA,MAAMe,eAAe1B,EAAKC,EAAS,CACjC,GAAM,CAAEC,KAAMyB,EAASC,OAAAA,CAAM,EAAK,MAAM,KAAKxB,OAAO,CAClDC,OAAQ,MACRC,IAAK,sBAAsBN,CAAAA,EAE7B,CAAA,EAAGO,MAAOC,GAAQA,GAAKE,QAAAA,EACnBkB,IAAW,KACb,MAAM,KAAKxB,OAAO,CAChBC,OAAQ,OACRC,IAAK,qBACLJ,KAAM,CACJ2B,KAAM7B,EACN8B,MAAO7B,CACT,CACF,CAAA,EAEE2B,IAAW,KAAOD,EAAQE,KAAKE,YAAW,IAAO/B,EAAI+B,YAAW,GAClE,MAAM,KAAK3B,OAAO,CAChBC,OAAQ,QACRC,IAAK,sBAAsBN,CAAAA,GAC3BE,KAAM,CACJ2B,KAAM7B,EACN8B,MAAO7B,CACT,CACF,CAAA,CAEJ,CACA+B,YAA4B,CAC1B,MAAM,IAAI7C,EAAI,gCAAA,CAChB,CACF,EEzFA,OAAS8C,OAAAA,MAAW,aACpB,OAASC,OAAAA,MAAW,iBACpB,OAASC,OAAAA,MAAW,WAIb,IAAMC,EAAN,cAA4BC,CAAAA,CANnC,MAMmCA,CAAAA,EAAAA,sBACjCC,aAAc,CACZ,GAAI,CAAC,KAAKC,OAAQ,MAAM,IAAIC,EAAI,SAAA,EAChC,GAAI,CAAC,KAAKC,UAAW,MAAM,IAAID,EAAI,YAAA,EACnC,GAAI,CAAC,KAAKE,MAAO,MAAM,IAAIF,EAAI,QAAA,CACjC,CACAG,YAAa,CACX,MAAO,WAAW,KAAKJ,MAAM,oBAAoB,KAAKK,aAAY,CAAA,EACpE,CACAC,YAAa,CACX,MAAO,CACL,gBAAiB,KAAKH,KACxB,CACF,CACAI,gBAAiB,CACf,OAAO,KAAKP,MACd,CACAQ,eAAgB,CACd,MAAO,WAAW,KAAKD,eAAc,CAAA,IAAM,KAAKE,eAAc,CAAA,EAChE,CACAC,0BAA2B,CACzB,MAAO,GAAG,KAAKF,cAAa,CAAA,mBAC9B,CACA,MAAMG,aAAaC,EAAKC,EAAS,CAC/B,GAAM,CAAEC,KAAMC,CAAO,EAAK,MAAM,KAAKC,OAAO,CAC1CC,OAAQ,MACRC,IAAK,cAAcN,CAAAA,EACrB,CAAA,EAAGO,MAAOC,GAAAA,CACR,GAAI,CAAC,KAAKC,MAAO,MAAMD,EACvB,MAAO,CAAEN,KAAM,CAAEQ,MAAO,cAAe,CAAE,CAC3C,CAAA,EAEA,GAAIP,EAAQO,OAASP,EAAQO,MAAMC,QAAQ,cAAA,IAAoB,IAAM,CAAC,KAAKF,MAAO,CAChFG,EAAIC,KAAK,oBAAoB,KAAKvB,SAAS,IAAIU,CAAAA,EAAK,EACpD,MACF,CAEA,MAAM,KAAKI,OAAO,CAChBC,OAAQ,SACRC,IAAK,cAAcN,CAAAA,EAErB,CAAA,EAAGO,MAAM,IAAA,CAAO,CAAA,EAEhB,MAAM,KAAKH,OAAO,CAChBC,OAAQ,OACRC,IAAK,aACLJ,KAAM,CACJF,IAAAA,EACAc,cAAe,OACfJ,MAAOT,EACPc,UAAW,EAEb,CACF,CAAA,CACF,CACA,MAAMC,gBAAiB,CACrBJ,MAAAA,EAAIC,KAAK,6CAAA,EACH,IAAIxB,EAAI,iBAAA,CAChB,CACA,MAAM4B,WAAY,CAChBL,MAAAA,EAAIC,KAAK,wCAAA,EACH,IAAIxB,EAAI,iBAAA,CAChB,CAEA,MAAM6B,gBAAiB,CACrB,GAAM,CAAEhB,KAAMiB,CAAS,EAAK,MAAM,KAAKf,OAAO,CAC5CC,OAAQ,MACRC,IAAK,QACP,CAAA,EAAGC,MAAOC,GAAAA,CACR,GAAI,CAAC,KAAKC,MAAO,MAAMD,EACvB,MAAO,CAAEN,KAAM,CAAEQ,MAAO,cAAe,CAAE,CAC3C,CAAA,EACA,MAAMU,EAAID,EAAW,MAAO,CAAEE,GAAIC,CAAM,IAAE,CACxC,MAAM,KAAKlB,OAAO,CAChBC,OAAQ,SACRC,IAAK,UAAUgB,CAAAA,EACjB,CAAA,CACF,CAAA,CACF,CACA,MAAMC,WAAWC,EAAM,CACrB,MAAM,KAAKpB,OAAO,CAChBC,OAAQ,OACRC,IAAK,SACLJ,KAAMsB,CACR,CAAA,CACF,CACF,EC5FA,OAASC,OAAAA,MAAW,WACpB,OAASC,WAAAA,MAAe,cACxB,OAASC,WAAAA,MAAe,OAExB,eAAsBC,EAAQC,EAAG,CAC/B,IAAMC,EAAU,MAAMC,EAAQF,EAAK,CAAEG,cAAe,EAAK,CAAA,EASzD,OARc,MAAMC,EAAIH,EAAS,MAAOI,GACjCA,EAAOC,YAAW,EAEhB,CACL,CAAEC,KAAMF,EAAOE,KAAMP,IAAKQ,EAAQR,CAAAA,EAAMS,SAAUD,EAAQR,EAAKK,EAAOE,IAAI,CAAE,KACxE,MAAMR,EAAQS,EAAQR,EAAKK,EAAOE,IAAI,CAAA,GAJV,CAAA,CAMpC,GACaG,KAAI,CAgBnB,CA1BsBX,EAAAA,EAAAA,WJStB,eAAsBY,EAAaC,EAAgBC,EAAe,CAAC,EAAC,CAClE,IAAMC,EAAcD,EAAQE,UAAY,GAAGH,CAAAA,SAEvCI,EACEC,EAAa,GAAGL,CAAAA,aACtB,GAAI,CAEFI,EAASE,EAAQD,CAAAA,CACnB,OAASE,EAAK,CACZ,GAAIA,EAAIC,OAAS,mBAAoB,CACnCC,EAAIC,MAAM,GAAGL,CAAAA,YAAsB,EACnC,MACF,CACA,MAAME,CACR,CAEA,MAAMI,EAAO,GAAGT,CAAAA,EAAa,EAAEU,MAAM,IAAA,CAAO,CAAA,EAC5C,MAAMC,EAAMX,EAAa,CAAEY,UAAW,EAAK,CAAA,EAE3C,IAAMC,EAAcX,EAAOY,SAASD,YACpC,GAAI,CAACA,EAAa,MAAM,IAAIE,EAAI,cAAA,EAEhC,IAAID,EACJ,GAAID,IAAgB,SAClBC,EAAU,IAAIE,EAAc,CAC1B,GAAGd,EAAOY,QACV,GAAGf,CACL,CAAA,UACSc,IAAgB,SACzBC,EAAU,IAAIG,EAAc,CAC1B,GAAGf,EAAOY,QACV,GAAGf,CACL,CAAA,MAEA,OAAM,IAAIgB,EAAI,wBAAyB,CAAEF,YAAAA,CAAY,CAAA,EAGvD,GAAM,CAAEK,MAAAA,EAAQ,CAAA,CAAE,EAAKhB,EACvB,MAAMiB,EAAUD,EAAO,MAAOE,GAAAA,CAC5B,GAAM,CAAEC,KAAAA,EAAMC,SAAAA,EAAUC,QAAAA,CAAO,EAAKH,EAC9BI,EAAM,MAAMD,EAAQH,EAAalB,CAAAA,EACjCuB,EAAUC,EAAW,CACzBJ,SAAAA,EACAK,OAAQ,CACN,CAAC,SAAUb,EAAQc,eAAc,GACjC,CAAC,UAAWd,EAAQe,eAAc,GAClC,CAAC,aAAcf,EAAQgB,aAAY,GACnC,CAAC,cAAehB,EAAQiB,cAAa,GACrC,CAAC,gBAAiBjB,EAAQkB,yBAAwB,IAEpDC,OACEnB,EAAQoB,mBAAkB,GAC1B;oBACYpB,EAAQoB,mBAAkB,CAAA;;QAEtCC,KAAI,CACR,CAAA,EACA,MAAMC,EAAW,GAAGpC,CAAAA,IAAesB,CAAAA,GAAYE,EAAK,CAClDH,KAAAA,EACAgB,QAAS,CAACtC,EAAQuC,MAClBb,QAAAA,CACF,CAAA,EACAlB,EAAIgC,KAAK,WAAWzB,EAAQe,eAAc,CAAA,KAAOP,CAAAA,GAAW,CAC9D,CAAA,CACF,CAhEsBzB,EAAAA,EAAAA,gBAiEtB,eAAsB2C,GAAiBC,EAAS1C,EAAU,CAAC,EAAC,CAC1D,IAAM2C,EAAW,MAAMC,EAAQF,CAAAA,EACzBvB,GACJ,MAAM0B,EAAIF,EAAU,MAAOG,GAAAA,CACzB,GAAM,CAAEvB,SAAAA,CAAQ,EAAKuB,EACrB,OAAM,MAAMC,EAAW,GAAGxB,CAAAA,YAAoB,EACvCuB,EADkD,IAE3D,CAAA,GACAE,OAAOC,OAAAA,EAET,OAAO7B,EAAUD,EAAO,MAAO,CAAEI,SAAAA,CAAQ,IAAE,CACzC,MAAMzB,EAAayB,EAAUvB,CAAAA,EAASW,MAAOL,GAAAA,CAC3CE,EAAIC,MAAM,eAAec,CAAAA,KAAcjB,CAAAA,CACzC,CAAA,CACF,CAAA,CACF,CAfsBmC,EAAAA,GAAAA","names":["Err","log","getComment","jsonToFile","map","mapSeries","existsSync","mkdir","unlink","Err","_sodium","Err","log","axios","map","Service","projectId","projectName","projectPath","projectCredsUrl","token","server","force","client","constructor","options","Object","assign","checkConfig","clientOptions","baseURL","getBaseUrl","headers","getHeaders","axios","create","Err","getServiceLink","getProjectName","getProjectId","getProjectPath","getProjectUrl","getProjectCredsUrl","getProjectCICDSettingURL","uploadSecret","key","content","uploadVariable","removeOldHooks","uploadHook","dataHook","uploadHooks","env","hooks","e","log","error","message","map","index","info","uploadAll","secrets","variables","files","entries","value","name","credType","debug","GithubService","Service","checkConfig","token","Err","f","getBaseUrl","server","getProjectPath","getHeaders","Accept","Authorization","getServiceLink","getProjectUrl","projectName","getProjectCICDSettingURL","uploadSecret","key","content","data","publicKeyData","client","method","url","catch","err","message","response","key_id","_sodium","ready","sodium","binkey","from_base64","base64_variants","ORIGINAL","binsec","from_string","encBytes","crypto_box_seal","output","to_base64","encrypted_value","uploadVariable","varData","status","name","value","toLowerCase","uploadHook","Err","log","map","GitlabService","Service","checkConfig","server","Err","projectId","token","getBaseUrl","getProjectId","getHeaders","getServiceLink","getProjectUrl","getProjectPath","getProjectCICDSettingURL","uploadSecret","key","content","data","varData","client","method","url","catch","err","force","value","indexOf","log","warn","variable_type","protected","uploadVariable","uploadEnv","removeOldHooks","hooksList","map","id","hookId","uploadHook","hook","map","readdir","resolve","getDirs","dir","dirents","readdir","withFileTypes","map","dirent","isDirectory","name","resolve","filename","flat","buildCommand","serviceDirname","options","buildDirDir","buildDir","config","configPath","require","err","code","log","error","unlink","catch","mkdir","recursive","serviceName","service","Err","GithubService","GitlabService","files","mapSeries","fileOptions","type","filename","handler","res","comment","getComment","values","getServiceLink","getProjectPath","getProjectId","getProjectUrl","getProjectCICDSettingURL","footer","getProjectCredsUrl","trim","jsonToFile","compare","force","info","buildDeepCommand","dirname","rawFiles","getDirs","map","rawFile","existsSync","filter","Boolean"]}