mirror of
https://github.com/balena-io/balena-cli.git
synced 2025-01-03 04:26:39 +00:00
Merge pull request #2175 from balena-io/cloud-build-orgs
Modify push to pass app slug to builder
This commit is contained in:
commit
6fb58a25fc
@ -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,
|
||||||
|
@ -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;
|
||||||
|
@ -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'],
|
||||||
|
Loading…
Reference in New Issue
Block a user