diff options
| author | Kasra Bigdeli <[email protected]> | 2020-08-16 07:34:44 -0400 |
|---|---|---|
| committer | Kasra Bigdeli <[email protected]> | 2020-08-16 07:34:44 -0400 |
| commit | f0ccc406dceee0c9916cc04dc413222ee1f79775 (patch) | |
| tree | 08f1316341420761eecc922801dfe6c66216d223 /scripts | |
| parent | 3cb7e7d6bbcd369d220b35eb0dea261fc17c14b5 (diff) | |
| download | caprover-one-click-apps-f0ccc406dceee0c9916cc04dc413222ee1f79775.tar.gz caprover-one-click-apps-f0ccc406dceee0c9916cc04dc413222ee1f79775.zip | |
Revert "Added private bin and v4"
This reverts commit 7c827cac0e2acb4fb912fc51b89fc0562de3e459.
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/build_one_click_apps.js | 6 | ||||
| -rw-r--r-- | scripts/build_one_click_apps_from_v4.js | 170 |
2 files changed, 3 insertions, 173 deletions
diff --git a/scripts/build_one_click_apps.js b/scripts/build_one_click_apps.js index 69fa232..b08f04d 100644 --- a/scripts/build_one_click_apps.js +++ b/scripts/build_one_click_apps.js @@ -77,12 +77,12 @@ function convertV2toV4(v2String) { parsed[propertyName] = undefined; } - parsed.services = parsed.dockerCompose.services; - parsed.dockerCompose = undefined; - parsed.captainVersion = 4; parsed.caproverOneClickApp = {}; + parsed.services = parsed.dockerCompose.services; + parsed.dockerCompose = undefined; + moveProperty('variables'); moveProperty('instructions'); moveProperty('displayName'); diff --git a/scripts/build_one_click_apps_from_v4.js b/scripts/build_one_click_apps_from_v4.js deleted file mode 100644 index 20bcda3..0000000 --- a/scripts/build_one_click_apps_from_v4.js +++ /dev/null @@ -1,170 +0,0 @@ -/*jshint esversion: 6 */ -const path = require('path'); -const yaml = require('yaml'); -const fs = require('fs-extra'); - -const pathOfPublic = path.join(__dirname, '..', `public`); - -const pathOfDist = path.join(__dirname, '..', `dist`); - -const pathOfDistV2 = path.join(pathOfDist, 'v2'); -const pathOfDistV3 = path.join(pathOfDist, 'v3'); -const pathOfDistV4 = path.join(pathOfDist, 'v4'); - -const pathOfSourceDirectory = path.join(pathOfPublic, 'v4'); -const pathOfSourceDirectoryApps = path.join(pathOfSourceDirectory, 'apps'); -const pathOfSourceDirectoryLogos = path.join(pathOfSourceDirectory, 'logos'); - -/** - * Creates a listing of apps for GET http://oneclickapps.caprover.com/v4 - * { - "oneClickApps": [ - { - "name": "adminer", - "displayName": "Adminer", - "description": "Adminer (formerly phpMinAdmin) is a full-featured database management tool written in PHP", - "isOfficial": true, - "logoUrl": "adminer.png" - },.....]} - */ -function createAppList(appsFileNames, pathOfApps) { - const apps = appsFileNames.filter(v => `${v}`.endsWith('.yml')); - - if (apps.length !== appsFileNames.length) { - throw new Error('All files in v4 must end with .yml extension!'); - } - - const appDetails = []; - - for (var i = 0; i < apps.length; i++) { - const contentString = fs.readFileSync(path.join(pathOfApps, apps[i]), 'utf-8'); - const content = yaml.parse(contentString); - const captainVersion = `${content.captainVersion}`; - - apps[i] = apps[i].replace('.yml', ''); - const caproverOneClickApp = content.caproverOneClickApp; - - if (captainVersion === '4') { - if (!caproverOneClickApp.displayName) { - caproverOneClickApp.displayName = apps[i]; - caproverOneClickApp.displayName = caproverOneClickApp.displayName.substr(0, 1).toUpperCase() + - caproverOneClickApp.displayName.substring(1, caproverOneClickApp.displayName.length); - } - if (!caproverOneClickApp.description) caproverOneClickApp.description = ''; - - appDetails[i] = { - name: apps[i], - displayName: caproverOneClickApp.displayName, - description: caproverOneClickApp.description, - isOfficial: `${caproverOneClickApp.isOfficial}`.toLowerCase().trim() === 'true', - logoUrl: apps[i] + '.png' - }; - } else { - throw new Error('Unknown captain-version: ' + captainVersion); - } - - } - - return { - appList: apps, - appDetails: appDetails - }; -} - -function convertV4toV2(v4String) { - const parsed = JSON.parse(v4String); - if (`${parsed.captainVersion}` !== '4') { - throw new Error('CaptainVersion must be 4 for this conversion'); - } - - function moveProperty(propertyName) { - parsed[propertyName] = parsed.caproverOneClickApp[propertyName]; - } - - parsed.dockerCompose = { - services: parsed.services - }; - parsed.services = undefined; - - parsed.captainVersion = 2; - - - moveProperty('variables'); - moveProperty('instructions'); - moveProperty('displayName'); - moveProperty('description'); - moveProperty('documentation'); - - Object.keys(parsed.dockerCompose.services).forEach(serviceName => { - const service = parsed.dockerCompose.services[serviceName]; - - if (!service.caproverExtra) { - return; - } - - if (service.caproverExtra.containerHttpPort) { - service.containerHttpPort = service.caproverExtra.containerHttpPort; - } - if (service.caproverExtra.dockerfileLines) { - service.dockerfileLines = service.caproverExtra.dockerfileLines; - } - if (service.caproverExtra.notExposeAsWebApp) { - service.notExposeAsWebApp = service.caproverExtra.notExposeAsWebApp; - } - - service.caproverExtra = undefined; - }); - - parsed.caproverOneClickApp = undefined; - return parsed; -} - - -function buildDist() { - return fs.readdir(pathOfSourceDirectoryApps) - .then(function (appsFileNames) { // [ app1.yml app2.yml .... ] - - appsFileNames.forEach(appFileName => { - - console.log('Building dist for ' + appFileName); - - const pathOfAppFileInSource = path.join(pathOfSourceDirectoryApps, appFileName); - const contentParsed = yaml.parse(fs.readFileSync(pathOfAppFileInSource, 'utf-8')); - - //v4 - fs.outputJsonSync(path.join(pathOfDistV4, `apps`, appFileName.split('.')[0]), contentParsed); - - //v3 - fs.outputJsonSync(path.join(pathOfDistV3, `apps`, appFileName.split('.')[0]), convertV4toV2(JSON.stringify(contentParsed))); - - //v2 - fs.outputJsonSync(path.join(pathOfDistV2, `apps`, appFileName.split('.')[0] + '.json'), convertV4toV2(JSON.stringify(contentParsed))); - }); - - fs.copySync(pathOfSourceDirectoryLogos, path.join(pathOfDistV2, `logos`)); - fs.copySync(pathOfSourceDirectoryLogos, path.join(pathOfDistV3, `logos`)); - fs.copySync(pathOfSourceDirectoryLogos, path.join(pathOfDistV4, `logos`)); - - const allAppsList = createAppList(appsFileNames, pathOfSourceDirectoryApps); - const v3List = { - oneClickApps: allAppsList.appDetails - }; - fs.outputJsonSync(path.join(pathOfDistV2, 'autoGeneratedList.json'), allAppsList); - fs.outputJsonSync(path.join(pathOfDistV2, 'list'), v3List); - fs.outputJsonSync(path.join(pathOfDistV3, 'list'), v3List); - fs.outputJsonSync(path.join(pathOfDistV4, 'list'), v3List); - }) - .then(function () { - return fs.copySync(path.join(pathOfPublic, 'CNAME'), path.join(pathOfDist, 'CNAME')); - }); -} - - -Promise.resolve() - .then(function () { - return buildDist(); - }) - .catch(function (err) { - console.error(err); - process.exit(127); - });
\ No newline at end of file |
