Compare commits

...

12 Commits

Author SHA1 Message Date
Foysal Iqbal
e5024b7f0a fix make file to have proper version 2019-12-20 11:58:28 -05:00
Foysal Iqbal
d408d33971 fix master 2019-12-20 11:01:01 -05:00
Foysal Iqbal
cff29ed862 always build from porter master 2019-12-20 10:36:36 -05:00
Boris Kuschel
e5108e0040 remove kruft
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-19 13:47:45 -05:00
Boris Kuschel
0372b82b49 Fix install command
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-19 13:41:43 -05:00
Foysal Iqbal
48ca84f5f8 fix tag issue for about action 2019-12-19 12:29:32 -05:00
Boris Kuschel
97a137ff23 Fix file perms
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-19 11:14:06 -05:00
Boris Kuschel
776c91d300 Add correct perms for unix
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-19 09:57:55 -05:00
Boris Kuschel
c37f5338dc Fix mixin parameter
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-19 07:22:20 -05:00
Boris Kuschel
0cf8a9b4c9 Add version infor
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-19 06:35:35 -05:00
Boris Kuschel
75fcb93c33 Download version of Porter
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-19 06:30:14 -05:00
Boris Kuschel
465095e4ee Use porter on cli releases page
Signed-off-by: Boris Kuschel <boris.kuschel@qlik.com>
2019-12-18 21:14:51 -05:00
9 changed files with 1314 additions and 26 deletions

View File

@@ -17,12 +17,23 @@ jobs:
steps:
- checkout
- run: make xbuild-all
- run:
name: "Build latest master from porter repo"
command: |
export GO111MODULE=off
go get -u get.porter.sh/porter || true
cd /go/src/get.porter.sh/porter
# store porter master commit
git rev-parse HEAD > /go/porter-master-commit.txt
make xbuild-all VERSION=latest
cp -r bin/latest/* /go/src/github.com/${CIRCLE_PROJECT_USERNAME}/${CIRCLE_PROJECT_REPONAME}/bin/${CIRCLE_TAG}/
- run:
name: "Publish Release on GitHub"
command: |
go get github.com/tcnksm/ghr
# VERSION=v$(./artifacts/qliksense-linux-amd64 version | sed -nre 's/^[^0-9]*(([0-9]+\.)*[0-9]+).*/\1/p')
ghr -t ${GITHUB_TOKEN} -u ${CIRCLE_PROJECT_USERNAME} -r ${CIRCLE_PROJECT_REPONAME} -c ${CIRCLE_SHA1} -delete ${CIRCLE_TAG} /go/src/github.com/${CIRCLE_PROJECT_USERNAME}/${CIRCLE_PROJECT_REPONAME}/bin/${CIRCLE_TAG}/
PORTER_REPO_COMMIT=$(cat /go/porter-master-commit.txt)
ghr -t ${GITHUB_TOKEN} -u ${CIRCLE_PROJECT_USERNAME} -r ${CIRCLE_PROJECT_REPONAME} -c ${CIRCLE_SHA1} -b "porter build based on commit: https://github.com/deislabs/porter/commit/${PORTER_REPO_COMMIT}" -delete ${CIRCLE_TAG} /go/src/github.com/${CIRCLE_PROJECT_USERNAME}/${CIRCLE_PROJECT_REPONAME}/bin/${CIRCLE_TAG}/
workflows:
version: 2
commit:

628
.qliksense/porter-runtime Normal file

File diff suppressed because one or more lines are too long

628
.qliksense/porter.exe Normal file

File diff suppressed because one or more lines are too long

View File

@@ -1,4 +1,4 @@
PKG = qlik-oss/sense-installer
PKG = github.com/qlik-oss/sense-installer
# --no-print-directory avoids verbose logging when invoking targets that utilize sub-makes
MAKE_OPTS ?= --no-print-directory

View File

@@ -7,9 +7,9 @@ The Qlik Sense installations and operations CLI provides capabilities for instal
Download the appropriate executable for your platform from the [releases page](https://github.com/qlik-oss/sense-installer/releases). When used, the CLI will check to see if porter is installed, if not, will download and install it. Once done, you can find porter through `echo $HOME/.porter` on Linux and MacOS and in `$Env:USERPROFILE\.porter` on Windows. You can also install it in advance, release > 0.22.1-beta.1 is required.
To make sure everything is order, you can fetch the Qlik Sense bundle version and corresponding image list from:
- `qliksense about -tag qlik/qliksense-cnab-bundle:latest `
- `qliksense about --tag qlik/qliksense-cnab-bundle:latest `
## Qliksense Packaging
Packaging of Qlik Sense on Kubernetes is done through a [Porter](https://porter.sh/) definition in the [Qlik Sense on Kubernetes configuration repository](https://github.com/qlik-oss/qliksense-k8s/blob/master/porter.yaml), the resulting bundle publisked on DockerHub as a [Cloud Natvie Application Bundle](https://cnab.io/) called [qliksense-cnab-bundle](https://hub.docker.com/r/qlik/qliksense-cnab-bundle).
Packaging of Qlik Sense on Kubernetes is done through a [Porter](https://porter.sh/) definition in the [Qlik Sense on Kubernetes configuration repository](https://github.com/qlik-oss/qliksense-k8s/blob/master/porter.yaml), the resulting bundle published on DockerHub as a [Cloud Natvie Application Bundle](https://cnab.io/) called [qliksense-cnab-bundle](https://hub.docker.com/r/qlik/qliksense-cnab-bundle).
### Versioning
A version of [qliksense-cnab-bundle](https://hub.docker.com/r/qlik/qliksense-cnab-bundle) is published corresponding to an edge release. To get the latest edge release simply specify `qliksense-cnab-bundle:latest`

View File

@@ -83,7 +83,7 @@ For example, the 'debug' driver may be specified, which simply logs the info giv
RunE: func(cmd *cobra.Command, args []string) error {
// Push images here.
// TODO: Need to get the private reg from params
args = opts.getTagDefaults(args)
args = append(os.Args[1:], opts.getTagDefaults(args)...)
if registry = opts.findKey("dockerRegistry"); registry != nil {
if len(*registry) > 0 {
q.TagAndPushImages(*registry)
@@ -122,6 +122,9 @@ For example, the 'debug' driver may be specified, which simply logs the info giv
}
func (o *aboutOptions) getTagDefaults(args []string) []string {
var err error
if len(o.Tag) > 1 {
args = append(args, []string{"--tag", o.Tag}...)
}
if len(o.Tag) <= 0 && len(o.File) <= 0 && len(o.CNABFile) <= 0 {
if _, err = os.Stat("porter.yaml"); err != nil {
args = append(args, []string{"--tag", "qlik/qliksense-cnab-bundle:" + o.Version}...)

View File

@@ -1,7 +1,5 @@
package main
func main() {
initAndExecute()
}

View File

@@ -11,18 +11,20 @@ import (
"strings"
"github.com/mitchellh/go-homedir"
"github.com/qlik-oss/sense-installer/pkg"
"github.com/qlik-oss/sense-installer/pkg/qliksense"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
const (
porterURLBase = "https://deislabs.blob.core.windows.net/porter"
porterHomeVar = "PORTER_HOME"
porterDirVar = ".porter"
mixinDirVar = "mixins"
porterPermaLink = "latest"
porterRuntime = "porter-runtime"
// porterURLBase = "https://deislabs.blob.core.windows.net/porter"
porterURLBase = "https://github.com/qlik-oss/sense-installer/releases/download"
porterHomeVar = "PORTER_HOME"
qlikSenseHomeVar = "QLIKSENSE_HOME"
qlikSenseDirVar = ".qliksense"
mixinDirVar = "mixins"
porterRuntime = "porter-runtime"
)
func initAndExecute() error {
@@ -42,8 +44,10 @@ func initAndExecute() error {
func installPorter() (string, error) {
var (
homeDir, mixin, mixinOpts, porterHome, porterExe string
mixinsVar = map[string]string{
porterPermaLink = pkg.Version
//porterPermaLink = "v0.3.0"
destination, homeDir, mixin, mixinOpts, qlikSenseHome, porterExe, ext string
mixinsVar = map[string]string{
"kustomize": "-v 0.2-beta-3-0e19ca4 --url https://github.com/donmstewart/porter-kustomize/releases/download",
"qliksense": "-v v0.11.0 --url https://github.com/qlik-oss/porter-qliksense/releases/download",
"exec": "-v latest",
@@ -64,17 +68,19 @@ func installPorter() (string, error) {
if runtime.GOOS == "windows" {
porterExe = porterExe + ".exe"
}
if porterHome = os.Getenv(porterHomeVar); porterHome == "" {
if qlikSenseHome = os.Getenv(qlikSenseHomeVar); qlikSenseHome == "" {
if homeDir, err = homedir.Dir(); err != nil {
return "", err
}
if homeDir, err = homedir.Expand(homeDir); err != nil {
return "", err
}
porterHome = filepath.Join(homeDir, porterDirVar)
qlikSenseHome = filepath.Join(homeDir, qlikSenseDirVar)
}
porterExe = filepath.Join(porterHome, porterExe)
if _, err = os.Stat(porterHome); err != nil {
os.Setenv(porterHomeVar, qlikSenseHome)
//TODO: Check if porter version is one alreadu is one for this build
porterExe = filepath.Join(qlikSenseHome, porterExe)
if _, err = os.Stat(qlikSenseHome); err != nil {
if os.IsNotExist(err) {
downloadPorter = true
} else {
@@ -90,22 +96,29 @@ func installPorter() (string, error) {
}
}
if downloadPorter {
os.Mkdir(porterHome, os.ModePerm)
if err = downloadFile(porterURLBase+"/"+porterPermaLink+"/porter-linux-amd64", filepath.Join(porterHome, porterRuntime)); err != nil {
os.Mkdir(qlikSenseHome, os.ModePerm)
destination = filepath.Join(qlikSenseHome, porterRuntime)
if err = downloadFile(porterURLBase+"/"+porterPermaLink+"/porter-linux-amd64", destination); err != nil {
return "", err
}
os.Chmod(destination, 0755)
if runtime.GOOS == "linux" && runtime.GOARCH == "amd64" {
if _, err = copy(filepath.Join(porterHome, porterRuntime), porterExe); err != nil {
if _, err = copy(filepath.Join(qlikSenseHome, porterRuntime), porterExe); err != nil {
return "", err
}
os.Chmod(porterExe, 0755)
} else {
if err = downloadFile(porterURLBase+"/"+porterPermaLink+"/"+"porter-"+runtime.GOOS+"-"+runtime.GOARCH, porterExe); err != nil {
if runtime.GOOS == "windows" {
ext = ".exe"
}
if err = downloadFile(porterURLBase+"/"+porterPermaLink+"/"+"porter-"+runtime.GOOS+"-"+runtime.GOARCH+ext, porterExe); err != nil {
return "", err
}
os.Chmod(porterExe, 0755)
}
}
if _, err = os.Stat(filepath.Join(porterHome, mixinDirVar)); err != nil {
if _, err = os.Stat(filepath.Join(qlikSenseHome, mixinDirVar)); err != nil {
if os.IsNotExist(err) {
downloadMixins = mixinsVar
} else {
@@ -114,7 +127,7 @@ func installPorter() (string, error) {
} else {
downloadMixins = make(map[string]string)
for mixin, mixinOpts = range mixinsVar {
if _, err = os.Stat(filepath.Join(porterHome, mixinDirVar, mixin)); err != nil {
if _, err = os.Stat(filepath.Join(qlikSenseHome, mixinDirVar, mixin)); err != nil {
if os.IsNotExist(err) {
downloadMixins[mixin] = mixinOpts
} else {
@@ -124,7 +137,7 @@ func installPorter() (string, error) {
}
}
for mixin, mixinOpts = range downloadMixins {
cmd = exec.Command(porterExe, "mixin", "install", mixin, mixinOpts)
cmd = exec.Command(porterExe, append([]string{"mixin", "install", mixin}, strings.Split(mixinOpts, " ")...)...)
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err = cmd.Run(); err != nil {

7
pkg/version.go Normal file
View File

@@ -0,0 +1,7 @@
package pkg
// These are build-time values, set during an official release
var (
Commit string
Version string
)