mirror of
https://github.com/cnrancher/kube-explorer.git
synced 2025-09-02 23:17:41 +00:00
Compare commits
8 Commits
release/v0
...
v0.4.2
Author | SHA1 | Date | |
---|---|---|---|
|
18027bbaeb | ||
|
99c03af96e | ||
|
618cd9abfb | ||
|
9c5a29c9cc | ||
|
2c0afb3776 | ||
|
ca5f23170f | ||
|
24a7324f92 | ||
|
71ad854ab1 |
2
.github/workflows/pr.yaml
vendored
2
.github/workflows/pr.yaml
vendored
@@ -16,6 +16,4 @@ jobs:
|
|||||||
- name: Commitsar check
|
- name: Commitsar check
|
||||||
uses: aevea/commitsar@v0.20.2
|
uses: aevea/commitsar@v0.20.2
|
||||||
- name: Build to test
|
- name: Build to test
|
||||||
env:
|
|
||||||
SKIP_COMPRESS: "true"
|
|
||||||
run: make ci
|
run: make ci
|
||||||
|
92
.github/workflows/push.yaml
vendored
92
.github/workflows/push.yaml
vendored
@@ -4,8 +4,12 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
|
- "release/v*"
|
||||||
tags:
|
tags:
|
||||||
- 'v*.*.*' # Matches any tag that starts with 'v' and follows semantic versioning
|
- "v*.*.*" # Matches any tag that starts with 'v' and follows semantic versioning
|
||||||
|
|
||||||
|
env:
|
||||||
|
ALIYUN_REGISTRY: ${{ vars.ALIYUN_REGISTRY || '' }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-and-deploy:
|
build-and-deploy:
|
||||||
@@ -15,67 +19,73 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
- name: CI
|
||||||
|
env:
|
||||||
|
SKIP_PACKAGE: "true"
|
||||||
|
run: make ci
|
||||||
|
- name: Prepare for packaging image
|
||||||
|
run: cp dist/* package/
|
||||||
|
# aliyun image to test the docker build is ok
|
||||||
- name: Login to Aliyun ACR
|
- name: Login to Aliyun ACR
|
||||||
|
if: ${{ vars.ALIYUN_REGISTRY != '' }}
|
||||||
uses: docker/login-action@v3
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
registry: registry.cn-shenzhen.aliyuncs.com
|
registry: ${{ env.ALIYUN_REGISTRY }}
|
||||||
username: ${{ secrets.ACR_USERNAME }}
|
username: ${{ secrets.ACR_USERNAME }}
|
||||||
password: ${{ secrets.ACR_TOKEN }}
|
password: ${{ secrets.ACR_TOKEN }}
|
||||||
if: ${{ vars.ALIYUN == 'true' }}
|
- name: Aliyun image docker meta
|
||||||
|
if: ${{ vars.ALIYUN_REGISTRY != '' }}
|
||||||
|
id: aliyun-meta
|
||||||
|
uses: docker/metadata-action@v5
|
||||||
|
with:
|
||||||
|
images: ${{ env.ALIYUN_REGISTRY }}/${{ vars.REPO || 'cnrancher' }}/${{ vars.IMAGE || 'kube-explorer' }}
|
||||||
|
tags: |
|
||||||
|
type=ref,event=tag
|
||||||
|
type=ref,event=branch,suffix=-head
|
||||||
|
- name: Build to Aliyun
|
||||||
|
if: ${{ vars.ALIYUN_REGISTRY != '' }}
|
||||||
|
uses: docker/build-push-action@v6
|
||||||
|
with:
|
||||||
|
labels: ${{ steps.aliyun-meta.outputs.labels }}
|
||||||
|
tags: "${{ steps.aliyun-meta.outputs.tags }}"
|
||||||
|
context: package
|
||||||
|
push: true
|
||||||
|
|
||||||
|
# docker hub multi-arch image
|
||||||
- name: Login to Dockerhub
|
- name: Login to Dockerhub
|
||||||
uses: docker/login-action@v3
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
- name: CI
|
- name: Docker meta
|
||||||
if: startsWith(github.ref, 'refs/heads/')
|
id: meta
|
||||||
env:
|
uses: docker/metadata-action@v5
|
||||||
CROSS: push
|
with:
|
||||||
run: make github_ci
|
images: ${{ vars.REPO || 'cnrancher' }}/${{ vars.IMAGE || 'kube-explorer' }}
|
||||||
|
tags: |
|
||||||
- name: CI
|
type=ref,event=tag
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
type=ref,event=branch,suffix=-head
|
||||||
env:
|
- name: Set up QEMU
|
||||||
CROSS: tag
|
|
||||||
run: |
|
|
||||||
make github_ci
|
|
||||||
make release-note
|
|
||||||
|
|
||||||
- name: Prepare for packaging image
|
|
||||||
run: cp dist/* package/
|
|
||||||
- name: Set docker iamge name
|
|
||||||
id: image-name
|
|
||||||
env:
|
|
||||||
REPO_OVERRIDE: ${{ vars.REPO || 'cnrancher' }}
|
|
||||||
IMAGE_OVERRIDE: ${{ vars.IMAGE || 'kube-explorer' }}
|
|
||||||
run: |
|
|
||||||
tag_name=latest;
|
|
||||||
if [[ ${GITHUB_REF} == refs/tags/* ]]; then tag_name=${GITHUB_REF#refs/tags/}; fi;
|
|
||||||
echo "image_name=${REPO_OVERRIDE}/${IMAGE_OVERRIDE}:${tag_name}" >> $GITHUB_OUTPUT;
|
|
||||||
-
|
|
||||||
name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v3
|
uses: docker/setup-qemu-action@v3
|
||||||
-
|
- name: Set up Docker Buildx
|
||||||
name: Set up Docker Buildx
|
|
||||||
uses: docker/setup-buildx-action@v3
|
uses: docker/setup-buildx-action@v3
|
||||||
- name: Build to Dockerhub
|
- name: Build to Dockerhub
|
||||||
uses: docker/build-push-action@v6
|
uses: docker/build-push-action@v6
|
||||||
with:
|
with:
|
||||||
platforms: linux/amd64,linux/arm64/v8
|
platforms: linux/amd64,linux/arm64/v8
|
||||||
tags: "${{ steps.image-name.outputs.image_name }}"
|
labels: ${{ steps.meta.outputs.labels }}
|
||||||
|
tags: "${{ steps.meta.outputs.tags }}"
|
||||||
context: package
|
context: package
|
||||||
push: true
|
push: true
|
||||||
- name: Build to Aliyun
|
|
||||||
uses: docker/build-push-action@v6
|
- name: Make release note
|
||||||
with:
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
tags: registry.cn-shenzhen.aliyuncs.com/${{ steps.image-name.outputs.image_name }}
|
run: |
|
||||||
context: package
|
make release-note
|
||||||
push: true
|
|
||||||
if: ${{ vars.ALIYUN == 'true' }}
|
|
||||||
- name: Release
|
- name: Release
|
||||||
uses: softprops/action-gh-release@v2
|
uses: softprops/action-gh-release@v2
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
with:
|
with:
|
||||||
files: dist/kube-explorer-*
|
files: dist/kube-explorer-*
|
||||||
body_path: dist/release-note
|
body_path: dist/release-note
|
||||||
draft: true
|
draft: true
|
||||||
|
4
.gitignore
vendored
4
.gitignore
vendored
@@ -23,3 +23,7 @@
|
|||||||
/.vscode
|
/.vscode
|
||||||
/vendor
|
/vendor
|
||||||
/internal/ui/ui/
|
/internal/ui/ui/
|
||||||
|
**/Dockerfile.dapper*
|
||||||
|
!**/Dockerfile.dapper
|
||||||
|
|
||||||
|
dist/
|
||||||
|
75
.goreleaser.yaml
Normal file
75
.goreleaser.yaml
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
# This is an example .goreleaser.yml file with some sensible defaults.
|
||||||
|
# Make sure to check the documentation at https://goreleaser.com
|
||||||
|
|
||||||
|
# The lines below are called `modelines`. See `:help modeline`
|
||||||
|
# Feel free to remove those if you don't want/need to use them.
|
||||||
|
# yaml-language-server: $schema=https://goreleaser.com/static/schema.json
|
||||||
|
# vim: set ts=2 sw=2 tw=0 fo=cnqoj
|
||||||
|
|
||||||
|
version: 2
|
||||||
|
|
||||||
|
dist: bin
|
||||||
|
|
||||||
|
before:
|
||||||
|
hooks:
|
||||||
|
# You may remove this if you don't use go modules.
|
||||||
|
- go mod tidy
|
||||||
|
|
||||||
|
builds:
|
||||||
|
- id: prod
|
||||||
|
env:
|
||||||
|
- CGO_ENABLED=0
|
||||||
|
targets:
|
||||||
|
- "darwin_amd64"
|
||||||
|
- "darwin_arm64"
|
||||||
|
- "linux_amd64"
|
||||||
|
- "linux_arm64"
|
||||||
|
- "linux_arm"
|
||||||
|
- "windows_amd64"
|
||||||
|
flags:
|
||||||
|
- -tags=embed
|
||||||
|
binary: '{{ .ProjectName }}-{{ .Os }}-{{ .Arch }}'
|
||||||
|
ldflags: |
|
||||||
|
{{ if ne .Os "darwin" }}
|
||||||
|
-extldflags -static -s
|
||||||
|
{{ else }}
|
||||||
|
-s -w
|
||||||
|
{{ end }}
|
||||||
|
-X github.com/cnrancher/kube-explorer/internal/version.Version={{ .Env.VERSION }}
|
||||||
|
-X github.com/cnrancher/kube-explorer/internal/version.GitCommit={{ .Env.COMMIT }}
|
||||||
|
-X github.com/cnrancher/kube-explorer/internal/config.APIUIVersion={{ .Env.CATTLE_API_UI_VERSION }}
|
||||||
|
no_unique_dist_dir: true
|
||||||
|
- id: dev
|
||||||
|
env:
|
||||||
|
- CGO_ENABLED=0
|
||||||
|
targets:
|
||||||
|
- "linux_amd64"
|
||||||
|
- "linux_arm64"
|
||||||
|
flags:
|
||||||
|
- -tags=embed
|
||||||
|
binary: '{{ .ProjectName }}-{{ .Os }}-{{ .Arch }}'
|
||||||
|
ldflags: |
|
||||||
|
{{ if ne .Os "darwin" }}
|
||||||
|
-extldflags -static -s
|
||||||
|
{{ else }}
|
||||||
|
-s -w
|
||||||
|
{{ end }}
|
||||||
|
-X github.com/cnrancher/kube-explorer/internal/version.Version={{ .Env.VERSION }}
|
||||||
|
-X github.com/cnrancher/kube-explorer/internal/version.GitCommit={{ .Env.COMMIT }}
|
||||||
|
-X github.com/cnrancher/kube-explorer/internal/config.APIUIVersion={{ .Env.CATTLE_API_UI_VERSION }}
|
||||||
|
no_unique_dist_dir: true
|
||||||
|
upx:
|
||||||
|
- compress: "5"
|
||||||
|
ids:
|
||||||
|
- prod
|
||||||
|
enabled: true
|
||||||
|
goos:
|
||||||
|
- linux
|
||||||
|
- windows
|
||||||
|
|
||||||
|
changelog:
|
||||||
|
sort: asc
|
||||||
|
filters:
|
||||||
|
exclude:
|
||||||
|
- "^docs:"
|
||||||
|
- "^test:"
|
@@ -1,3 +1,4 @@
|
|||||||
|
FROM goreleaser/goreleaser:v2.3.2 as goreleaser
|
||||||
FROM aevea/release-notary:0.9.2 as tools
|
FROM aevea/release-notary:0.9.2 as tools
|
||||||
|
|
||||||
FROM registry.suse.com/bci/golang:1.22
|
FROM registry.suse.com/bci/golang:1.22
|
||||||
@@ -8,8 +9,7 @@ ENV HOST_ARCH=${DAPPER_HOST_ARCH} ARCH=${DAPPER_HOST_ARCH}
|
|||||||
ENV https_proxy=${PROXY} \
|
ENV https_proxy=${PROXY} \
|
||||||
http_proxy=${PROXY}
|
http_proxy=${PROXY}
|
||||||
|
|
||||||
RUN zypper -n install ca-certificates git-core wget curl unzip tar vim less file xz
|
RUN zypper -n install ca-certificates git-core wget curl unzip tar vim less file xz cosign docker
|
||||||
RUN zypper install -y -f docker
|
|
||||||
|
|
||||||
ENV UPX_VERSION 4.2.1
|
ENV UPX_VERSION 4.2.1
|
||||||
RUN curl -sL https://github.com/upx/upx/releases/download/v${UPX_VERSION}/upx-${UPX_VERSION}-${ARCH}_linux.tar.xz | tar xvJf - --strip-components=1 -C /tmp && \
|
RUN curl -sL https://github.com/upx/upx/releases/download/v${UPX_VERSION}/upx-${UPX_VERSION}-${ARCH}_linux.tar.xz | tar xvJf - --strip-components=1 -C /tmp && \
|
||||||
@@ -18,11 +18,12 @@ RUN curl -sL https://github.com/upx/upx/releases/download/v${UPX_VERSION}/upx-${
|
|||||||
RUN if [ "${ARCH}" == "amd64" ]; then \
|
RUN if [ "${ARCH}" == "amd64" ]; then \
|
||||||
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.54.2; \
|
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.54.2; \
|
||||||
fi
|
fi
|
||||||
|
COPY --from=goreleaser /usr/bin/goreleaser /usr/bin/goreleaser
|
||||||
COPY --from=tools /app/release-notary /usr/local/bin/
|
COPY --from=tools /app/release-notary /usr/local/bin/
|
||||||
ENV CATTLE_DASHBOARD_UI_VERSION="v2.8.0-kube-explorer-ui-rc3"
|
ENV CATTLE_DASHBOARD_UI_VERSION="v2.8.5-kube-explorer-ui-rc1"
|
||||||
ENV CATTLE_API_UI_VERSION="1.1.11"
|
ENV CATTLE_API_UI_VERSION="1.1.11"
|
||||||
|
|
||||||
ENV DAPPER_ENV REPO TAG DRONE_TAG CROSS GOPROXY SKIP_COMPRESS GITHUB_REPOSITORY GITHUB_TOKEN
|
ENV DAPPER_ENV REPO TAG DRONE_TAG CROSS GOPROXY GITHUB_TOKEN GITHUB_REF GITHUB_REF_NAME BUILD_TARGET SKIP_PACKAGE
|
||||||
ENV DAPPER_SOURCE /go/src/github.com/cnrancher/kube-explorer
|
ENV DAPPER_SOURCE /go/src/github.com/cnrancher/kube-explorer
|
||||||
ENV DAPPER_OUTPUT ./bin ./dist
|
ENV DAPPER_OUTPUT ./bin ./dist
|
||||||
ENV DAPPER_DOCKER_SOCKET true
|
ENV DAPPER_DOCKER_SOCKET true
|
||||||
|
31
go.mod
31
go.mod
@@ -2,13 +2,21 @@ module github.com/cnrancher/kube-explorer
|
|||||||
|
|
||||||
go 1.22.0
|
go 1.22.0
|
||||||
|
|
||||||
replace k8s.io/client-go => k8s.io/client-go v0.30.1
|
replace (
|
||||||
|
github.com/rancher/steve => github.com/rancher/steve v0.0.0-20240529152548-9fb3e50aa806
|
||||||
|
k8s.io/api => k8s.io/api v0.28.6
|
||||||
|
k8s.io/apiextensions-apiserver => k8s.io/apiextensions-apiserver v0.28.6
|
||||||
|
k8s.io/apimachinery => k8s.io/apimachinery v0.28.6
|
||||||
|
k8s.io/apiserver => k8s.io/apiserver v0.28.6
|
||||||
|
k8s.io/client-go => github.com/rancher/client-go v1.28.6-rancher1
|
||||||
|
|
||||||
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/gorilla/mux v1.8.1
|
github.com/gorilla/mux v1.8.1
|
||||||
github.com/rancher/apiserver v0.0.0-20240708202538-39a6f2535146
|
github.com/rancher/apiserver v0.0.0-20240207153744-69b3c2b56f3f
|
||||||
github.com/rancher/steve v0.0.0-20240709130809-47871606146c
|
github.com/rancher/steve v0.0.0-20240529152548-9fb3e50aa806
|
||||||
github.com/rancher/wrangler/v3 v3.0.0
|
github.com/rancher/wrangler/v2 v2.1.4
|
||||||
github.com/sirupsen/logrus v1.9.3
|
github.com/sirupsen/logrus v1.9.3
|
||||||
github.com/urfave/cli v1.22.15
|
github.com/urfave/cli v1.22.15
|
||||||
golang.org/x/text v0.14.0
|
golang.org/x/text v0.14.0
|
||||||
@@ -26,7 +34,6 @@ require (
|
|||||||
github.com/cespare/xxhash/v2 v2.2.0 // indirect
|
github.com/cespare/xxhash/v2 v2.2.0 // indirect
|
||||||
github.com/cpuguy83/go-md2man/v2 v2.0.4 // indirect
|
github.com/cpuguy83/go-md2man/v2 v2.0.4 // indirect
|
||||||
github.com/davecgh/go-spew v1.1.1 // indirect
|
github.com/davecgh/go-spew v1.1.1 // indirect
|
||||||
github.com/dustin/go-humanize v1.0.1 // indirect
|
|
||||||
github.com/emicklei/go-restful/v3 v3.11.0 // indirect
|
github.com/emicklei/go-restful/v3 v3.11.0 // indirect
|
||||||
github.com/evanphx/json-patch v5.6.0+incompatible // indirect
|
github.com/evanphx/json-patch v5.6.0+incompatible // indirect
|
||||||
github.com/felixge/httpsnoop v1.0.3 // indirect
|
github.com/felixge/httpsnoop v1.0.3 // indirect
|
||||||
@@ -41,33 +48,30 @@ require (
|
|||||||
github.com/google/gnostic-models v0.6.8 // indirect
|
github.com/google/gnostic-models v0.6.8 // indirect
|
||||||
github.com/google/go-cmp v0.6.0 // indirect
|
github.com/google/go-cmp v0.6.0 // indirect
|
||||||
github.com/google/gofuzz v1.2.0 // indirect
|
github.com/google/gofuzz v1.2.0 // indirect
|
||||||
|
github.com/google/pprof v0.0.0-20240409012703-83162a5b38cd // indirect
|
||||||
github.com/google/uuid v1.6.0 // indirect
|
github.com/google/uuid v1.6.0 // indirect
|
||||||
github.com/gorilla/websocket v1.5.1 // indirect
|
github.com/gorilla/websocket v1.5.1 // indirect
|
||||||
github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.0 // indirect
|
github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.0 // indirect
|
||||||
github.com/hashicorp/golang-lru/v2 v2.0.7 // indirect
|
|
||||||
github.com/imdario/mergo v0.3.12 // indirect
|
github.com/imdario/mergo v0.3.12 // indirect
|
||||||
github.com/josharian/intern v1.0.0 // indirect
|
github.com/josharian/intern v1.0.0 // indirect
|
||||||
github.com/json-iterator/go v1.1.12 // indirect
|
github.com/json-iterator/go v1.1.12 // indirect
|
||||||
github.com/mailru/easyjson v0.7.7 // indirect
|
github.com/mailru/easyjson v0.7.7 // indirect
|
||||||
github.com/mattn/go-isatty v0.0.20 // indirect
|
|
||||||
github.com/matttproud/golang_protobuf_extensions v1.0.4 // indirect
|
github.com/matttproud/golang_protobuf_extensions v1.0.4 // indirect
|
||||||
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
|
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
|
||||||
github.com/modern-go/reflect2 v1.0.2 // indirect
|
github.com/modern-go/reflect2 v1.0.2 // indirect
|
||||||
github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect
|
github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect
|
||||||
github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f // indirect
|
github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f // indirect
|
||||||
github.com/ncruces/go-strftime v0.1.9 // indirect
|
|
||||||
github.com/pborman/uuid v1.2.1 // indirect
|
github.com/pborman/uuid v1.2.1 // indirect
|
||||||
github.com/pkg/errors v0.9.1 // indirect
|
github.com/pkg/errors v0.9.1 // indirect
|
||||||
github.com/prometheus/client_golang v1.16.0 // indirect
|
github.com/prometheus/client_golang v1.16.0 // indirect
|
||||||
github.com/prometheus/client_model v0.4.0 // indirect
|
github.com/prometheus/client_model v0.4.0 // indirect
|
||||||
github.com/prometheus/common v0.44.0 // indirect
|
github.com/prometheus/common v0.44.0 // indirect
|
||||||
github.com/prometheus/procfs v0.10.1 // indirect
|
github.com/prometheus/procfs v0.10.1 // indirect
|
||||||
github.com/rancher/dynamiclistener v0.6.0-rc2 // indirect
|
github.com/rancher/dynamiclistener v0.4.0-rc2 // indirect
|
||||||
github.com/rancher/kubernetes-provider-detector v0.1.5 // indirect
|
github.com/rancher/kubernetes-provider-detector v0.1.5 // indirect
|
||||||
github.com/rancher/lasso v0.0.0-20240705194423-b2a060d103c1 // indirect
|
github.com/rancher/lasso v0.0.0-20240705194423-b2a060d103c1 // indirect
|
||||||
github.com/rancher/norman v0.0.0-20240708202514-a0127673d1b9 // indirect
|
github.com/rancher/norman v0.0.0-20240708202514-a0127673d1b9 // indirect
|
||||||
github.com/rancher/remotedialer v0.3.2 // indirect
|
github.com/rancher/remotedialer v0.3.2 // indirect
|
||||||
github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec // indirect
|
|
||||||
github.com/russross/blackfriday/v2 v2.1.0 // indirect
|
github.com/russross/blackfriday/v2 v2.1.0 // indirect
|
||||||
github.com/spf13/pflag v1.0.5 // indirect
|
github.com/spf13/pflag v1.0.5 // indirect
|
||||||
github.com/urfave/cli/v2 v2.27.1 // indirect
|
github.com/urfave/cli/v2 v2.27.1 // indirect
|
||||||
@@ -102,13 +106,6 @@ require (
|
|||||||
k8s.io/kube-aggregator v0.30.1 // indirect
|
k8s.io/kube-aggregator v0.30.1 // indirect
|
||||||
k8s.io/kube-openapi v0.0.0-20240411171206-dc4e619f62f3 // indirect
|
k8s.io/kube-openapi v0.0.0-20240411171206-dc4e619f62f3 // indirect
|
||||||
k8s.io/utils v0.0.0-20230726121419-3b25d923346b // indirect
|
k8s.io/utils v0.0.0-20230726121419-3b25d923346b // indirect
|
||||||
modernc.org/gc/v3 v3.0.0-20240107210532-573471604cb6 // indirect
|
|
||||||
modernc.org/libc v1.49.3 // indirect
|
|
||||||
modernc.org/mathutil v1.6.0 // indirect
|
|
||||||
modernc.org/memory v1.8.0 // indirect
|
|
||||||
modernc.org/sqlite v1.29.10 // indirect
|
|
||||||
modernc.org/strutil v1.2.0 // indirect
|
|
||||||
modernc.org/token v1.1.0 // indirect
|
|
||||||
sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.29.0 // indirect
|
sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.29.0 // indirect
|
||||||
sigs.k8s.io/cli-utils v0.35.0 // indirect
|
sigs.k8s.io/cli-utils v0.35.0 // indirect
|
||||||
sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect
|
sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect
|
||||||
|
@@ -10,7 +10,7 @@ import (
|
|||||||
"github.com/cnrancher/kube-explorer/internal/config"
|
"github.com/cnrancher/kube-explorer/internal/config"
|
||||||
"github.com/rancher/steve/pkg/podimpersonation"
|
"github.com/rancher/steve/pkg/podimpersonation"
|
||||||
"github.com/rancher/steve/pkg/stores/proxy"
|
"github.com/rancher/steve/pkg/stores/proxy"
|
||||||
"github.com/rancher/wrangler/v3/pkg/schemas/validation"
|
"github.com/rancher/wrangler/v2/pkg/schemas/validation"
|
||||||
v1 "k8s.io/api/core/v1"
|
v1 "k8s.io/api/core/v1"
|
||||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||||
"k8s.io/apiserver/pkg/authentication/user"
|
"k8s.io/apiserver/pkg/authentication/user"
|
||||||
|
@@ -12,8 +12,8 @@ import (
|
|||||||
"github.com/rancher/steve/pkg/server"
|
"github.com/rancher/steve/pkg/server"
|
||||||
"github.com/rancher/steve/pkg/server/cli"
|
"github.com/rancher/steve/pkg/server/cli"
|
||||||
"github.com/rancher/steve/pkg/server/router"
|
"github.com/rancher/steve/pkg/server/router"
|
||||||
"github.com/rancher/wrangler/v3/pkg/kubeconfig"
|
"github.com/rancher/wrangler/v2/pkg/kubeconfig"
|
||||||
"github.com/rancher/wrangler/v3/pkg/ratelimit"
|
"github.com/rancher/wrangler/v2/pkg/ratelimit"
|
||||||
|
|
||||||
"github.com/cnrancher/kube-explorer/internal/config"
|
"github.com/cnrancher/kube-explorer/internal/config"
|
||||||
"github.com/cnrancher/kube-explorer/internal/resources/cluster"
|
"github.com/cnrancher/kube-explorer/internal/resources/cluster"
|
||||||
@@ -21,7 +21,7 @@ import (
|
|||||||
"github.com/cnrancher/kube-explorer/internal/version"
|
"github.com/cnrancher/kube-explorer/internal/version"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ToServer(ctx context.Context, c *cli.Config, sqlCache bool) (*server.Server, error) {
|
func ToServer(ctx context.Context, c *cli.Config) (*server.Server, error) {
|
||||||
var (
|
var (
|
||||||
auth steveauth.Middleware
|
auth steveauth.Middleware
|
||||||
)
|
)
|
||||||
@@ -59,7 +59,6 @@ func ToServer(ctx context.Context, c *cli.Config, sqlCache bool) (*server.Server
|
|||||||
AuthMiddleware: auth,
|
AuthMiddleware: auth,
|
||||||
Controllers: controllers,
|
Controllers: controllers,
|
||||||
Next: ui,
|
Next: ui,
|
||||||
SQLCache: sqlCache,
|
|
||||||
// router needs to hack here
|
// router needs to hack here
|
||||||
Router: func(h router.Handlers) http.Handler {
|
Router: func(h router.Handlers) http.Handler {
|
||||||
return handleProxyHeader(
|
return handleProxyHeader(
|
||||||
|
4
main.go
4
main.go
@@ -6,7 +6,7 @@ import (
|
|||||||
"github.com/rancher/steve/pkg/debug"
|
"github.com/rancher/steve/pkg/debug"
|
||||||
stevecli "github.com/rancher/steve/pkg/server/cli"
|
stevecli "github.com/rancher/steve/pkg/server/cli"
|
||||||
"github.com/rancher/steve/pkg/version"
|
"github.com/rancher/steve/pkg/version"
|
||||||
"github.com/rancher/wrangler/v3/pkg/signals"
|
"github.com/rancher/wrangler/v2/pkg/signals"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
|
|
||||||
@@ -34,7 +34,7 @@ func main() {
|
|||||||
func run(_ *cli.Context) error {
|
func run(_ *cli.Context) error {
|
||||||
ctx := signals.SetupSignalContext()
|
ctx := signals.SetupSignalContext()
|
||||||
keconfig.Debug.MustSetupDebug()
|
keconfig.Debug.MustSetupDebug()
|
||||||
s, err := server.ToServer(ctx, &keconfig.Steve, false)
|
s, err := server.ToServer(ctx, &keconfig.Steve)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@@ -4,5 +4,4 @@ ARG TARGETOS
|
|||||||
ENV ARCH=${TARGETARCH:-"amd64"} OS=${TARGETOS:-"linux"}
|
ENV ARCH=${TARGETARCH:-"amd64"} OS=${TARGETOS:-"linux"}
|
||||||
RUN zypper install -y catatonit
|
RUN zypper install -y catatonit
|
||||||
COPY kube-explorer-${OS}-${ARCH} /usr/bin/kube-explorer
|
COPY kube-explorer-${OS}-${ARCH} /usr/bin/kube-explorer
|
||||||
ENTRYPOINT [ "/usr/bin/catatonit", "--" ]
|
ENTRYPOINT [ "/usr/bin/catatonit", "--", "kube-explorer" ]
|
||||||
CMD [ "kube-explorer" ]
|
|
||||||
|
@@ -6,77 +6,33 @@ cd "$(dirname $0)/.."
|
|||||||
|
|
||||||
rm -rf ./bin/* ./dist/*
|
rm -rf ./bin/* ./dist/*
|
||||||
|
|
||||||
OS_ARCH_ARG_LINUX="amd64 arm arm64"
|
BUILD_TARGET="${BUILD_TARGET:-dev}"
|
||||||
OS_ARCH_ARG_DARWIN="amd64 arm64"
|
CROSS=${CROSS:-}
|
||||||
OS_ARCH_ARG_WINDOWS="amd64"
|
|
||||||
|
|
||||||
LD_INJECT_VALUES="-X github.com/cnrancher/kube-explorer/internal/version.Version=$VERSION
|
if [[ ${GITHUB_REF} == refs/tags/* ]]; then
|
||||||
-X github.com/cnrancher/kube-explorer/internal/version.GitCommit=$COMMIT
|
CROSS=tag
|
||||||
-X github.com/cnrancher/kube-explorer/internal/config.APIUIVersion=$CATTLE_API_UI_VERSION"
|
elif [ -n "${GITHUB_REF}" ]; then
|
||||||
|
CROSS=push
|
||||||
|
fi
|
||||||
|
|
||||||
[ "$(uname)" != "Darwin" ] && LINKFLAGS="-extldflags -static -s"
|
case "$CROSS" in
|
||||||
|
|
||||||
case "$CROSS" in
|
|
||||||
"push")
|
|
||||||
for ARCH in ${OS_ARCH_ARG_LINUX}; do
|
|
||||||
OUTPUT_BIN="bin/kube-explorer-linux-$ARCH"
|
|
||||||
echo "Building binary for linux/$ARCH..."
|
|
||||||
GOARCH=$ARCH GOOS=linux CGO_ENABLED=0 go build -tags embed \
|
|
||||||
-ldflags \
|
|
||||||
"$LD_INJECT_VALUES $LINKFLAGS" \
|
|
||||||
-o ${OUTPUT_BIN}
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
"tag")
|
"tag")
|
||||||
for ARCH in ${OS_ARCH_ARG_LINUX}; do
|
BUILD_TARGET="prod"
|
||||||
OUTPUT_BIN="bin/kube-explorer-linux-$ARCH"
|
;;
|
||||||
echo "Building binary for linux/$ARCH..."
|
"push")
|
||||||
GOARCH=$ARCH GOOS=linux CGO_ENABLED=0 go build -tags embed \
|
;;
|
||||||
-ldflags \
|
|
||||||
"$LD_INJECT_VALUES $LINKFLAGS" \
|
|
||||||
-o ${OUTPUT_BIN}
|
|
||||||
done
|
|
||||||
|
|
||||||
for ARCH in ${OS_ARCH_ARG_DARWIN}; do
|
|
||||||
OUTPUT_BIN="bin/kube-explorer-darwin-$ARCH"
|
|
||||||
echo "Building binary for darwin/$ARCH..."
|
|
||||||
GOARCH=$ARCH GOOS=darwin CGO_ENABLED=0 go build -tags embed \
|
|
||||||
-ldflags \
|
|
||||||
"$LD_INJECT_VALUES" \
|
|
||||||
-o ${OUTPUT_BIN}
|
|
||||||
done
|
|
||||||
|
|
||||||
for ARCH in ${OS_ARCH_ARG_WINDOWS}; do
|
|
||||||
OUTPUT_BIN="bin/kube-explorer-windows-$ARCH.exe"
|
|
||||||
echo "Building binary for windows/$ARCH..."
|
|
||||||
GOARCH=$ARCH GOOS=windows CGO_ENABLED=0 go build -tags embed \
|
|
||||||
-ldflags \
|
|
||||||
"$LD_INJECT_VALUES" \
|
|
||||||
-o ${OUTPUT_BIN}
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
# only build one for current platform
|
BUILD_ARG="${BUILD_ARG} --single-target"
|
||||||
CGO_ENABLED=0 go build -tags embed \
|
;;
|
||||||
-ldflags \
|
|
||||||
"$LD_INJECT_VALUES $LINKFLAGS" \
|
|
||||||
-o "bin/kube-explorer-$(uname | tr '[:upper:]' '[:lower:]')-${ARCH}"
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
BUILD_ARG="${BUILD_ARG:-} --skip validate --id ${BUILD_TARGET}"
|
||||||
|
|
||||||
mkdir -p "./bin"
|
mkdir -p "./bin"
|
||||||
|
|
||||||
|
# upx is handled by goreleaser
|
||||||
|
VERSION=${VERSION} COMMIT=${COMMIT} goreleaser build $BUILD_ARG
|
||||||
|
|
||||||
mkdir -p "./dist"
|
mkdir -p "./dist"
|
||||||
|
|
||||||
for f in ./bin/*; do
|
cp -r bin/kube-explorer-* dist/
|
||||||
filename=$(basename "$f")
|
|
||||||
if [[ $filename != *darwin* && -z "$SKIP_COMPRESS" ]]; then
|
|
||||||
if upx -o "./dist/$filename" "$f"; then
|
|
||||||
echo "UPX done for $filename!"
|
|
||||||
else
|
|
||||||
echo "UPX failed for $filename, copying original file."
|
|
||||||
cp "$f" "./dist/$filename"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
cp "$f" "./dist/$filename"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
@@ -6,4 +6,6 @@ cd $(dirname $0)
|
|||||||
./download
|
./download
|
||||||
./validate
|
./validate
|
||||||
./build
|
./build
|
||||||
./package
|
if [ -z "${SKIP_PACKAGE}" ]; then
|
||||||
|
./package
|
||||||
|
fi
|
@@ -1,9 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
set -e
|
|
||||||
|
|
||||||
cd $(dirname $0)
|
|
||||||
|
|
||||||
./download
|
|
||||||
./validate
|
|
||||||
./build
|
|
||||||
|
|
@@ -1,11 +1,15 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [[ ${GITHUB_REF} == refs/tags/* ]]; then
|
||||||
|
GIT_TAG=${GIT_TAG:-${GITHUB_REF_NAME}}
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -n "$(git status --porcelain --untracked-files=no)" ]; then
|
if [ -n "$(git status --porcelain --untracked-files=no)" ]; then
|
||||||
DIRTY="-dirty"
|
DIRTY="-dirty"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
COMMIT=$(git rev-parse --short HEAD)
|
COMMIT=$(git rev-parse --short HEAD)
|
||||||
GIT_TAG=${DRONE_TAG:-$(git tag -l --contains HEAD | head -n 1)}
|
GIT_TAG=${GIT_TAG:-$(git tag -l --contains HEAD | head -n 1)}
|
||||||
|
|
||||||
if [[ -z "$DIRTY" && -n "$GIT_TAG" ]]; then
|
if [[ -z "$DIRTY" && -n "$GIT_TAG" ]]; then
|
||||||
VERSION=$GIT_TAG
|
VERSION=$GIT_TAG
|
||||||
|
Reference in New Issue
Block a user