diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 4b9c449..f9009d3 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -108,50 +108,6 @@ jobs: if: always() uses: crazy-max/ghaction-dump-context@v1 - bake: - runs-on: ubuntu-latest - strategy: - fail-fast: false - matrix: - target: - - default - - release - steps: - - - name: Run local registry - run: | - docker run -d -p 5000:5000 registry:2 - - - name: Checkout - uses: actions/checkout@v2.3.1 - - - name: Set up QEMU - uses: ./setup-qemu/ # change to docker/setup-qemu-action@master - with: - platforms: all - - - name: Set up Docker Buildx - id: buildx - uses: ./setup-buildx/ # change to docker/setup-buildx-action@master - with: - driver-opt: network=host - buildkitd-flags: --allow-insecure-entitlement security.insecure - - - name: Build and push - uses: ./ - with: - builder: ${{ steps.buildx.outputs.name }} - bake: true - push: false # set to true when https://github.com/docker/buildx/issues/179 is fixed - bake-files: | - ./test/config.hcl - bake-targets: | - ${{ matrix.target }} - - - name: Dump context - if: always() - uses: crazy-max/ghaction-dump-context@v1 - github-cache: runs-on: ubuntu-latest steps: diff --git a/README.md b/README.md index b33062e..808f5fb 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,6 @@ ___ * [Usage](#usage) * [Quick start](#quick-start) - * [Bake](#bake) * [Git context](#git-context) * [Customizing](#customizing) * [inputs](#inputs) @@ -66,57 +65,6 @@ jobs: user/app:1.0.0 ``` -### Bake - -[Buildx bake](https://github.com/docker/buildx#buildx-bake-options-target) is also available with this action through -the [`bake` inputs](#inputs): - -```yaml -name: ci - -on: - pull_request: - branches: master - push: - branches: master - tags: - -jobs: - bake: - runs-on: ubuntu-latest - steps: - - - name: Checkout - uses: actions/checkout@v2 - - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - with: - platforms: all - - - name: Set up Docker Buildx - id: buildx - uses: docker/setup-buildx-action@v1 - - - name: Login to DockerHub - uses: crazy-max/ghaction-docker-login@v1 # switch to docker/login-action@v1 when available - with: - username: ${{ secrets.DOCKER_USERNAME }} - password: ${{ secrets.DOCKER_PASSWORD }} - - - name: Build and push - uses: docker/build-push-action@v2 - with: - builder: ${{ steps.buildx.outputs.name }} - push: true - bake: true - bake-files: | - ./config.hcl - bake-targets: | - default - release -``` - ### Git context You can build from Git directly without [`actions/checkout`](https://github.com/actions/checkout/) action, @@ -192,9 +140,6 @@ Following inputs can be used as `step.with` keys | `outputs` | List | | List of [output destinations](https://github.com/docker/buildx#-o---outputpath-typetypekeyvalue) (format: `type=local,dest=path`) | | `cache-from` | List | | List of [external cache sources](https://github.com/docker/buildx#--cache-fromnametypetypekeyvalue) (eg. `user/app:cache`, `type=local,src=path/to/dir`) | | `cache-to` | List | | List of [cache export destinations](https://github.com/docker/buildx#--cache-tonametypetypekeyvalue) (eg. `user/app:cache`, `type=local,dest=path/to/dir`) | -| `bake` | Bool | `false` | Use [bake](https://github.com/docker/buildx#buildx-bake-options-target) as the high-level build command | -| `bake-files` | List | | List of [bake definition files](https://github.com/docker/buildx#file-definition) | -| `bake-targets` | List | | List of bake targets | > List type can be a comma or newline-delimited string > ```yaml diff --git a/action.yml b/action.yml index d642397..5e8ffaa 100644 --- a/action.yml +++ b/action.yml @@ -1,5 +1,6 @@ -name: Docker Build and Push -description: Build and push Docker images +# https://help.github.com/en/articles/metadata-syntax-for-github-actions +name: Docker Build Push +description: Build and push Docker images with Buildx author: docker branding: icon: 'anchor' @@ -64,16 +65,6 @@ inputs: description: "Export all the layers of all intermediate steps in the GitHub cache" required: false default: 'false' - bake: - description: "Use bake as the high-level build command" - required: false - default: 'false' - bake-files: - description: "Newline-delimited list of bake definition files" - required: false - bake-targets: - description: "Newline-delimited list of bake targets" - required: false outputs: digest: diff --git a/dist/index.js b/dist/index.js index f4a31bd..a1267a4 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1928,65 +1928,7 @@ var ValueType; /***/ }), /* 44 */, -/* 45 */ -/***/ (function(module, __unusedexports, __webpack_require__) { - -"use strict"; - - -// Dependencies - -var parseUrl = __webpack_require__(823), - isSsh = __webpack_require__(720); - -/** - * gitUp - * Parses the input url. - * - * @name gitUp - * @function - * @param {String} input The input url. - * @return {Object} An object containing the following fields: - * - * - `protocols` (Array): An array with the url protocols (usually it has one element). - * - `port` (null|Number): The domain port. - * - `resource` (String): The url domain (including subdomains). - * - `user` (String): The authentication user (usually for ssh urls). - * - `pathname` (String): The url pathname. - * - `hash` (String): The url hash. - * - `search` (String): The url querystring value. - * - `href` (String): The input url. - * - `protocol` (String): The git url protocol. - * - `token` (String): The oauth token (could appear in the https urls). - */ -function gitUp(input) { - var output = parseUrl(input); - output.token = ""; - - var splits = output.user.split(":"); - if (splits.length === 2) { - if (splits[1] === "x-oauth-basic") { - output.token = splits[0]; - } else if (splits[0] === "x-token-auth") { - output.token = splits[1]; - } - } - - if (isSsh(output.protocols) || isSsh(input)) { - output.protocol = "ssh"; - } else if (output.protocols.length) { - output.protocol = output.protocols[0]; - } else { - output.protocol = "file"; - } - - output.href = output.href.replace(/\/$/, ""); - return output; -} - -module.exports = gitUp; - -/***/ }), +/* 45 */, /* 46 */, /* 47 */ /***/ (function(__unusedmodule, exports) { @@ -2023,149 +1965,46 @@ module.exports = ["ac","com.ac","edu.ac","gov.ac","net.ac","mil.ac","org.ac","ad /* 51 */, /* 52 */, /* 53 */ -/***/ (function(module, __unusedexports, __webpack_require__) { +/***/ (function(__unusedmodule, exports, __webpack_require__) { "use strict"; -// TODO: Use the `URL` global when targeting Node.js 10 -const URLParser = typeof URL === 'undefined' ? __webpack_require__(835).URL : URL; - -const testParameter = (name, filters) => { - return filters.some(filter => filter instanceof RegExp ? filter.test(name) : filter === name); -}; - -module.exports = (urlString, opts) => { - opts = Object.assign({ - defaultProtocol: 'http:', - normalizeProtocol: true, - forceHttp: false, - forceHttps: false, - stripHash: true, - stripWWW: true, - removeQueryParameters: [/^utm_\w+/i], - removeTrailingSlash: true, - removeDirectoryIndex: false, - sortQueryParameters: true - }, opts); - - // Backwards compatibility - if (Reflect.has(opts, 'normalizeHttps')) { - opts.forceHttp = opts.normalizeHttps; - } - - if (Reflect.has(opts, 'normalizeHttp')) { - opts.forceHttps = opts.normalizeHttp; - } - - if (Reflect.has(opts, 'stripFragment')) { - opts.stripHash = opts.stripFragment; - } - - urlString = urlString.trim(); - - const hasRelativeProtocol = urlString.startsWith('//'); - const isRelativeUrl = !hasRelativeProtocol && /^\.*\//.test(urlString); - - // Prepend protocol - if (!isRelativeUrl) { - urlString = urlString.replace(/^(?!(?:\w+:)?\/\/)|^\/\//, opts.defaultProtocol); - } - - const urlObj = new URLParser(urlString); - - if (opts.forceHttp && opts.forceHttps) { - throw new Error('The `forceHttp` and `forceHttps` options cannot be used together'); - } - - if (opts.forceHttp && urlObj.protocol === 'https:') { - urlObj.protocol = 'http:'; - } - - if (opts.forceHttps && urlObj.protocol === 'http:') { - urlObj.protocol = 'https:'; - } - - // Remove hash - if (opts.stripHash) { - urlObj.hash = ''; - } - - // Remove duplicate slashes if not preceded by a protocol - if (urlObj.pathname) { - // TODO: Use the following instead when targeting Node.js 10 - // `urlObj.pathname = urlObj.pathname.replace(/(?<!https?:)\/{2,}/g, '/');` - urlObj.pathname = urlObj.pathname.replace(/((?![https?:]).)\/{2,}/g, (_, p1) => { - if (/^(?!\/)/g.test(p1)) { - return `${p1}/`; - } - return '/'; - }); - } - - // Decode URI octets - if (urlObj.pathname) { - urlObj.pathname = decodeURI(urlObj.pathname); - } - - // Remove directory index - if (opts.removeDirectoryIndex === true) { - opts.removeDirectoryIndex = [/^index\.[a-z]+$/]; - } - - if (Array.isArray(opts.removeDirectoryIndex) && opts.removeDirectoryIndex.length > 0) { - let pathComponents = urlObj.pathname.split('/'); - const lastComponent = pathComponents[pathComponents.length - 1]; - - if (testParameter(lastComponent, opts.removeDirectoryIndex)) { - pathComponents = pathComponents.slice(0, pathComponents.length - 1); - urlObj.pathname = pathComponents.slice(1).join('/') + '/'; - } - } - - if (urlObj.hostname) { - // Remove trailing dot - urlObj.hostname = urlObj.hostname.replace(/\.$/, ''); - - // Remove `www.` - // eslint-disable-next-line no-useless-escape - if (opts.stripWWW && /^www\.([a-z\-\d]{2,63})\.([a-z\.]{2,5})$/.test(urlObj.hostname)) { - // Each label should be max 63 at length (min: 2). - // The extension should be max 5 at length (min: 2). - // Source: https://en.wikipedia.org/wiki/Hostname#Restrictions_on_valid_host_names - urlObj.hostname = urlObj.hostname.replace(/^www\./, ''); - } - } - - // Remove query unwanted parameters - if (Array.isArray(opts.removeQueryParameters)) { - for (const key of [...urlObj.searchParams.keys()]) { - if (testParameter(key, opts.removeQueryParameters)) { - urlObj.searchParams.delete(key); - } - } - } - - // Sort query parameters - if (opts.sortQueryParameters) { - urlObj.searchParams.sort(); - } - - // Take advantage of many of the Node `url` normalizations - urlString = urlObj.toString(); - - // Remove ending `/` - if (opts.removeTrailingSlash || urlObj.pathname === '/') { - urlString = urlString.replace(/\/$/, ''); - } - - // Restore relative protocol, if applicable - if (hasRelativeProtocol && !opts.normalizeProtocol) { - urlString = urlString.replace(/^http:\/\//, '//'); - } - - return urlString; -}; - +/*! + * Copyright 2019, OpenTelemetry Authors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +Object.defineProperty(exports, "__esModule", { value: true }); +const context_1 = __webpack_require__(560); +class NoopContextManager { + active() { + return context_1.Context.ROOT_CONTEXT; + } + with(context, fn) { + return fn(); + } + bind(target, context) { + return target; + } + enable() { + return this; + } + disable() { + return this; + } +} +exports.NoopContextManager = NoopContextManager; +//# sourceMappingURL=NoopContextManager.js.map /***/ }), /* 54 */, @@ -5545,12 +5384,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); /* 188 */, /* 189 */, /* 190 */, -/* 191 */ -/***/ (function(module) { - -module.exports = require("querystring"); - -/***/ }), +/* 191 */, /* 192 */, /* 193 */, /* 194 */, @@ -6368,239 +6202,7 @@ exports.downloadCacheStorageSDK = downloadCacheStorageSDK; /***/ }), /* 252 */, -/* 253 */ -/***/ (function(module, __unusedexports, __webpack_require__) { - -"use strict"; - - -var gitUp = __webpack_require__(45); - -/** - * gitUrlParse - * Parses a Git url. - * - * @name gitUrlParse - * @function - * @param {String} url The Git url to parse. - * @return {GitUrl} The `GitUrl` object containing: - * - * - `protocols` (Array): An array with the url protocols (usually it has one element). - * - `port` (null|Number): The domain port. - * - `resource` (String): The url domain (including subdomains). - * - `user` (String): The authentication user (usually for ssh urls). - * - `pathname` (String): The url pathname. - * - `hash` (String): The url hash. - * - `search` (String): The url querystring value. - * - `href` (String): The input url. - * - `protocol` (String): The git url protocol. - * - `token` (String): The oauth token (could appear in the https urls). - * - `source` (String): The Git provider (e.g. `"github.com"`). - * - `owner` (String): The repository owner. - * - `name` (String): The repository name. - * - `ref` (String): The repository ref (e.g., "master" or "dev"). - * - `filepath` (String): A filepath relative to the repository root. - * - `filepathtype` (String): The type of filepath in the url ("blob" or "tree"). - * - `full_name` (String): The owner and name values in the `owner/name` format. - * - `toString` (Function): A function to stringify the parsed url into another url type. - * - `organization` (String): The organization the owner belongs to. This is CloudForge specific. - * - `git_suffix` (Boolean): Whether to add the `.git` suffix or not. - * - */ -function gitUrlParse(url) { - - if (typeof url !== "string") { - throw new Error("The url must be a string."); - } - - var urlInfo = gitUp(url), - sourceParts = urlInfo.resource.split("."), - splits = null; - - urlInfo.toString = function (type) { - return gitUrlParse.stringify(this, type); - }; - - urlInfo.source = sourceParts.length > 2 ? sourceParts.slice(1 - sourceParts.length).join(".") : urlInfo.source = urlInfo.resource; - - // Note: Some hosting services (e.g. Visual Studio Team Services) allow whitespace characters - // in the repository and owner names so we decode the URL pieces to get the correct result - urlInfo.git_suffix = /\.git$/.test(urlInfo.pathname); - urlInfo.name = decodeURIComponent(urlInfo.pathname.replace(/^\//, '').replace(/\.git$/, "")); - urlInfo.owner = decodeURIComponent(urlInfo.user); - - switch (urlInfo.source) { - case "git.cloudforge.com": - urlInfo.owner = urlInfo.user; - urlInfo.organization = sourceParts[0]; - urlInfo.source = "cloudforge.com"; - break; - case "visualstudio.com": - // Handle VSTS SSH URLs - if (urlInfo.resource === 'vs-ssh.visualstudio.com') { - splits = urlInfo.name.split("/"); - if (splits.length === 4) { - urlInfo.organization = splits[1]; - urlInfo.owner = splits[2]; - urlInfo.name = splits[3]; - urlInfo.full_name = splits[2] + '/' + splits[3]; - } - break; - } else { - splits = urlInfo.name.split("/"); - if (splits.length === 2) { - urlInfo.owner = splits[1]; - urlInfo.name = splits[1]; - urlInfo.full_name = '_git/' + urlInfo.name; - } else if (splits.length === 3) { - urlInfo.name = splits[2]; - if (splits[0] === 'DefaultCollection') { - urlInfo.owner = splits[2]; - urlInfo.organization = splits[0]; - urlInfo.full_name = urlInfo.organization + '/_git/' + urlInfo.name; - } else { - urlInfo.owner = splits[0]; - urlInfo.full_name = urlInfo.owner + '/_git/' + urlInfo.name; - } - } else if (splits.length === 4) { - urlInfo.organization = splits[0]; - urlInfo.owner = splits[1]; - urlInfo.name = splits[3]; - urlInfo.full_name = urlInfo.organization + '/' + urlInfo.owner + '/_git/' + urlInfo.name; - } - break; - } - - // Azure DevOps (formerly Visual Studio Team Services) - case "dev.azure.com": - case "azure.com": - if (urlInfo.resource === 'ssh.dev.azure.com') { - splits = urlInfo.name.split("/"); - if (splits.length === 4) { - urlInfo.organization = splits[1]; - urlInfo.owner = splits[2]; - urlInfo.name = splits[3]; - } - break; - } else { - splits = urlInfo.name.split("/"); - if (splits.length === 5) { - urlInfo.organization = splits[0]; - urlInfo.owner = splits[1]; - urlInfo.name = splits[4]; - urlInfo.full_name = '_git/' + urlInfo.name; - } else if (splits.length === 3) { - urlInfo.name = splits[2]; - if (splits[0] === 'DefaultCollection') { - urlInfo.owner = splits[2]; - urlInfo.organization = splits[0]; - urlInfo.full_name = urlInfo.organization + '/_git/' + urlInfo.name; - } else { - urlInfo.owner = splits[0]; - urlInfo.full_name = urlInfo.owner + '/_git/' + urlInfo.name; - } - } else if (splits.length === 4) { - urlInfo.organization = splits[0]; - urlInfo.owner = splits[1]; - urlInfo.name = splits[3]; - urlInfo.full_name = urlInfo.organization + '/' + urlInfo.owner + '/_git/' + urlInfo.name; - } - break; - } - default: - splits = urlInfo.name.split("/"); - var nameIndex = splits.length - 1; - if (splits.length >= 2) { - var blobIndex = splits.indexOf("blob", 2); - var treeIndex = splits.indexOf("tree", 2); - var commitIndex = splits.indexOf("commit", 2); - nameIndex = blobIndex > 0 ? blobIndex - 1 : treeIndex > 0 ? treeIndex - 1 : commitIndex > 0 ? commitIndex - 1 : nameIndex; - - urlInfo.owner = splits.slice(0, nameIndex).join('/'); - urlInfo.name = splits[nameIndex]; - if (commitIndex) { - urlInfo.commit = splits[nameIndex + 2]; - } - } - - urlInfo.ref = ""; - urlInfo.filepathtype = ""; - urlInfo.filepath = ""; - if (splits.length > nameIndex + 2 && ["blob", "tree"].indexOf(splits[nameIndex + 1]) >= 0) { - urlInfo.filepathtype = splits[nameIndex + 1]; - urlInfo.ref = splits[nameIndex + 2]; - if (splits.length > nameIndex + 3) { - urlInfo.filepath = splits.slice(nameIndex + 3).join('/'); - } - } - urlInfo.organization = urlInfo.owner; - break; - } - - if (!urlInfo.full_name) { - urlInfo.full_name = urlInfo.owner; - if (urlInfo.name) { - urlInfo.full_name && (urlInfo.full_name += "/"); - urlInfo.full_name += urlInfo.name; - } - } - - return urlInfo; -} - -/** - * stringify - * Stringifies a `GitUrl` object. - * - * @name stringify - * @function - * @param {GitUrl} obj The parsed Git url object. - * @param {String} type The type of the stringified url (default `obj.protocol`). - * @return {String} The stringified url. - */ -gitUrlParse.stringify = function (obj, type) { - type = type || (obj.protocols && obj.protocols.length ? obj.protocols.join('+') : obj.protocol); - var port = obj.port ? ":" + obj.port : ''; - var user = obj.user || 'git'; - var maybeGitSuffix = obj.git_suffix ? ".git" : ""; - switch (type) { - case "ssh": - if (port) return "ssh://" + user + "@" + obj.resource + port + "/" + obj.full_name + maybeGitSuffix;else return user + "@" + obj.resource + ":" + obj.full_name + maybeGitSuffix; - case "git+ssh": - case "ssh+git": - case "ftp": - case "ftps": - return type + "://" + user + "@" + obj.resource + port + "/" + obj.full_name + maybeGitSuffix; - case "http": - case "https": - var auth = obj.token ? buildToken(obj) : obj.user && (obj.protocols.includes('http') || obj.protocols.includes('https')) ? obj.user + "@" : ""; - return type + "://" + auth + obj.resource + port + "/" + obj.full_name + maybeGitSuffix; - default: - return obj.href; - } -}; - -/*! - * buildToken - * Builds OAuth token prefix (helper function) - * - * @name buildToken - * @function - * @param {GitUrl} obj The parsed Git url object. - * @return {String} token prefix - */ -function buildToken(obj) { - switch (obj.source) { - case "bitbucket.org": - return "x-token-auth:" + obj.token + "@"; - default: - return obj.token + "@"; - } -} - -module.exports = gitUrlParse; - -/***/ }), +/* 253 */, /* 254 */, /* 255 */, /* 256 */ @@ -34836,7 +34438,7 @@ function __export(m) { } Object.defineProperty(exports, "__esModule", { value: true }); __export(__webpack_require__(560)); -__export(__webpack_require__(599)); +__export(__webpack_require__(53)); //# sourceMappingURL=index.js.map /***/ }), @@ -35304,17 +34906,13 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; -var __importDefault = (this && this.__importDefault) || function (mod) { - return (mod && mod.__esModule) ? mod : { "default": mod }; -}; Object.defineProperty(exports, "__esModule", { value: true }); exports.asyncForEach = exports.getInputList = exports.getArgs = exports.getInputs = void 0; -const git_url_parse_1 = __importDefault(__webpack_require__(253)); const core = __importStar(__webpack_require__(470)); function getInputs() { return __awaiter(this, void 0, void 0, function* () { return { - context: yield getBuildContext(), + context: core.getInput('context') || '.', file: core.getInput('file') || './Dockerfile', buildArgs: yield getInputList('build-args'), labels: yield getInputList('labels'), @@ -35330,10 +34928,7 @@ function getInputs() { outputs: yield getInputList('outputs'), cacheFrom: yield getInputList('cache-from'), cacheTo: yield getInputList('cache-to'), - cacheGithub: /true/i.test(core.getInput('cache-github')), - bake: /true/i.test(core.getInput('bake')), - bakeFiles: yield getInputList('bake-files'), - bakeTargets: yield getInputList('bake-targets') + cacheGithub: /true/i.test(core.getInput('cache-github')) }; }); } @@ -35341,42 +34936,13 @@ exports.getInputs = getInputs; function getArgs(inputs) { return __awaiter(this, void 0, void 0, function* () { let args = ['buildx']; - if (inputs.bake) { - args.push.apply(args, yield getBakeArgs(inputs)); - } - else { - args.push.apply(args, yield getBuildArgs(inputs)); - } + args.push.apply(args, yield getBuildArgs(inputs)); args.push.apply(args, yield getCommonArgs(inputs)); - if (!inputs.bake) { - args.push(inputs.context); - } - else { - args.push.apply(args, inputs.bakeTargets); - } + args.push(inputs.context); return args; }); } exports.getArgs = getArgs; -function getBuildContext() { - return __awaiter(this, void 0, void 0, function* () { - let context = core.getInput('context'); - if (!context) { - return '.'; - } - try { - const gitUrl = git_url_parse_1.default(context); - const gitRef = process.env['GIT_REF'] || ''; - if (gitRef) { - return `${gitUrl.toString()}#${gitRef}`; - } - return gitUrl.toString(); - } - catch (_a) { - return context; - } - }); -} function getCommonArgs(inputs) { return __awaiter(this, void 0, void 0, function* () { let args = []; @@ -35395,15 +34961,6 @@ function getCommonArgs(inputs) { return args; }); } -function getBakeArgs(inputs) { - return __awaiter(this, void 0, void 0, function* () { - let args = ['bake']; - yield exports.asyncForEach(inputs.bakeFiles, (bakeFile) => __awaiter(this, void 0, void 0, function* () { - args.push('--file', bakeFile); - })); - return args; - }); -} function getBuildArgs(inputs) { return __awaiter(this, void 0, void 0, function* () { let args = ['build']; @@ -38477,49 +38034,7 @@ exports.partialMatch = partialMatch; /***/ }), /* 598 */, -/* 599 */ -/***/ (function(__unusedmodule, exports, __webpack_require__) { - -"use strict"; - -/*! - * Copyright 2019, OpenTelemetry Authors - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * https://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -Object.defineProperty(exports, "__esModule", { value: true }); -const context_1 = __webpack_require__(560); -class NoopContextManager { - active() { - return context_1.Context.ROOT_CONTEXT; - } - with(context, fn) { - return fn(); - } - bind(target, context) { - return target; - } - enable() { - return this; - } - disable() { - return this; - } -} -exports.NoopContextManager = NoopContextManager; -//# sourceMappingURL=NoopContextManager.js.map - -/***/ }), +/* 599 */, /* 600 */, /* 601 */ /***/ (function(__unusedmodule, exports, __webpack_require__) { @@ -41252,145 +40767,7 @@ exports.NOOP_METER_PROVIDER = new NoopMeterProvider(); /* 663 */, /* 664 */, /* 665 */, -/* 666 */ -/***/ (function(module, __unusedexports, __webpack_require__) { - -"use strict"; - - -// Dependencies -var protocols = __webpack_require__(737), - isSsh = __webpack_require__(720), - qs = __webpack_require__(191); - -/** - * parsePath - * Parses the input url. - * - * @name parsePath - * @function - * @param {String} url The input url. - * @return {Object} An object containing the following fields: - * - * - `protocols` (Array): An array with the url protocols (usually it has one element). - * - `protocol` (String): The first protocol, `"ssh"` (if the url is a ssh url) or `"file"`. - * - `port` (null|Number): The domain port. - * - `resource` (String): The url domain (including subdomains). - * - `user` (String): The authentication user (usually for ssh urls). - * - `pathname` (String): The url pathname. - * - `hash` (String): The url hash. - * - `search` (String): The url querystring value. - * - `href` (String): The input url. - * - `query` (Object): The url querystring, parsed as object. - */ -function parsePath(url) { - url = (url || "").trim(); - var output = { - protocols: protocols(url), - protocol: null, - port: null, - resource: "", - user: "", - pathname: "", - hash: "", - search: "", - href: url, - query: Object.create(null) - }, - protocolIndex = url.indexOf("://"), - resourceIndex = -1, - splits = null, - parts = null; - - if (url.startsWith(".")) { - if (url.startsWith("./")) { - url = url.substring(2); - } - output.pathname = url; - output.protocol = "file"; - } - - var firstChar = url.charAt(1); - if (!output.protocol) { - output.protocol = output.protocols[0]; - if (!output.protocol) { - if (isSsh(url)) { - output.protocol = "ssh"; - } else if (firstChar === "/" || firstChar === "~") { - url = url.substring(2); - output.protocol = "file"; - } else { - output.protocol = "file"; - } - } - } - - if (protocolIndex !== -1) { - url = url.substring(protocolIndex + 3); - } - - parts = url.split("/"); - if (output.protocol !== "file") { - output.resource = parts.shift(); - } else { - output.resource = ""; - } - - // user@domain - splits = output.resource.split("@"); - if (splits.length === 2) { - output.user = splits[0]; - output.resource = splits[1]; - } - - // domain.com:port - splits = output.resource.split(":"); - if (splits.length === 2) { - output.resource = splits[0]; - if (splits[1]) { - output.port = Number(splits[1]); - if (isNaN(output.port)) { - output.port = null; - parts.unshift(splits[1]); - } - } else { - output.port = null; - } - } - - // Remove empty elements - parts = parts.filter(Boolean); - - // Stringify the pathname - if (output.protocol === "file") { - output.pathname = output.href; - } else { - output.pathname = output.pathname || (output.protocol !== "file" || output.href[0] === "/" ? "/" : "") + parts.join("/"); - } - - // #some-hash - splits = output.pathname.split("#"); - if (splits.length === 2) { - output.pathname = splits[0]; - output.hash = splits[1]; - } - - // ?foo=bar - splits = output.pathname.split("?"); - if (splits.length === 2) { - output.pathname = splits[0]; - output.search = splits[1]; - } - - output.query = qs.parse(output.search); - output.href = output.href.replace(/\/$/, ""); - output.pathname = output.pathname.replace(/\/$/, ""); - return output; -} - -module.exports = parsePath; - -/***/ }), +/* 666 */, /* 667 */, /* 668 */, /* 669 */ @@ -42035,47 +41412,7 @@ for (var i = 0; i < modules.length; i++) { /* 717 */, /* 718 */, /* 719 */, -/* 720 */ -/***/ (function(module, __unusedexports, __webpack_require__) { - -"use strict"; - - -// Dependencies -var protocols = __webpack_require__(737); - -/** - * isSsh - * Checks if an input value is a ssh url or not. - * - * @name isSsh - * @function - * @param {String|Array} input The input url or an array of protocols. - * @return {Boolean} `true` if the input is a ssh url, `false` otherwise. - */ -function isSsh(input) { - - if (Array.isArray(input)) { - return input.indexOf("ssh") !== -1 || input.indexOf("rsync") !== -1; - } - - if (typeof input !== "string") { - return false; - } - - var prots = protocols(input); - input = input.substring(input.indexOf("://") + 3); - if (isSsh(prots)) { - return true; - } - - // TODO This probably could be improved :) - return input.indexOf("@") < input.indexOf(":"); -} - -module.exports = isSsh; - -/***/ }), +/* 720 */, /* 721 */, /* 722 */ /***/ (function(module) { @@ -42450,39 +41787,7 @@ function rng() { /***/ }), /* 736 */, -/* 737 */ -/***/ (function(module) { - -"use strict"; - - -/** - * protocols - * Returns the protocols of an input url. - * - * @name protocols - * @function - * @param {String} input The input url. - * @param {Boolean|Number} first If `true`, the first protocol will be returned. If number, it will represent the zero-based index of the protocols array. - * @return {Array|String} The array of protocols or the specified protocol. - */ -module.exports = function protocols(input, first) { - - if (first === true) { - first = 0; - } - - var index = input.indexOf("://"), - splits = input.substring(0, index).split("+").filter(Boolean); - - if (typeof first === "number") { - return splits[first]; - } - - return splits; -}; - -/***/ }), +/* 737 */, /* 738 */ /***/ (function(module, __unusedexports, __webpack_require__) { @@ -44683,67 +43988,7 @@ module.exports = { /***/ }), /* 821 */, /* 822 */, -/* 823 */ -/***/ (function(module, __unusedexports, __webpack_require__) { - -"use strict"; - - -var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; - -var parsePath = __webpack_require__(666), - normalizeUrl = __webpack_require__(53); - -/** - * parseUrl - * Parses the input url. - * - * **Note**: This *throws* if invalid urls are provided. - * - * @name parseUrl - * @function - * @param {String} url The input url. - * @param {Boolean|Object} normalize Wheter to normalize the url or not. - * Default is `false`. If `true`, the url will - * be normalized. If an object, it will be the - * options object sent to [`normalize-url`](https://github.com/sindresorhus/normalize-url). - * - * For SSH urls, normalize won't work. - * - * @return {Object} An object containing the following fields: - * - * - `protocols` (Array): An array with the url protocols (usually it has one element). - * - `protocol` (String): The first protocol, `"ssh"` (if the url is a ssh url) or `"file"`. - * - `port` (null|Number): The domain port. - * - `resource` (String): The url domain (including subdomains). - * - `user` (String): The authentication user (usually for ssh urls). - * - `pathname` (String): The url pathname. - * - `hash` (String): The url hash. - * - `search` (String): The url querystring value. - * - `href` (String): The input url. - * - `query` (Object): The url querystring, parsed as object. - */ -function parseUrl(url) { - var normalize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - - if (typeof url !== "string" || !url.trim()) { - throw new Error("Invalid url."); - } - if (normalize) { - if ((typeof normalize === "undefined" ? "undefined" : _typeof(normalize)) !== "object") { - normalize = { - stripFragment: false - }; - } - url = normalizeUrl(url, normalize); - } - var parsed = parsePath(url); - return parsed; -} - -module.exports = parseUrl; - -/***/ }), +/* 823 */, /* 824 */ /***/ (function(__unusedmodule, exports, __webpack_require__) { @@ -44787,7 +44032,7 @@ const core = __importStar(__webpack_require__(470)); const cachePath = path.join(os.tmpdir(), 'docker-build-push'); function restoreCache(inputs) { return __awaiter(this, void 0, void 0, function* () { - if (inputs.bake || !inputs.cacheGithub) { + if (!inputs.cacheGithub) { return inputs; } const primaryKey = `${process.env.RUNNER_OS}-docker-build-push-${process.env.GITHUB_SHA}`; @@ -44819,7 +44064,7 @@ function restoreCache(inputs) { exports.restoreCache = restoreCache; function saveCache(inputs) { return __awaiter(this, void 0, void 0, function* () { - if (inputs.bake || !inputs.cacheGithub) { + if (!inputs.cacheGithub) { return; } if (!stateHelper.cachePrimaryKey) { diff --git a/src/context.ts b/src/context.ts index 52c0d74..a185314 100644 --- a/src/context.ts +++ b/src/context.ts @@ -18,9 +18,6 @@ export interface Inputs { cacheFrom: string[]; cacheTo: string[]; cacheGithub: boolean; - bake: boolean; - bakeFiles: string[]; - bakeTargets: string[]; } export async function getInputs(): Promise<Inputs> { @@ -41,29 +38,15 @@ export async function getInputs(): Promise<Inputs> { outputs: await getInputList('outputs'), cacheFrom: await getInputList('cache-from'), cacheTo: await getInputList('cache-to'), - cacheGithub: /true/i.test(core.getInput('cache-github')), - bake: /true/i.test(core.getInput('bake')), - bakeFiles: await getInputList('bake-files'), - bakeTargets: await getInputList('bake-targets') + cacheGithub: /true/i.test(core.getInput('cache-github')) }; } export async function getArgs(inputs: Inputs): Promise<Array<string>> { let args: Array<string> = ['buildx']; - - if (inputs.bake) { - args.push.apply(args, await getBakeArgs(inputs)); - } else { - args.push.apply(args, await getBuildArgs(inputs)); - } + args.push.apply(args, await getBuildArgs(inputs)); args.push.apply(args, await getCommonArgs(inputs)); - - if (!inputs.bake) { - args.push(inputs.context); - } else { - args.push.apply(args, inputs.bakeTargets); - } - + args.push(inputs.context); return args; } @@ -84,14 +67,6 @@ async function getCommonArgs(inputs: Inputs): Promise<Array<string>> { return args; } -async function getBakeArgs(inputs: Inputs): Promise<Array<string>> { - let args: Array<string> = ['bake']; - await asyncForEach(inputs.bakeFiles, async bakeFile => { - args.push('--file', bakeFile); - }); - return args; -} - async function getBuildArgs(inputs: Inputs): Promise<Array<string>> { let args: Array<string> = ['build']; await asyncForEach(inputs.buildArgs, async buildArg => { diff --git a/src/github.ts b/src/github.ts index 044b788..9a3275c 100644 --- a/src/github.ts +++ b/src/github.ts @@ -8,7 +8,7 @@ import * as core from '@actions/core'; const cachePath = path.join(os.tmpdir(), 'docker-build-push'); export async function restoreCache(inputs: Inputs): Promise<Inputs> { - if (inputs.bake || !inputs.cacheGithub) { + if (!inputs.cacheGithub) { return inputs; } @@ -40,7 +40,7 @@ export async function restoreCache(inputs: Inputs): Promise<Inputs> { } export async function saveCache(inputs: Inputs): Promise<void> { - if (inputs.bake || !inputs.cacheGithub) { + if (!inputs.cacheGithub) { return; } diff --git a/src/md5.d.ts b/src/md5.d.ts deleted file mode 100644 index a455fd2..0000000 --- a/src/md5.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -declare module 'md5' { - function md5(data: string, options?: {encoding: string; asBytes: boolean; asString: boolean}): string; - export = md5; -} diff --git a/test/Dockerfile-bake b/test/Dockerfile-bake deleted file mode 100644 index 8153110..0000000 --- a/test/Dockerfile-bake +++ /dev/null @@ -1,4 +0,0 @@ -FROM alpine - -ARG name=world -RUN echo "Hello ${name}!" diff --git a/test/config.hcl b/test/config.hcl deleted file mode 100644 index 2ee66e5..0000000 --- a/test/config.hcl +++ /dev/null @@ -1,39 +0,0 @@ -group "default" { - targets = ["db", "app"] -} - -group "release" { - targets = ["db", "app-plus"] -} - -target "db" { - context = "./test" - tags = ["docker.io/tonistiigi/db"] -} - -target "app" { - context = "./test" - dockerfile = "Dockerfile-bake" - args = { - name = "foo" - } - tags = [ - "localhost:5000/name/app:latest", - "localhost:5000/name/app:1.0.0" - ] -} - -target "cross" { - platforms = [ - "linux/amd64", - "linux/arm64", - "linux/386" - ] -} - -target "app-plus" { - inherits = ["app", "cross"] - args = { - IAMPLUS = "true" - } -}