Skip to content
GitLab
Explore
Projects
Groups
Topics
Snippets
Projects
Groups
Topics
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
1105 Внедрение механизмов обеспечения безопасности цепочки поставки программных проектов
Legacy
scanned-projects
helm
Commits
5e654c03
Commit
5e654c03
authored
8 years ago
by
Michelle Noorali
Committed by
migmartri-michelleN
8 years ago
Browse files
Options
Download
Patches
Plain Diff
feat(*): get helm & tiller chatting about upgrades
parent
e633b4b7
main
Release
add-codeql
dependabot/go_modules/github.com/docker/distribution-2.8.2incompatible
dependabot/go_modules/github.com/lib/pq-1.10.9
dependabot/go_modules/github.com/rubenv/sql-migrate-1.4.0
dependabot/go_modules/golang.org/x/crypto-0.9.0
dependabot/go_modules/golang.org/x/term-0.8.0
dependabot/go_modules/k8s.io/klog/v2-2.100.1
dev-v2
feat-v3/event-emitter-lua
kube-update-test
release-2.0
release-2.1
release-2.10
release-2.11
release-2.12
release-2.13
release-2.14
release-2.15
release-2.16
release-2.17
release-2.2
release-2.3
release-2.4
release-2.5
release-2.6
release-2.7
release-2.8
release-2.9
release-3.0
release-3.1
release-3.10
release-3.11
release-3.12
release-3.2
release-3.3
release-3.4
release-3.5
release-3.6
release-3.6.1
release-3.6.2
release-3.7
release-3.8
release-3.9
release-v3.0.0-beta.4
v3.12.0
v3.12.0-rc.1
v3.12.0-dev.1
v3.11.3
v3.11.2
v3.11.1
v3.11.0
v3.11.0-rc.2
v3.11.0-rc.1
v3.10.3
v3.10.2
v3.10.1
v3.10.0
v3.10.0-rc.1
v3.9.4
v3.9.3
v3.9.2
v3.9.1
v3.9.0
v3.9.0-rc.1
v3.8.2
v3.8.1
v3.8.0
v3.8.0-rc.2
v3.8.0-rc.1
v3.7.2
v3.7.1
v3.7.0
v3.7.0-rc.3
v3.7.0-rc.2
v3.7.0-rc.1
v3.6.3
v3.6.2
v3.6.1
v3.6.0
v3.6.0-rc.1
v3.5.4
v3.5.3
v3.5.2
v3.5.1
v3.5.0
v3.5.0-rc.2
v3.5.0-rc.1
v3.4.2
v3.4.1
v3.4.0
v3.4.0-rc.1
v3.3.4
v3.3.3
v3.3.2
v3.3.1
v3.3.0
v3.3.0-rc.2
v3.3.0-rc.1
v3.2.4
v3.2.3
v3.2.2
v3.2.1
v3.2.0
v3.2.0-rc.1
v3.1.3
v3.1.2
v3.1.1
v3.1.0
v3.1.0-rc.3
v3.1.0-rc.2
v3.1.0-rc.1
v3.0.3
v3.0.2
v3.0.1
v3.0.0
v3.0.0-rc.4
v3.0.0-rc.3
v3.0.0-rc.2
v3.0.0-rc.1
v3.0.0-beta.5
v3.0.0-beta.4
v3.0.0-beta.3
v3.0.0-beta.2
v3.0.0-beta.1
v3.0.0-alpha.2
v3.0.0-alpha.1
v2.17.0
v2.17.0-rc.1
v2.16.12
v2.16.11
v2.16.10
v2.16.9
v2.16.8
v2.16.7
v2.16.6
v2.16.5
v2.16.4
v2.16.3
v2.16.2
v2.16.1
v2.16.0
v2.16.0-rc.2
v2.16.0-rc.1
v2.15.2
v2.15.1
v2.15.0
v2.15.0-rc.2
v2.15.0-rc.1
v2.14.3
v2.14.2
v2.14.1
v2.14.0
v2.14.0-rc.2
v2.14.0-rc.1
v2.13.1
v2.13.1-rc.1
v2.13.0
v2.13.0-rc.2
v2.13.0-rc.1
v2.12.3
v2.12.2
v2.12.1
v2.12.0
v2.12.0-rc.2
v2.12.0-rc.1
v2.11.0
v2.11.0-rc.4
v2.11.0-rc.3
v2.11.0-rc.2
v2.11.0-rc.1
v2.10.0
v2.10.0-rc.3
v2.10.0-rc.2
v2.10.0-rc.1
v2.9.1
v2.9.0
v2.9.0-rc5
v2.9.0-rc4
v2.9.0-rc3
v2.9.0-rc2
v2.9.0-rc1
v2.8.2
v2.8.2-rc1
v2.8.1
v2.8.0
v2.8.0-rc.1
v2.7.2
v2.7.1
v2.7.0
v2.7.0-rc1
v2.6.2
v2.6.1
v2.6.0
v2.5.1
v2.5.0
v2.4.2
v2.4.1
v2.4.0
v2.3.1
v2.3.0
v2.2.3
v2.2.2
v2.2.1
v2.2.0
v2.1.3
v2.1.2
v2.1.1
v2.1.0
v2.0.2
v2.0.1
v2.0.0
v2.0.0-rc.2
v2.0.0-rc.1
v2.0.0-beta.2
v2.0.0-beta.1
v2.0.0-alpha.5
v2.0.0-alpha.4
v2.0.0-alpha.3
No related merge requests found
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
cmd/helm/upgrade.go
+40
-5
cmd/helm/upgrade.go
pkg/helm/client.go
+11
-7
pkg/helm/client.go
pkg/helm/compat.go
+82
-0
pkg/helm/compat.go
pkg/helm/option.go
+4
-3
pkg/helm/option.go
with
137 additions
and
15 deletions
+137
-15
cmd/helm/upgrade.go
+
40
−
5
View file @
5e654c03
...
...
@@ -20,6 +20,8 @@ import (
"fmt"
"github.com/spf13/cobra"
"k8s.io/helm/pkg/helm"
)
const
upgradeDesc
=
`
...
...
@@ -30,17 +32,50 @@ argument can be a relative path to a packaged or unpackaged chart.
`
var
upgradeCmd
=
&
cobra
.
Command
{
Use
:
"upgrade [RELEASE] [CHART]"
,
Short
:
"upgrade a release"
,
Long
:
upgradeDesc
,
RunE
:
runUpgrade
,
Use
:
"upgrade [RELEASE] [CHART]"
,
Short
:
"upgrade a release"
,
Long
:
upgradeDesc
,
RunE
:
runUpgrade
,
PersistentPreRunE
:
setupConnection
,
}
// upgrade flags
var
(
// upgradeDryRun performs a dry-run upgrade
upgradeDryRun
bool
// upgradeValues is the filename of supplied values.
upgradeValues
string
)
func
init
()
{
f
:=
upgradeCmd
.
Flags
()
f
.
StringVarP
(
&
upgradeValues
,
"values"
,
"f"
,
""
,
"path to a values YAML file"
)
f
.
BoolVar
(
&
upgradeDryRun
,
"dry-run"
,
false
,
"simulate an upgrade"
)
RootCommand
.
AddCommand
(
upgradeCmd
)
}
func
runUpgrade
(
cmd
*
cobra
.
Command
,
args
[]
string
)
error
{
fmt
.
Println
(
"Coming Soon"
)
if
err
:=
checkArgsLength
(
2
,
len
(
args
),
"release name, chart path"
);
err
!=
nil
{
return
err
}
chartPath
,
err
:=
locateChartPath
(
args
[
1
])
if
err
!=
nil
{
return
err
}
rawVals
,
err
:=
vals
(
upgradeValues
)
if
err
!=
nil
{
return
err
}
_
,
err
=
helm
.
UpdateRelease
(
args
[
0
],
chartPath
,
rawVals
,
upgradeDryRun
)
if
err
!=
nil
{
return
prettyError
(
err
)
}
fmt
.
Println
(
"Coming SOON to a Helm near YOU!"
)
return
nil
}
This diff is collapsed.
Click to expand it.
pkg/helm/client.go
+
11
−
7
View file @
5e654c03
...
...
@@ -17,10 +17,12 @@ limitations under the License.
package
helm
// import "k8s.io/helm/pkg/helm"
import
(
"os"
"google.golang.org/grpc"
"k8s.io/helm/pkg/chartutil"
rls
"k8s.io/helm/pkg/proto/hapi/services"
"os"
)
const
(
...
...
@@ -102,18 +104,20 @@ func (h *Client) DeleteRelease(rlsName string, opts ...DeleteOption) (*rls.Unins
return
h
.
opts
.
rpcDeleteRelease
(
rlsName
,
rls
.
NewReleaseServiceClient
(
c
),
opts
...
)
}
// UpdateRelease updates a release to a new/different chart.
//
// Note: there aren't currently any supported UpdateOptions, but they
// are kept in the API signature as a placeholder for future additions.
func
(
h
*
Client
)
UpdateRelease
(
rlsName
string
,
opts
...
UpdateOption
)
(
*
rls
.
UpdateReleaseResponse
,
error
)
{
// UpdateRelease updates a release to a new/different chart
func
(
h
*
Client
)
UpdateRelease
(
rlsName
string
,
chStr
string
,
opts
...
UpdateOption
)
(
*
rls
.
UpdateReleaseResponse
,
error
)
{
c
,
err
:=
grpc
.
Dial
(
h
.
opts
.
host
,
grpc
.
WithInsecure
())
if
err
!=
nil
{
return
nil
,
err
}
defer
c
.
Close
()
return
h
.
opts
.
rpcUpdateRelease
(
rlsName
,
rls
.
NewReleaseServiceClient
(
c
),
opts
...
)
chart
,
err
:=
chartutil
.
Load
(
chStr
)
if
err
!=
nil
{
return
nil
,
err
}
return
h
.
opts
.
rpcUpdateRelease
(
rlsName
,
chart
,
rls
.
NewReleaseServiceClient
(
c
),
opts
...
)
}
// ReleaseStatus returns the given release's status.
...
...
This diff is collapsed.
Click to expand it.
pkg/helm/compat.go
0 → 100644
+
82
−
0
View file @
5e654c03
/*
Copyright 2016 The Kubernetes Authors All rights reserved.
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
http://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.
*/
package
helm
import
(
rls
"k8s.io/helm/pkg/proto/hapi/services"
)
// These APIs are a temporary abstraction layer that captures the interaction between the current cmd/helm and old
// pkg/helm implementations. Post refactor the cmd/helm package will use the APIs exposed on helm.Client directly.
// Config is the base configuration
var
Config
struct
{
ServAddr
string
}
// ListReleases lists releases. DEPRECATED.
//
// Soon to be deprecated helm ListReleases API.
func
ListReleases
(
limit
int
,
offset
string
,
sort
rls
.
ListSort_SortBy
,
order
rls
.
ListSort_SortOrder
,
filter
string
)
(
*
rls
.
ListReleasesResponse
,
error
)
{
opts
:=
[]
ReleaseListOption
{
ReleaseListLimit
(
limit
),
ReleaseListOffset
(
offset
),
ReleaseListFilter
(
filter
),
ReleaseListSort
(
int32
(
sort
)),
ReleaseListOrder
(
int32
(
order
)),
}
return
NewClient
(
Host
(
Config
.
ServAddr
))
.
ListReleases
(
opts
...
)
}
// GetReleaseStatus gets a release status. DEPRECATED
//
// Soon to be deprecated helm GetReleaseStatus API.
func
GetReleaseStatus
(
rlsName
string
)
(
*
rls
.
GetReleaseStatusResponse
,
error
)
{
return
NewClient
(
Host
(
Config
.
ServAddr
))
.
ReleaseStatus
(
rlsName
)
}
// GetReleaseContent gets the content of a release.
// Soon to be deprecated helm GetReleaseContent API.
func
GetReleaseContent
(
rlsName
string
)
(
*
rls
.
GetReleaseContentResponse
,
error
)
{
return
NewClient
(
Host
(
Config
.
ServAddr
))
.
ReleaseContent
(
rlsName
)
}
// UpdateRelease updates a release.
// Soon to be deprecated helm UpdateRelease API.
func
UpdateRelease
(
rlsName
,
chStr
string
,
vals
[]
byte
,
dryRun
bool
)
(
*
rls
.
UpdateReleaseResponse
,
error
)
{
return
NewClient
(
Host
(
Config
.
ServAddr
))
.
UpdateRelease
(
rlsName
,
chStr
)
}
// InstallRelease runs an install for a release.
// Soon to be deprecated helm InstallRelease API.
func
InstallRelease
(
vals
[]
byte
,
rlsName
,
chStr
string
,
dryRun
bool
)
(
*
rls
.
InstallReleaseResponse
,
error
)
{
client
:=
NewClient
(
Host
(
Config
.
ServAddr
))
if
dryRun
{
client
.
Option
(
DryRun
())
}
return
client
.
InstallRelease
(
chStr
,
ValueOverrides
(
vals
),
ReleaseName
(
rlsName
))
}
// UninstallRelease destroys an existing release.
// Soon to be deprecated helm UninstallRelease API.
func
UninstallRelease
(
rlsName
string
,
dryRun
bool
)
(
*
rls
.
UninstallReleaseResponse
,
error
)
{
client
:=
NewClient
(
Host
(
Config
.
ServAddr
))
if
dryRun
{
client
.
Option
(
DryRun
())
}
return
client
.
DeleteRelease
(
rlsName
)
}
This diff is collapsed.
Click to expand it.
pkg/helm/option.go
+
4
−
3
View file @
5e654c03
...
...
@@ -17,7 +17,6 @@ limitations under the License.
package
helm
import
(
"fmt"
"golang.org/x/net/context"
cpb
"k8s.io/helm/pkg/proto/hapi/chart"
rls
"k8s.io/helm/pkg/proto/hapi/services"
...
...
@@ -209,8 +208,10 @@ func (o *options) rpcDeleteRelease(rlsName string, rlc rls.ReleaseServiceClient,
}
// Executes tiller.UpdateRelease RPC.
func
(
o
*
options
)
rpcUpdateRelease
(
rlsName
string
,
rlc
rls
.
ReleaseServiceClient
,
opts
...
UpdateOption
)
(
*
rls
.
UpdateReleaseResponse
,
error
)
{
return
nil
,
fmt
.
Errorf
(
"helm: UpdateRelease: not implemented"
)
func
(
o
*
options
)
rpcUpdateRelease
(
rlsName
string
,
chr
*
cpb
.
Chart
,
rlc
rls
.
ReleaseServiceClient
,
opts
...
UpdateOption
)
(
*
rls
.
UpdateReleaseResponse
,
error
)
{
//TODO: handle dryRun
return
rlc
.
UpdateRelease
(
context
.
TODO
(),
&
rls
.
UpdateReleaseRequest
{
Name
:
rlsName
,
Chart
:
chr
})
}
// Executes tiller.GetReleaseStatus RPC.
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment
Menu
Explore
Projects
Groups
Topics
Snippets