Merge pull request #2175 from balena-io/cloud-build-orgs

Modify push to pass app slug to builder
This commit is contained in:
bulldozer-balena[bot] 2021-02-04 13:56:31 +00:00 committed by GitHub
commit 6fb58a25fc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 9 additions and 40 deletions

View File

@ -20,7 +20,7 @@ import Command from '../command';
import * as cf from '../utils/common-flags'; import * as cf from '../utils/common-flags';
import { getBalenaSdk, stripIndent } from '../utils/lazy'; import { getBalenaSdk, stripIndent } from '../utils/lazy';
import { dockerignoreHelp, registrySecretsHelp } from '../utils/messages'; import { dockerignoreHelp, registrySecretsHelp } from '../utils/messages';
import type { BalenaSDK, Application, Organization } from 'balena-sdk'; import type { BalenaSDK } from 'balena-sdk';
import { ExpectedError, instanceOf } from '../errors'; import { ExpectedError, instanceOf } from '../errors';
import { isV13 } from '../utils/version'; import { isV13 } from '../utils/version';
import { RegistrySecrets } from 'resin-multibuild'; import { RegistrySecrets } from 'resin-multibuild';
@ -353,32 +353,9 @@ export default class PushCmd extends Command {
sdk.settings.get('balenaUrl'), sdk.settings.get('balenaUrl'),
]); ]);
const application = (await getApplication(sdk, appNameOrSlug, { const application = await getApplication(sdk, appNameOrSlug, {
$expand: {
organization: {
$select: ['handle'],
},
},
$select: ['app_name', 'slug'], $select: ['app_name', 'slug'],
})) as Application & { });
organization: [Organization];
};
// * Temporary fix *
// When doing `$expand organization` on a public app (when not the owner)
// a partial document is returned without any organization data.
// So e.g. `balena push balena-sound` will break this commands logic.
// The balena cloud builder api will soon change to accept application slugs
// instead of `owner, app`, after which we will not need to do the expand
//
// Users should not be pushing to public apps anyway, so for now catch this situation:
if (!application.organization[0]) {
throw new ExpectedError(stripIndent`
You do not have permissions to push to application ${application.slug}.
If you are trying to deploy a public app, please make sure that you have created
your own application first.
`);
}
const opts = { const opts = {
dockerfilePath, dockerfilePath,
@ -390,8 +367,7 @@ export default class PushCmd extends Command {
convertEol: !options['noconvert-eol'], convertEol: !options['noconvert-eol'],
}; };
const args = { const args = {
app: application.app_name, appSlug: application.slug,
owner: application.organization[0].handle,
source: options.source, source: options.source,
auth: token, auth: token,
baseUrl, baseUrl,

View File

@ -45,16 +45,13 @@ export interface BuildOpts {
} }
export interface RemoteBuild { export interface RemoteBuild {
app: string; appSlug: string;
owner: string;
source: string; source: string;
auth: string; auth: string;
baseUrl: string; baseUrl: string;
nogitignore: boolean; nogitignore: boolean;
opts: BuildOpts; opts: BuildOpts;
sdk: BalenaSDK; sdk: BalenaSDK;
// For internal use // For internal use
releaseId?: number; releaseId?: number;
hadError?: boolean; hadError?: boolean;
@ -85,14 +82,12 @@ export class RemoteBuildFailedError extends ExpectedError {
async function getBuilderEndpoint( async function getBuilderEndpoint(
baseUrl: string, baseUrl: string,
owner: string, appSlug: string,
app: string,
opts: BuildOpts, opts: BuildOpts,
): Promise<string> { ): Promise<string> {
const querystring = await import('querystring'); const querystring = await import('querystring');
const args = querystring.stringify({ const args = querystring.stringify({
owner, slug: appSlug,
app,
dockerfilePath: opts.dockerfilePath, dockerfilePath: opts.dockerfilePath,
emulated: opts.emulated, emulated: opts.emulated,
nocache: opts.nocache, nocache: opts.nocache,
@ -384,8 +379,7 @@ async function getRemoteBuildStream(
): Promise<[request.Request, Stream.Stream]> { ): Promise<[request.Request, Stream.Stream]> {
const builderUrl = await getBuilderEndpoint( const builderUrl = await getBuilderEndpoint(
build.baseUrl, build.baseUrl,
build.owner, build.appSlug,
build.app,
build.opts, build.opts,
); );
let stream: Stream.Stream; let stream: Stream.Stream;

View File

@ -66,8 +66,7 @@ const commonResponseLines = {
}; };
const commonQueryParams = [ const commonQueryParams = [
['owner', 'gh_user'], ['slug', 'gh_user/testApp'],
['app', 'testApp'],
['dockerfilePath', ''], ['dockerfilePath', ''],
['emulated', 'false'], ['emulated', 'false'],
['nocache', 'false'], ['nocache', 'false'],