UNPKG

5.02 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.dpush_image_ex = exports.dpush_prep = exports.realm_init = void 0;
4const p_spawn_1 = require("p-spawn");
5const block_1 = require("./block");
6const main_1 = require("./main");
7//#region ---------- Hook Functions ----------
8// finish initializing a realm object
9async function realm_init(realm) {
10 // a aws realm must have a profile. Default is 'default'
11 if (!realm.profile) {
12 realm.profile = 'default';
13 }
14}
15exports.realm_init = realm_init;
16async function dpush_prep(realm, serviceNames) {
17 const blockByName = await block_1.loadBlocks();
18 const repoNames = serviceNames.map(sn => main_1.getRepositoryName(blockByName[sn]));
19 const existingRepositoryNames = await getAwsExistingRepositoryNames(realm);
20 const missingRepositoryNames = repoNames.filter(n => !existingRepositoryNames.includes(n));
21 await createRepositories(realm, missingRepositoryNames);
22}
23exports.dpush_prep = dpush_prep;
24// const args = ['login', '-u', 'AWS', '-p',
25// "eyJwYXlsb2FkIjoiSGNQSXUyWEFRaE9KaU1NVGtzTGRKZXdibVJnSGdULy9KbmxCdDF1bUVySlFiUGpuY0ZYMWRHazg2YU4vU1hpTGg3c2tmeURoSkRlUzRHS3NSYi8yYnk1MXNnRkJieW1vVExrVkdvMS9ycXk2bURyMGxUUXVnNlNkb0ZsN2I5ZVdBZjlYdjdFN0ZSVjBQME56UEFteWloVmQ3Si8zNWJNU1k1ZGw5dHZ2U2sxeEd6Y3JUUGRZN0RxK0lwQVA2TXZjYjFUT1BORDc0OXdjN1UzcWw2Zkd2Y2htVkZPdzZDa2NuVlNsOHJqUTJRU3orRUdnMDl3K1FQL0hteGhEY1A4UXhmL0l2SnM5QXVDRkhpMWN5bWpCdXZxUlE0SWtPKzYvbDJadS9CN1BNNDZqeU0wM3NIQzBsVGRNdktpVFhzSFpOQ0RSU1AyQ3hFT0x1T3pFcHpjTnZaUUhBZXpHdzQvRy8zQjVINFZ1bG5iY1pPaklkZVEyeklkbXBvcW9WZmNoMVJaL2MxOHJFbnhKaVcwM0pudTRIMElLSXVzaksvaytCdU9PZVlNSnRHUmpDK1NFWWk0ajBZMDhOZ1I4cVp4bktIdFBwSkUrVm9jTVJmdCtub3lLQklac0JJdTZtQ2srTTc1ZnVYeEp1V01ZL3pQY1dlcUdFbnZTWVRPbzRsd0RzRmlocEE3WmVsQjdGS1d0Y01Za2JBU1Z6d1JIUDlkM1dBRGhVMXBMcm1hM1VmUnFZVmtXdkNVaVF2QU5wbUZhVG9iWkJzeU9UUkFLaVM4cWV5ZUdtZnJyK3lUUGNVNW93REdnRWduMHdFbENnTDd6bkR1OTdMWjhvVUVZZkROd2FvdnJacEtWbUpJVW5UVWNMdml0eTFVa2tNSHhPNDBDRnRSckc3Y0hSbXovc0VhMjFOeDhpbTRlbVpKSUdNUzI1TUw1YWRqQ1ZOMXRDUVFRWUVTUWVqSzdXUkt3YmgvSWVGSXE3RjJDeVdUNllJU3BmTGYrbG5RR1pReXVOTlovbUtLNzRDOGJacDN5b3pVRUhoMWJPTy9UK2htQVp5Z1pTdmFBVnJkbTJ6OS9mcXpldWcxbzFhZGRwbG9sbDJMMlZZVFJBbklCcHhBQjlRQ0d4MDRsU3dyajJmL25Xc0JOT0xyR3BDZytJYnZpRlRWUzBxK2dLcU1rOWV4K1ZldGVKbXhWTjVZbm9TK1pxZHdGUmk5bkcxeW5QSVkwMWl4TnNRbzgxZ3BHNWJCclFqK0RwUEVxMnNrN2dlOUwzejNlWGRkaWdxcyt6eG5oUUNsdStJOEk4YjRiTEJEQmZTclBNUU0rSnpZblpGZ0hCUFF6NVBKU2U5d0syMGtFNk9KMzk0QVZmN0NHRGRjVThTc0JJanhoL2hyZ2tvMmlxZG9vQ3ZncTFKNnlROVdSY09RSXBORTg4VVBXZExvamZNcFBCZ0hnVVl4aVlPMHBMY2RqUVFaY0dNdGJwT29aSnc9PSIsImRhdGFrZXkiOiJBUUVCQUhqNmxjNFhJSncvN2xuMEhjMDBETWVrNkdFeEhDYlk0UklwVE1DSTU4SW5Vd0FBQUg0d2ZBWUpLb1pJaHZjTkFRY0dvRzh3YlFJQkFEQm9CZ2txaGtpRzl3MEJCd0V3SGdZSllJWklBV1VEQkFFdU1CRUVET2x2cmtCYi9VbFJQOE1HOEFJQkVJQTdkcEtMYlBMZHcvWS94MGR2aWV1cXFKc2c5Ni9aNnR6ZnBhdEozOUxka0d6VXgrMHF2cnYyajJUN2I4bC9MWW5ZaURIUExNVFVIMjBJR1A0PSIsInZlcnNpb24iOiIyIiwidHlwZSI6IkRBVEFfS0VZIiwiZXhwaXJhdGlvbiI6MTU2MDE2NjYyNn0=", 'https://349642121055.dkr.ecr.us-west-2.amazonaws.com']
26async function dpush_image_ex(realm, ex, remoteImage) {
27 console.log(`dpush - recovering - first docker dpush to ${remoteImage} failed, trying to recover`);
28 // aws ecr get-login --no-include-email
29 const reloginCmd = await p_spawn_1.spawn('aws', ['ecr', 'get-login', '--no-include-email', '--profile', realm.profile], { capture: 'stdout' });
30 const reloginArg = reloginCmd.stdout.trim().split(' ');
31 reloginArg.shift(); // remove the 'docker' first item.
32 try {
33 const relogin = await p_spawn_1.spawn('docker', reloginArg, { capture: 'stdout' });
34 console.log('dpush - relogin success');
35 console.log(`dpush - trying to push again ${remoteImage}`);
36 await p_spawn_1.spawn('docker', ['push', remoteImage]);
37 console.log('dpush - fully recovered');
38 }
39 catch (ex2) {
40 console.log('dpush - error - relogin/repush failed', ex2);
41 throw ex2;
42 }
43 return true;
44}
45exports.dpush_image_ex = dpush_image_ex;
46//#endregion ---------- /Hook Functions ----------
47//#region ---------- Utils ----------
48async function createRepositories(realm, repoNames) {
49 for (const repo of repoNames) {
50 // aws ecr create-repository --profile default --repository-name cstar-agent
51 console.log(`Info - aws ECR repository ${repo} does not exist, creating...`);
52 await p_spawn_1.spawn('aws', ['ecr', 'create-repository', '--profile', realm.profile, '--repository-name', repo]);
53 }
54}
55async function getAwsExistingRepositoryNames(realm) {
56 // NOTE: Somehow even when the login has expired, this call works (it's the push that does not work)
57 const dataStr = await p_spawn_1.spawn('aws', ['ecr', 'describe-repositories', '--profile', realm.profile], { capture: 'stdout' });
58 const repositories = JSON.parse(dataStr.stdout.trim()).repositories;
59 if (repositories) {
60 return repositories.map((r) => r.repositoryName);
61 }
62 else {
63 return [];
64 }
65}
66//#endregion ---------- /Utils ----------