2016-12-18 05:21:29 +00:00
|
|
|
package http
|
|
|
|
|
|
|
|
import (
|
2021-04-06 10:08:43 +00:00
|
|
|
"context"
|
2021-08-10 04:59:47 +00:00
|
|
|
"crypto/tls"
|
2020-07-05 23:21:03 +00:00
|
|
|
"net/http"
|
|
|
|
"path/filepath"
|
2018-05-07 18:01:39 +00:00
|
|
|
"time"
|
|
|
|
|
2023-11-20 07:35:03 +00:00
|
|
|
"github.com/pkg/errors"
|
2020-03-29 09:54:14 +00:00
|
|
|
portainer "github.com/portainer/portainer/api"
|
2021-04-06 10:08:43 +00:00
|
|
|
"github.com/portainer/portainer/api/adminmonitor"
|
2021-11-30 02:31:16 +00:00
|
|
|
"github.com/portainer/portainer/api/apikey"
|
2020-07-22 00:16:00 +00:00
|
|
|
"github.com/portainer/portainer/api/crypto"
|
chore(store) EE-1981: Refactor/store/error checking, and other refactoring (#6173)
* use the Store interface IsErrObjectNotFound() to avoid revealing internal errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* what happens when you extract the datastore interfaces into their own package
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* Start renaming Storage methods
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the boltdb specific code from the Portainer storage code (example, the others need the same)
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extract bolt.Tx from datastore code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* minimise imports by putting moving the struct definition into the file that needs the Service imports
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extraction of boltdb.Tx
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the use of bucket.SetSequence
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* almost done - just endpoint.Synchonise :/
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* so, endpoint.Synchonize looks hard, but i can't find where we use it, so 'delete first refactoring'
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix test compile errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* test compile fixes after rebase
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix a mis-remembering I had wrt deserialisation - last time i used AnyData - jsoniter's bindTo looks interesting for the same reason
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* set us up to make the connection an interface
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make the db connection a datastore interface, and separate out our datastore services from the bolt ones
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* rename methods to something less oltdb internals specific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* these errors are not boltdb secific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* start using the db-backend factory method too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* export boltdb raw in case we can't export from the service layer
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add a raw export from boltdb to yaml for broken db's, and an export services to yaml in backup
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add the version info by hand for now
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* actually, the export from services can be fully typed - its the import that needs to do more work
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* redo raw export, and make import capable of using it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add DockerHub
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* migration from anything older than v1.21.0 has been broken for quite a while, deleting the un-tested code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix go test ./... again
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* my goland wasn't setup to gofmt
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the two extremely dubious migration tests down into store, so they can use the test store code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* the migrator is now free of boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* reverse goland overzealous replcement of internal with boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more undo over-zealous goland internal->boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* yay, now bolt is only mentioned inside the api/database/ dir
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* and this might be the last of the boltdb references?
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add todo
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the store code into a separate module too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* don't need the fileService in boltdb anymore
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use IsErrObjectNotFound()
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use a string to select what database backend we use
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make isNew store an ephemeral bool that doesn't stay true after we've initialised it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the import.json wip to a separate file so its more obvious - we'll be using it for testing, emergency fixups, and in the next part of the store work, when we improve migrations and data model lifecycles
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* undo vscode formatting html
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix app templates symbol (#6221)
* feat(webhook) EE-2125 send registry auth haeder when update swarms service via webhook (#6220)
* feat(webhook) EE-2125 add some helpers to registry utils
* feat(webhook) EE-2125 persist registryID when creating a webhook
* feat(webhook) EE-2125 send registry auth header when executing a webhook
* feat(webhook) EE-2125 send registryID to backend when creating a service with webhook
* feat(webhook) EE-2125 use the initial registry ID to create webhook on editing service screen
* feat(webhook) EE-2125 update webhook when update registry
* feat(webhook) EE-2125 add endpoint of update webhook
* feat(webhook) EE-2125 code cleanup
* feat(webhook) EE-2125 fix a typo
* feat(webhook) EE-2125 fix circle import issue with unit test
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix(kubeconfig): show kubeconfig download button for non admin users [EE-2123] (#6204)
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix data-cy for k8s cluster menu (#6226)
LGTM
* feat(stack): make stack created from app template editable EE-1941 (#6104)
feat(stack): make stack from app template editable
* fix(container):disable Duplicate/Edit button when the container is portainer (#6223)
* fix/ee-1909/show-pull-image-error (#6195)
Co-authored-by: sunportainer <ericsun@SG1.local>
* feat(cy): add data-cy to helm install button (#6241)
* feat(cy): add data-cy to add registry button (#6242)
* refactor(app): convert root folder files to es6 (#4159)
* refactor(app): duplicate constants as es6 exports (#4158)
* fix(docker): provide workaround to save network name variable (#6080)
* fix/EE-1862/unable-to-stop-or-remove-stack workaround for var without default value in yaml file
* fix/EE-1862/unable-to-stop-or-remove-stack check yaml file
* fixed func and var names
* wrapper error and used bool for stringset
* UT case for createNetworkEnvFile
* UT case for %s=%s
* powerful StringSet
* wrapper error for extract network name
* wrapper all the return err
* store more env
* put to env file
* make default value None
* feat: gzip static resources (#6258)
* fix(ssl)//handle --sslcert and --sslkey ee-2106 (#6203)
* fix/ee-2106/handle-sslcert-sslkey
Co-authored-by: sunportainer <ericsun@SG1.local>
* fix(server):support disable https only ee-2068 (#6232)
* fix/ee-2068/disable-forcely-https
* feat(store): implement store tests EE-2112 (#6224)
* add store tests
* add some more tests
* Update missing helm user repo methods
* remove redundant comments
* add webhook export
* update webhooks
* use the Store interface IsErrObjectNotFound() to avoid revealing internal errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* what happens when you extract the datastore interfaces into their own package
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* Start renaming Storage methods
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the boltdb specific code from the Portainer storage code (example, the others need the same)
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extract bolt.Tx from datastore code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* minimise imports by putting moving the struct definition into the file that needs the Service imports
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extraction of boltdb.Tx
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the use of bucket.SetSequence
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* almost done - just endpoint.Synchonise :/
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* so, endpoint.Synchonize looks hard, but i can't find where we use it, so 'delete first refactoring'
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix test compile errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* test compile fixes after rebase
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix a mis-remembering I had wrt deserialisation - last time i used AnyData - jsoniter's bindTo looks interesting for the same reason
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* set us up to make the connection an interface
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make the db connection a datastore interface, and separate out our datastore services from the bolt ones
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* rename methods to something less oltdb internals specific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* these errors are not boltdb secific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* start using the db-backend factory method too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* export boltdb raw in case we can't export from the service layer
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add a raw export from boltdb to yaml for broken db's, and an export services to yaml in backup
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add the version info by hand for now
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* actually, the export from services can be fully typed - its the import that needs to do more work
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* redo raw export, and make import capable of using it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add DockerHub
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* migration from anything older than v1.21.0 has been broken for quite a while, deleting the un-tested code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix go test ./... again
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* my goland wasn't setup to gofmt
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the two extremely dubious migration tests down into store, so they can use the test store code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* the migrator is now free of boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* reverse goland overzealous replcement of internal with boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more undo over-zealous goland internal->boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* yay, now bolt is only mentioned inside the api/database/ dir
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* and this might be the last of the boltdb references?
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add todo
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the store code into a separate module too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* don't need the fileService in boltdb anymore
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use IsErrObjectNotFound()
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use a string to select what database backend we use
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make isNew store an ephemeral bool that doesn't stay true after we've initialised it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the import.json wip to a separate file so its more obvious - we'll be using it for testing, emergency fixups, and in the next part of the store work, when we improve migrations and data model lifecycles
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* undo vscode formatting html
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* Update missing helm user repo methods
* feat(store): implement store tests EE-2112 (#6224)
* add store tests
* add some more tests
* remove redundant comments
* add webhook export
* update webhooks
* fix build issues after rebasing
* move migratorparams
* remove unneeded integer type conversions
* disable the db import/export for now
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: cong meng <mcpacino@gmail.com>
Co-authored-by: Simon Meng <simon.meng@portainer.io>
Co-authored-by: Marcelo Rydel <marcelorydel26@gmail.com>
Co-authored-by: Hao Zhang <hao.zhang@portainer.io>
Co-authored-by: sunportainer <93502624+sunportainer@users.noreply.github.com>
Co-authored-by: sunportainer <ericsun@SG1.local>
Co-authored-by: wheresolivia <78844659+wheresolivia@users.noreply.github.com>
Co-authored-by: Chaim Lev-Ari <chiptus@users.noreply.github.com>
Co-authored-by: Chao Geng <93526589+chaogeng77977@users.noreply.github.com>
Co-authored-by: Dmitry Salakhov <to@dimasalakhov.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
2021-12-15 02:26:09 +00:00
|
|
|
"github.com/portainer/portainer/api/dataservices"
|
2022-05-22 05:34:09 +00:00
|
|
|
"github.com/portainer/portainer/api/demo"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/docker"
|
2023-05-29 21:36:10 +00:00
|
|
|
dockerclient "github.com/portainer/portainer/api/docker/client"
|
2023-11-20 07:35:03 +00:00
|
|
|
"github.com/portainer/portainer/api/http/csrf"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/auth"
|
2021-04-06 10:08:43 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/backup"
|
2020-07-06 23:18:39 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/customtemplates"
|
2022-08-11 04:33:29 +00:00
|
|
|
dockerhandler "github.com/portainer/portainer/api/http/handler/docker"
|
2020-07-05 23:21:03 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/edgegroups"
|
2020-06-25 03:25:51 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/edgejobs"
|
2020-07-05 23:21:03 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/edgestacks"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/edgetemplates"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/endpointedge"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/endpointgroups"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/endpointproxy"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/endpoints"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/file"
|
2023-04-04 00:44:42 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/gitops"
|
feat(helm/templates): helm app templates EE-943 (#5449)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm): list and configure helm chart (#5431)
* backport and tidyup code
* --amend
* using rocket icon for charts
* helm chart bugfix - clear category button
* added matomo analytics for helm chart install
* fix web editor exit warning without changes
* editor modified exit bugfix
* fixed notifications typo
* updated helm template text
* helper text to convey slow helm templates load
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* removing redundant time-consuming api call by using prop attribute
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* bugfix: kubectl shell not opening - bearer token bug
* tidy go modules & remove yarn-error.log
* removed redundant handler (not used) - to match EE
* resolved merge conflicts, updated code
* feat(helm/views): helm release and application views EE-1236 (#5529)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* removed redundant handler (not used) - to match EE
* feat(helm) display helm charts - backend EE-1236
* copy over components for new applications view EE-1236
* Add new applications datatable component
* Add more migrated files
* removed test not applicable to CE
* baclkported EE app data table code to CE
* removed redundant helm repo url
* resolved conflicts, updated code
* using endpoint middleware
* PR review fixes
* using constants, openapi updated
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* fixed test conflicts, go linted
* feat(helm/templates-add): helm templates add repo for user support EE-1278 (#5514)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* backport EE-1278, squashed, diffed, updated
* helm install openapi spec update
* resolved conflicts, updated code
* - matching ee codebase at 0afe57034449ee0e9f333d92c252a13995a93019
- helm install using endpoint middleware
- remove trailing slash from added/persisted helm repo urls
* feat(helm) use libhelm url validator and improved path assembly EE-1554 (#5561)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562 (#5567)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562
* post review changes and further backported changes from EE
* resolved conflicts, updated code
* fixed helm_install handler unit test
* user cannot add existing repo if suffix is '/' (#5571)
* feat(helm/docs) fix broken swagger docs EE-1278 (#5572)
* Fix swagger docs
* minor correction
* fix(helm): migrating code from user handler to helm handler (#5573)
* - migrated user_helm_repos to helm endpoint handler
- migrated api operations from user factory/service to helm factory/service
- passing endpointId into helm service/factory as endpoint provider is deprecated
* upgrade libhelm to hide secrets
Co-authored-by: Matt Hook <hookenz@gmail.com>
* removed duplicate file - due to merge conflict
* dependency injection in helm factory
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
* kubernetes.templates -> kubernetes.templates.helm name conflict fix
* Validate the URL added as a public helm repo (#5579)
* fix(helm): helm app deletion fix EE-1581 (#5582)
* updated helm lib to show correct error on uninstall failure
* passing down helm app namespace on deletion
* fix(k8s): EE-1591 non-admin users cannot deploy charts containing secrets (#5590)
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix(helm): helm epic bugfixes EE-1582 EE-1593 (#5585)
* - trim trailing slash and lowercase before persisting helm repo
- browser helm templates url /kubernetes/templates/templates -> /kubernetes/templates/helm
- fix publish url
- fix helm repo add refresh
- semi-fix k8s app expansion
* Tidy up swagger documentation related to helm. Make json consistent
* fixed helm release page for non-default namespaces
* k8s app view table expansion bugfix
* EE-1593: publish url load balancer fallback
Co-authored-by: Matt Hook <hookenz@gmail.com>
* k8s app list fix for charts with deployments containing multiple pods - which use the same label (#5599)
* fix(kubernetes): app list view fix for secrets with long keys or values EE-1600 (#5600)
* k8s app secrets key value text overflow ellipses
* wrapping key value pairs instead of ellipses
* fix(helm): helm apps bundling issue across different namespaces EE-1619 (#5602)
* helm apps bundling issue across different namespaces
* - code comments and indentation to ease reading
- moved namespace calc out of loop
* feat(helm/test) disable slow helm search test by default EE-1599 (#5598)
* skip helm_repo_search as it's an integration test
* switch to portainer built in integration test checker
* make module order match EE
* don't print test struct out when skipping integration test
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
Co-authored-by: cong meng <mcpacino@gmail.com>
Co-authored-by: Simon Meng <simon.meng@portainer.io>
2021-09-10 02:06:57 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/helm"
|
2022-01-23 19:48:04 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/hostmanagement/fdo"
|
2021-11-29 13:06:50 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/hostmanagement/openamt"
|
2021-08-26 14:00:59 +00:00
|
|
|
kubehandler "github.com/portainer/portainer/api/http/handler/kubernetes"
|
2021-10-06 06:24:26 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/ldap"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/motd"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/registries"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/resourcecontrols"
|
2020-07-05 23:21:03 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/roles"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/settings"
|
2021-08-10 04:59:47 +00:00
|
|
|
sslhandler "github.com/portainer/portainer/api/http/handler/ssl"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/stacks"
|
2021-11-03 10:41:59 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/storybook"
|
2022-12-11 06:58:22 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/system"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/handler/tags"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/teammemberships"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/teams"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/templates"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/upload"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/users"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/webhooks"
|
|
|
|
"github.com/portainer/portainer/api/http/handler/websocket"
|
2023-07-05 12:25:05 +00:00
|
|
|
"github.com/portainer/portainer/api/http/middlewares"
|
2021-04-06 10:08:43 +00:00
|
|
|
"github.com/portainer/portainer/api/http/offlinegate"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/proxy"
|
2020-07-05 23:21:03 +00:00
|
|
|
"github.com/portainer/portainer/api/http/proxy/factory/kubernetes"
|
2019-03-21 01:20:14 +00:00
|
|
|
"github.com/portainer/portainer/api/http/security"
|
2021-06-16 08:15:29 +00:00
|
|
|
"github.com/portainer/portainer/api/internal/authorization"
|
2022-12-01 06:40:52 +00:00
|
|
|
edgestackservice "github.com/portainer/portainer/api/internal/edge/edgestacks"
|
2023-07-14 15:34:50 +00:00
|
|
|
"github.com/portainer/portainer/api/internal/snapshot"
|
2021-08-10 04:59:47 +00:00
|
|
|
"github.com/portainer/portainer/api/internal/ssl"
|
2022-12-11 06:58:22 +00:00
|
|
|
"github.com/portainer/portainer/api/internal/upgrade"
|
feat(helm/templates): helm app templates EE-943 (#5449)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm): list and configure helm chart (#5431)
* backport and tidyup code
* --amend
* using rocket icon for charts
* helm chart bugfix - clear category button
* added matomo analytics for helm chart install
* fix web editor exit warning without changes
* editor modified exit bugfix
* fixed notifications typo
* updated helm template text
* helper text to convey slow helm templates load
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* removing redundant time-consuming api call by using prop attribute
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* bugfix: kubectl shell not opening - bearer token bug
* tidy go modules & remove yarn-error.log
* removed redundant handler (not used) - to match EE
* resolved merge conflicts, updated code
* feat(helm/views): helm release and application views EE-1236 (#5529)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* removed redundant handler (not used) - to match EE
* feat(helm) display helm charts - backend EE-1236
* copy over components for new applications view EE-1236
* Add new applications datatable component
* Add more migrated files
* removed test not applicable to CE
* baclkported EE app data table code to CE
* removed redundant helm repo url
* resolved conflicts, updated code
* using endpoint middleware
* PR review fixes
* using constants, openapi updated
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* fixed test conflicts, go linted
* feat(helm/templates-add): helm templates add repo for user support EE-1278 (#5514)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* backport EE-1278, squashed, diffed, updated
* helm install openapi spec update
* resolved conflicts, updated code
* - matching ee codebase at 0afe57034449ee0e9f333d92c252a13995a93019
- helm install using endpoint middleware
- remove trailing slash from added/persisted helm repo urls
* feat(helm) use libhelm url validator and improved path assembly EE-1554 (#5561)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562 (#5567)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562
* post review changes and further backported changes from EE
* resolved conflicts, updated code
* fixed helm_install handler unit test
* user cannot add existing repo if suffix is '/' (#5571)
* feat(helm/docs) fix broken swagger docs EE-1278 (#5572)
* Fix swagger docs
* minor correction
* fix(helm): migrating code from user handler to helm handler (#5573)
* - migrated user_helm_repos to helm endpoint handler
- migrated api operations from user factory/service to helm factory/service
- passing endpointId into helm service/factory as endpoint provider is deprecated
* upgrade libhelm to hide secrets
Co-authored-by: Matt Hook <hookenz@gmail.com>
* removed duplicate file - due to merge conflict
* dependency injection in helm factory
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
* kubernetes.templates -> kubernetes.templates.helm name conflict fix
* Validate the URL added as a public helm repo (#5579)
* fix(helm): helm app deletion fix EE-1581 (#5582)
* updated helm lib to show correct error on uninstall failure
* passing down helm app namespace on deletion
* fix(k8s): EE-1591 non-admin users cannot deploy charts containing secrets (#5590)
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix(helm): helm epic bugfixes EE-1582 EE-1593 (#5585)
* - trim trailing slash and lowercase before persisting helm repo
- browser helm templates url /kubernetes/templates/templates -> /kubernetes/templates/helm
- fix publish url
- fix helm repo add refresh
- semi-fix k8s app expansion
* Tidy up swagger documentation related to helm. Make json consistent
* fixed helm release page for non-default namespaces
* k8s app view table expansion bugfix
* EE-1593: publish url load balancer fallback
Co-authored-by: Matt Hook <hookenz@gmail.com>
* k8s app list fix for charts with deployments containing multiple pods - which use the same label (#5599)
* fix(kubernetes): app list view fix for secrets with long keys or values EE-1600 (#5600)
* k8s app secrets key value text overflow ellipses
* wrapping key value pairs instead of ellipses
* fix(helm): helm apps bundling issue across different namespaces EE-1619 (#5602)
* helm apps bundling issue across different namespaces
* - code comments and indentation to ease reading
- moved namespace calc out of loop
* feat(helm/test) disable slow helm search test by default EE-1599 (#5598)
* skip helm_repo_search as it's an integration test
* switch to portainer built in integration test checker
* make module order match EE
* don't print test struct out when skipping integration test
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
Co-authored-by: cong meng <mcpacino@gmail.com>
Co-authored-by: Simon Meng <simon.meng@portainer.io>
2021-09-10 02:06:57 +00:00
|
|
|
k8s "github.com/portainer/portainer/api/kubernetes"
|
2020-07-05 23:21:03 +00:00
|
|
|
"github.com/portainer/portainer/api/kubernetes/cli"
|
2023-09-18 20:57:27 +00:00
|
|
|
"github.com/portainer/portainer/api/pendingactions"
|
2021-08-17 01:12:07 +00:00
|
|
|
"github.com/portainer/portainer/api/scheduler"
|
2022-10-05 09:33:59 +00:00
|
|
|
"github.com/portainer/portainer/api/stacks/deployments"
|
2022-12-04 21:38:16 +00:00
|
|
|
"github.com/portainer/portainer/pkg/libhelm"
|
2022-09-16 16:18:44 +00:00
|
|
|
|
|
|
|
"github.com/rs/zerolog/log"
|
2016-12-18 05:21:29 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Server implements the portainer.Server interface
|
|
|
|
type Server struct {
|
2021-08-10 04:59:47 +00:00
|
|
|
AuthorizationService *authorization.Service
|
2021-01-25 19:16:53 +00:00
|
|
|
BindAddress string
|
2021-08-10 04:59:47 +00:00
|
|
|
BindAddressHTTPS string
|
|
|
|
HTTPEnabled bool
|
2021-01-25 19:16:53 +00:00
|
|
|
AssetsPath string
|
|
|
|
Status *portainer.Status
|
|
|
|
ReverseTunnelService portainer.ReverseTunnelService
|
|
|
|
ComposeStackManager portainer.ComposeStackManager
|
|
|
|
CryptoService portainer.CryptoService
|
2022-12-01 06:40:52 +00:00
|
|
|
EdgeStacksService *edgestackservice.Service
|
2021-01-25 19:16:53 +00:00
|
|
|
SignatureService portainer.DigitalSignatureService
|
|
|
|
SnapshotService portainer.SnapshotService
|
|
|
|
FileService portainer.FileService
|
chore(store) EE-1981: Refactor/store/error checking, and other refactoring (#6173)
* use the Store interface IsErrObjectNotFound() to avoid revealing internal errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* what happens when you extract the datastore interfaces into their own package
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* Start renaming Storage methods
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the boltdb specific code from the Portainer storage code (example, the others need the same)
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extract bolt.Tx from datastore code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* minimise imports by putting moving the struct definition into the file that needs the Service imports
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extraction of boltdb.Tx
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the use of bucket.SetSequence
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* almost done - just endpoint.Synchonise :/
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* so, endpoint.Synchonize looks hard, but i can't find where we use it, so 'delete first refactoring'
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix test compile errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* test compile fixes after rebase
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix a mis-remembering I had wrt deserialisation - last time i used AnyData - jsoniter's bindTo looks interesting for the same reason
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* set us up to make the connection an interface
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make the db connection a datastore interface, and separate out our datastore services from the bolt ones
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* rename methods to something less oltdb internals specific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* these errors are not boltdb secific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* start using the db-backend factory method too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* export boltdb raw in case we can't export from the service layer
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add a raw export from boltdb to yaml for broken db's, and an export services to yaml in backup
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add the version info by hand for now
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* actually, the export from services can be fully typed - its the import that needs to do more work
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* redo raw export, and make import capable of using it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add DockerHub
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* migration from anything older than v1.21.0 has been broken for quite a while, deleting the un-tested code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix go test ./... again
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* my goland wasn't setup to gofmt
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the two extremely dubious migration tests down into store, so they can use the test store code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* the migrator is now free of boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* reverse goland overzealous replcement of internal with boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more undo over-zealous goland internal->boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* yay, now bolt is only mentioned inside the api/database/ dir
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* and this might be the last of the boltdb references?
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add todo
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the store code into a separate module too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* don't need the fileService in boltdb anymore
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use IsErrObjectNotFound()
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use a string to select what database backend we use
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make isNew store an ephemeral bool that doesn't stay true after we've initialised it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the import.json wip to a separate file so its more obvious - we'll be using it for testing, emergency fixups, and in the next part of the store work, when we improve migrations and data model lifecycles
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* undo vscode formatting html
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix app templates symbol (#6221)
* feat(webhook) EE-2125 send registry auth haeder when update swarms service via webhook (#6220)
* feat(webhook) EE-2125 add some helpers to registry utils
* feat(webhook) EE-2125 persist registryID when creating a webhook
* feat(webhook) EE-2125 send registry auth header when executing a webhook
* feat(webhook) EE-2125 send registryID to backend when creating a service with webhook
* feat(webhook) EE-2125 use the initial registry ID to create webhook on editing service screen
* feat(webhook) EE-2125 update webhook when update registry
* feat(webhook) EE-2125 add endpoint of update webhook
* feat(webhook) EE-2125 code cleanup
* feat(webhook) EE-2125 fix a typo
* feat(webhook) EE-2125 fix circle import issue with unit test
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix(kubeconfig): show kubeconfig download button for non admin users [EE-2123] (#6204)
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix data-cy for k8s cluster menu (#6226)
LGTM
* feat(stack): make stack created from app template editable EE-1941 (#6104)
feat(stack): make stack from app template editable
* fix(container):disable Duplicate/Edit button when the container is portainer (#6223)
* fix/ee-1909/show-pull-image-error (#6195)
Co-authored-by: sunportainer <ericsun@SG1.local>
* feat(cy): add data-cy to helm install button (#6241)
* feat(cy): add data-cy to add registry button (#6242)
* refactor(app): convert root folder files to es6 (#4159)
* refactor(app): duplicate constants as es6 exports (#4158)
* fix(docker): provide workaround to save network name variable (#6080)
* fix/EE-1862/unable-to-stop-or-remove-stack workaround for var without default value in yaml file
* fix/EE-1862/unable-to-stop-or-remove-stack check yaml file
* fixed func and var names
* wrapper error and used bool for stringset
* UT case for createNetworkEnvFile
* UT case for %s=%s
* powerful StringSet
* wrapper error for extract network name
* wrapper all the return err
* store more env
* put to env file
* make default value None
* feat: gzip static resources (#6258)
* fix(ssl)//handle --sslcert and --sslkey ee-2106 (#6203)
* fix/ee-2106/handle-sslcert-sslkey
Co-authored-by: sunportainer <ericsun@SG1.local>
* fix(server):support disable https only ee-2068 (#6232)
* fix/ee-2068/disable-forcely-https
* feat(store): implement store tests EE-2112 (#6224)
* add store tests
* add some more tests
* Update missing helm user repo methods
* remove redundant comments
* add webhook export
* update webhooks
* use the Store interface IsErrObjectNotFound() to avoid revealing internal errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* what happens when you extract the datastore interfaces into their own package
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* Start renaming Storage methods
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the boltdb specific code from the Portainer storage code (example, the others need the same)
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extract bolt.Tx from datastore code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* minimise imports by putting moving the struct definition into the file that needs the Service imports
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more extraction of boltdb.Tx
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the use of bucket.SetSequence
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* almost done - just endpoint.Synchonise :/
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* so, endpoint.Synchonize looks hard, but i can't find where we use it, so 'delete first refactoring'
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix test compile errors
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* test compile fixes after rebase
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix a mis-remembering I had wrt deserialisation - last time i used AnyData - jsoniter's bindTo looks interesting for the same reason
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* set us up to make the connection an interface
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make the db connection a datastore interface, and separate out our datastore services from the bolt ones
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* rename methods to something less oltdb internals specific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* these errors are not boltdb secific
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* start using the db-backend factory method too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* export boltdb raw in case we can't export from the service layer
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add a raw export from boltdb to yaml for broken db's, and an export services to yaml in backup
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add the version info by hand for now
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* actually, the export from services can be fully typed - its the import that needs to do more work
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* redo raw export, and make import capable of using it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add DockerHub
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* migration from anything older than v1.21.0 has been broken for quite a while, deleting the un-tested code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* fix go test ./... again
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* my goland wasn't setup to gofmt
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the two extremely dubious migration tests down into store, so they can use the test store code
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* the migrator is now free of boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* reverse goland overzealous replcement of internal with boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* more undo over-zealous goland internal->boltdb
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* yay, now bolt is only mentioned inside the api/database/ dir
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* and this might be the last of the boltdb references?
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* add todo
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* extract the store code into a separate module too
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* don't need the fileService in boltdb anymore
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use IsErrObjectNotFound()
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* use a string to select what database backend we use
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* make isNew store an ephemeral bool that doesn't stay true after we've initialised it
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* move the import.json wip to a separate file so its more obvious - we'll be using it for testing, emergency fixups, and in the next part of the store work, when we improve migrations and data model lifecycles
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* undo vscode formatting html
Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io>
* Update missing helm user repo methods
* feat(store): implement store tests EE-2112 (#6224)
* add store tests
* add some more tests
* remove redundant comments
* add webhook export
* update webhooks
* fix build issues after rebasing
* move migratorparams
* remove unneeded integer type conversions
* disable the db import/export for now
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: cong meng <mcpacino@gmail.com>
Co-authored-by: Simon Meng <simon.meng@portainer.io>
Co-authored-by: Marcelo Rydel <marcelorydel26@gmail.com>
Co-authored-by: Hao Zhang <hao.zhang@portainer.io>
Co-authored-by: sunportainer <93502624+sunportainer@users.noreply.github.com>
Co-authored-by: sunportainer <ericsun@SG1.local>
Co-authored-by: wheresolivia <78844659+wheresolivia@users.noreply.github.com>
Co-authored-by: Chaim Lev-Ari <chiptus@users.noreply.github.com>
Co-authored-by: Chao Geng <93526589+chaogeng77977@users.noreply.github.com>
Co-authored-by: Dmitry Salakhov <to@dimasalakhov.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
2021-12-15 02:26:09 +00:00
|
|
|
DataStore dataservices.DataStore
|
2021-01-25 19:16:53 +00:00
|
|
|
GitService portainer.GitService
|
2021-11-29 13:06:50 +00:00
|
|
|
OpenAMTService portainer.OpenAMTService
|
2021-11-30 02:31:16 +00:00
|
|
|
APIKeyService apikey.APIKeyService
|
2023-11-20 07:35:03 +00:00
|
|
|
JWTService portainer.JWTService
|
2021-01-25 19:16:53 +00:00
|
|
|
LDAPService portainer.LDAPService
|
|
|
|
OAuthService portainer.OAuthService
|
|
|
|
SwarmStackManager portainer.SwarmStackManager
|
|
|
|
ProxyManager *proxy.Manager
|
|
|
|
KubernetesTokenCacheManager *kubernetes.TokenCacheManager
|
2022-03-21 12:51:29 +00:00
|
|
|
KubeClusterAccessService k8s.KubeClusterAccessService
|
2021-01-25 19:16:53 +00:00
|
|
|
Handler *handler.Handler
|
2021-08-10 04:59:47 +00:00
|
|
|
SSLService *ssl.Service
|
2023-05-29 21:36:10 +00:00
|
|
|
DockerClientFactory *dockerclient.ClientFactory
|
2021-01-25 19:16:53 +00:00
|
|
|
KubernetesClientFactory *cli.ClientFactory
|
|
|
|
KubernetesDeployer portainer.KubernetesDeployer
|
feat(helm/templates): helm app templates EE-943 (#5449)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm): list and configure helm chart (#5431)
* backport and tidyup code
* --amend
* using rocket icon for charts
* helm chart bugfix - clear category button
* added matomo analytics for helm chart install
* fix web editor exit warning without changes
* editor modified exit bugfix
* fixed notifications typo
* updated helm template text
* helper text to convey slow helm templates load
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* removing redundant time-consuming api call by using prop attribute
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* bugfix: kubectl shell not opening - bearer token bug
* tidy go modules & remove yarn-error.log
* removed redundant handler (not used) - to match EE
* resolved merge conflicts, updated code
* feat(helm/views): helm release and application views EE-1236 (#5529)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* removed redundant handler (not used) - to match EE
* feat(helm) display helm charts - backend EE-1236
* copy over components for new applications view EE-1236
* Add new applications datatable component
* Add more migrated files
* removed test not applicable to CE
* baclkported EE app data table code to CE
* removed redundant helm repo url
* resolved conflicts, updated code
* using endpoint middleware
* PR review fixes
* using constants, openapi updated
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* fixed test conflicts, go linted
* feat(helm/templates-add): helm templates add repo for user support EE-1278 (#5514)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* backport EE-1278, squashed, diffed, updated
* helm install openapi spec update
* resolved conflicts, updated code
* - matching ee codebase at 0afe57034449ee0e9f333d92c252a13995a93019
- helm install using endpoint middleware
- remove trailing slash from added/persisted helm repo urls
* feat(helm) use libhelm url validator and improved path assembly EE-1554 (#5561)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562 (#5567)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562
* post review changes and further backported changes from EE
* resolved conflicts, updated code
* fixed helm_install handler unit test
* user cannot add existing repo if suffix is '/' (#5571)
* feat(helm/docs) fix broken swagger docs EE-1278 (#5572)
* Fix swagger docs
* minor correction
* fix(helm): migrating code from user handler to helm handler (#5573)
* - migrated user_helm_repos to helm endpoint handler
- migrated api operations from user factory/service to helm factory/service
- passing endpointId into helm service/factory as endpoint provider is deprecated
* upgrade libhelm to hide secrets
Co-authored-by: Matt Hook <hookenz@gmail.com>
* removed duplicate file - due to merge conflict
* dependency injection in helm factory
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
* kubernetes.templates -> kubernetes.templates.helm name conflict fix
* Validate the URL added as a public helm repo (#5579)
* fix(helm): helm app deletion fix EE-1581 (#5582)
* updated helm lib to show correct error on uninstall failure
* passing down helm app namespace on deletion
* fix(k8s): EE-1591 non-admin users cannot deploy charts containing secrets (#5590)
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix(helm): helm epic bugfixes EE-1582 EE-1593 (#5585)
* - trim trailing slash and lowercase before persisting helm repo
- browser helm templates url /kubernetes/templates/templates -> /kubernetes/templates/helm
- fix publish url
- fix helm repo add refresh
- semi-fix k8s app expansion
* Tidy up swagger documentation related to helm. Make json consistent
* fixed helm release page for non-default namespaces
* k8s app view table expansion bugfix
* EE-1593: publish url load balancer fallback
Co-authored-by: Matt Hook <hookenz@gmail.com>
* k8s app list fix for charts with deployments containing multiple pods - which use the same label (#5599)
* fix(kubernetes): app list view fix for secrets with long keys or values EE-1600 (#5600)
* k8s app secrets key value text overflow ellipses
* wrapping key value pairs instead of ellipses
* fix(helm): helm apps bundling issue across different namespaces EE-1619 (#5602)
* helm apps bundling issue across different namespaces
* - code comments and indentation to ease reading
- moved namespace calc out of loop
* feat(helm/test) disable slow helm search test by default EE-1599 (#5598)
* skip helm_repo_search as it's an integration test
* switch to portainer built in integration test checker
* make module order match EE
* don't print test struct out when skipping integration test
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
Co-authored-by: cong meng <mcpacino@gmail.com>
Co-authored-by: Simon Meng <simon.meng@portainer.io>
2021-09-10 02:06:57 +00:00
|
|
|
HelmPackageManager libhelm.HelmPackageManager
|
2021-08-17 01:12:07 +00:00
|
|
|
Scheduler *scheduler.Scheduler
|
2021-04-06 10:08:43 +00:00
|
|
|
ShutdownCtx context.Context
|
|
|
|
ShutdownTrigger context.CancelFunc
|
2022-10-05 09:33:59 +00:00
|
|
|
StackDeployer deployments.StackDeployer
|
2022-05-22 05:34:09 +00:00
|
|
|
DemoService *demo.Service
|
2022-12-11 06:58:22 +00:00
|
|
|
UpgradeService upgrade.Service
|
2023-05-03 21:44:11 +00:00
|
|
|
AdminCreationDone chan struct{}
|
2023-09-18 20:57:27 +00:00
|
|
|
PendingActionsService *pendingactions.PendingActionsService
|
2016-12-18 05:21:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Start starts the HTTP server
|
|
|
|
func (server *Server) Start() error {
|
2021-01-25 19:16:53 +00:00
|
|
|
kubernetesTokenCacheManager := server.KubernetesTokenCacheManager
|
2020-05-20 05:23:15 +00:00
|
|
|
|
2021-11-30 02:31:16 +00:00
|
|
|
requestBouncer := security.NewRequestBouncer(server.DataStore, server.JWTService, server.APIKeyService)
|
2019-05-24 06:04:58 +00:00
|
|
|
|
2018-05-07 18:01:39 +00:00
|
|
|
rateLimiter := security.NewRateLimiter(10, 1*time.Second, 1*time.Hour)
|
2021-04-06 10:08:43 +00:00
|
|
|
offlineGate := offlinegate.NewOfflineGate()
|
2016-12-25 20:34:02 +00:00
|
|
|
|
2022-06-03 04:00:13 +00:00
|
|
|
passwordStrengthChecker := security.NewPasswordStrengthChecker(server.DataStore.Settings())
|
|
|
|
|
|
|
|
var authHandler = auth.NewHandler(requestBouncer, rateLimiter, passwordStrengthChecker)
|
2020-05-20 05:23:15 +00:00
|
|
|
authHandler.DataStore = server.DataStore
|
2016-12-18 05:21:29 +00:00
|
|
|
authHandler.CryptoService = server.CryptoService
|
|
|
|
authHandler.JWTService = server.JWTService
|
2017-08-10 08:35:23 +00:00
|
|
|
authHandler.LDAPService = server.LDAPService
|
2021-01-25 19:16:53 +00:00
|
|
|
authHandler.ProxyManager = server.ProxyManager
|
2020-07-05 23:21:03 +00:00
|
|
|
authHandler.KubernetesTokenCacheManager = kubernetesTokenCacheManager
|
2020-08-05 08:36:46 +00:00
|
|
|
authHandler.OAuthService = server.OAuthService
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2021-04-06 10:08:43 +00:00
|
|
|
adminMonitor := adminmonitor.New(5*time.Minute, server.DataStore, server.ShutdownCtx)
|
|
|
|
adminMonitor.Start()
|
|
|
|
|
2022-05-22 05:34:09 +00:00
|
|
|
var backupHandler = backup.NewHandler(
|
|
|
|
requestBouncer,
|
|
|
|
server.DataStore,
|
|
|
|
offlineGate,
|
|
|
|
server.FileService.GetDatastorePath(),
|
|
|
|
server.ShutdownTrigger,
|
|
|
|
adminMonitor,
|
|
|
|
server.DemoService,
|
|
|
|
)
|
2021-04-06 10:08:43 +00:00
|
|
|
|
2019-05-24 06:04:58 +00:00
|
|
|
var roleHandler = roles.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
roleHandler.DataStore = server.DataStore
|
2019-05-24 06:04:58 +00:00
|
|
|
|
2023-04-04 00:44:42 +00:00
|
|
|
var customTemplatesHandler = customtemplates.NewHandler(requestBouncer, server.DataStore, server.FileService, server.GitService)
|
2020-07-06 23:18:39 +00:00
|
|
|
|
2020-05-14 02:14:28 +00:00
|
|
|
var edgeGroupsHandler = edgegroups.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
edgeGroupsHandler.DataStore = server.DataStore
|
2022-12-19 21:54:51 +00:00
|
|
|
edgeGroupsHandler.ReverseTunnelService = server.ReverseTunnelService
|
2020-05-14 02:14:28 +00:00
|
|
|
|
2020-06-25 03:25:51 +00:00
|
|
|
var edgeJobsHandler = edgejobs.NewHandler(requestBouncer)
|
|
|
|
edgeJobsHandler.DataStore = server.DataStore
|
|
|
|
edgeJobsHandler.FileService = server.FileService
|
|
|
|
edgeJobsHandler.ReverseTunnelService = server.ReverseTunnelService
|
|
|
|
|
2022-12-01 06:40:52 +00:00
|
|
|
var edgeStacksHandler = edgestacks.NewHandler(requestBouncer, server.DataStore, server.EdgeStacksService)
|
2020-05-14 02:14:28 +00:00
|
|
|
edgeStacksHandler.FileService = server.FileService
|
|
|
|
edgeStacksHandler.GitService = server.GitService
|
2021-09-09 08:38:34 +00:00
|
|
|
edgeStacksHandler.KubernetesDeployer = server.KubernetesDeployer
|
2020-05-14 02:14:28 +00:00
|
|
|
|
|
|
|
var edgeTemplatesHandler = edgetemplates.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
edgeTemplatesHandler.DataStore = server.DataStore
|
2020-05-14 02:14:28 +00:00
|
|
|
|
2022-05-22 05:34:09 +00:00
|
|
|
var endpointHandler = endpoints.NewHandler(requestBouncer, server.DemoService)
|
2020-05-20 05:23:15 +00:00
|
|
|
endpointHandler.DataStore = server.DataStore
|
2016-12-25 20:34:02 +00:00
|
|
|
endpointHandler.FileService = server.FileService
|
2021-01-25 19:16:53 +00:00
|
|
|
endpointHandler.ProxyManager = server.ProxyManager
|
2020-07-05 23:21:03 +00:00
|
|
|
endpointHandler.SnapshotService = server.SnapshotService
|
2021-07-14 09:15:21 +00:00
|
|
|
endpointHandler.K8sClientFactory = server.KubernetesClientFactory
|
2023-10-22 09:32:05 +00:00
|
|
|
endpointHandler.DockerClientFactory = server.DockerClientFactory
|
2019-07-25 22:38:07 +00:00
|
|
|
endpointHandler.ReverseTunnelService = server.ReverseTunnelService
|
2021-01-25 19:16:53 +00:00
|
|
|
endpointHandler.ComposeStackManager = server.ComposeStackManager
|
2021-06-16 08:15:29 +00:00
|
|
|
endpointHandler.AuthorizationService = server.AuthorizationService
|
2021-08-17 20:25:34 +00:00
|
|
|
endpointHandler.BindAddress = server.BindAddress
|
|
|
|
endpointHandler.BindAddressHTTPS = server.BindAddressHTTPS
|
2023-09-18 20:57:27 +00:00
|
|
|
endpointHandler.PendingActionsService = server.PendingActionsService
|
2020-05-14 02:14:28 +00:00
|
|
|
|
2022-04-08 14:27:38 +00:00
|
|
|
var endpointEdgeHandler = endpointedge.NewHandler(requestBouncer, server.DataStore, server.FileService, server.ReverseTunnelService)
|
2018-06-11 13:13:19 +00:00
|
|
|
|
|
|
|
var endpointGroupHandler = endpointgroups.NewHandler(requestBouncer)
|
2021-06-16 08:15:29 +00:00
|
|
|
endpointGroupHandler.AuthorizationService = server.AuthorizationService
|
2020-05-20 05:23:15 +00:00
|
|
|
endpointGroupHandler.DataStore = server.DataStore
|
2023-09-18 20:57:27 +00:00
|
|
|
endpointGroupHandler.PendingActionsService = server.PendingActionsService
|
2018-06-11 13:13:19 +00:00
|
|
|
|
|
|
|
var endpointProxyHandler = endpointproxy.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
endpointProxyHandler.DataStore = server.DataStore
|
2021-01-25 19:16:53 +00:00
|
|
|
endpointProxyHandler.ProxyManager = server.ProxyManager
|
2019-07-25 22:38:07 +00:00
|
|
|
endpointProxyHandler.ReverseTunnelService = server.ReverseTunnelService
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2022-09-21 04:49:42 +00:00
|
|
|
var kubernetesHandler = kubehandler.NewHandler(requestBouncer, server.AuthorizationService, server.DataStore, server.JWTService, server.KubeClusterAccessService, server.KubernetesClientFactory, nil)
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2023-05-29 21:36:10 +00:00
|
|
|
containerService := docker.NewContainerService(server.DockerClientFactory, server.DataStore)
|
|
|
|
|
|
|
|
var dockerHandler = dockerhandler.NewHandler(requestBouncer, server.AuthorizationService, server.DataStore, server.DockerClientFactory, containerService)
|
2022-08-11 04:33:29 +00:00
|
|
|
|
2022-04-05 04:29:57 +00:00
|
|
|
var fileHandler = file.NewHandler(filepath.Join(server.AssetsPath, "public"), adminMonitor.WasInstanceDisabled)
|
2021-08-05 03:02:06 +00:00
|
|
|
|
2022-03-21 12:51:29 +00:00
|
|
|
var endpointHelmHandler = helm.NewHandler(requestBouncer, server.DataStore, server.JWTService, server.KubernetesDeployer, server.HelmPackageManager, server.KubeClusterAccessService)
|
feat(helm/templates): helm app templates EE-943 (#5449)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm): list and configure helm chart (#5431)
* backport and tidyup code
* --amend
* using rocket icon for charts
* helm chart bugfix - clear category button
* added matomo analytics for helm chart install
* fix web editor exit warning without changes
* editor modified exit bugfix
* fixed notifications typo
* updated helm template text
* helper text to convey slow helm templates load
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* removing redundant time-consuming api call by using prop attribute
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* bugfix: kubectl shell not opening - bearer token bug
* tidy go modules & remove yarn-error.log
* removed redundant handler (not used) - to match EE
* resolved merge conflicts, updated code
* feat(helm/views): helm release and application views EE-1236 (#5529)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* removed redundant handler (not used) - to match EE
* feat(helm) display helm charts - backend EE-1236
* copy over components for new applications view EE-1236
* Add new applications datatable component
* Add more migrated files
* removed test not applicable to CE
* baclkported EE app data table code to CE
* removed redundant helm repo url
* resolved conflicts, updated code
* using endpoint middleware
* PR review fixes
* using constants, openapi updated
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* fixed test conflicts, go linted
* feat(helm/templates-add): helm templates add repo for user support EE-1278 (#5514)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* backport EE-1278, squashed, diffed, updated
* helm install openapi spec update
* resolved conflicts, updated code
* - matching ee codebase at 0afe57034449ee0e9f333d92c252a13995a93019
- helm install using endpoint middleware
- remove trailing slash from added/persisted helm repo urls
* feat(helm) use libhelm url validator and improved path assembly EE-1554 (#5561)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562 (#5567)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562
* post review changes and further backported changes from EE
* resolved conflicts, updated code
* fixed helm_install handler unit test
* user cannot add existing repo if suffix is '/' (#5571)
* feat(helm/docs) fix broken swagger docs EE-1278 (#5572)
* Fix swagger docs
* minor correction
* fix(helm): migrating code from user handler to helm handler (#5573)
* - migrated user_helm_repos to helm endpoint handler
- migrated api operations from user factory/service to helm factory/service
- passing endpointId into helm service/factory as endpoint provider is deprecated
* upgrade libhelm to hide secrets
Co-authored-by: Matt Hook <hookenz@gmail.com>
* removed duplicate file - due to merge conflict
* dependency injection in helm factory
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
* kubernetes.templates -> kubernetes.templates.helm name conflict fix
* Validate the URL added as a public helm repo (#5579)
* fix(helm): helm app deletion fix EE-1581 (#5582)
* updated helm lib to show correct error on uninstall failure
* passing down helm app namespace on deletion
* fix(k8s): EE-1591 non-admin users cannot deploy charts containing secrets (#5590)
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix(helm): helm epic bugfixes EE-1582 EE-1593 (#5585)
* - trim trailing slash and lowercase before persisting helm repo
- browser helm templates url /kubernetes/templates/templates -> /kubernetes/templates/helm
- fix publish url
- fix helm repo add refresh
- semi-fix k8s app expansion
* Tidy up swagger documentation related to helm. Make json consistent
* fixed helm release page for non-default namespaces
* k8s app view table expansion bugfix
* EE-1593: publish url load balancer fallback
Co-authored-by: Matt Hook <hookenz@gmail.com>
* k8s app list fix for charts with deployments containing multiple pods - which use the same label (#5599)
* fix(kubernetes): app list view fix for secrets with long keys or values EE-1600 (#5600)
* k8s app secrets key value text overflow ellipses
* wrapping key value pairs instead of ellipses
* fix(helm): helm apps bundling issue across different namespaces EE-1619 (#5602)
* helm apps bundling issue across different namespaces
* - code comments and indentation to ease reading
- moved namespace calc out of loop
* feat(helm/test) disable slow helm search test by default EE-1599 (#5598)
* skip helm_repo_search as it's an integration test
* switch to portainer built in integration test checker
* make module order match EE
* don't print test struct out when skipping integration test
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
Co-authored-by: cong meng <mcpacino@gmail.com>
Co-authored-by: Simon Meng <simon.meng@portainer.io>
2021-09-10 02:06:57 +00:00
|
|
|
|
2023-04-04 00:44:42 +00:00
|
|
|
var gitOperationHandler = gitops.NewHandler(requestBouncer, server.DataStore, server.GitService, server.FileService)
|
|
|
|
|
feat(helm/templates): helm app templates EE-943 (#5449)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm): list and configure helm chart (#5431)
* backport and tidyup code
* --amend
* using rocket icon for charts
* helm chart bugfix - clear category button
* added matomo analytics for helm chart install
* fix web editor exit warning without changes
* editor modified exit bugfix
* fixed notifications typo
* updated helm template text
* helper text to convey slow helm templates load
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* removing redundant time-consuming api call by using prop attribute
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* bugfix: kubectl shell not opening - bearer token bug
* tidy go modules & remove yarn-error.log
* removed redundant handler (not used) - to match EE
* resolved merge conflicts, updated code
* feat(helm/views): helm release and application views EE-1236 (#5529)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* removed redundant handler (not used) - to match EE
* feat(helm) display helm charts - backend EE-1236
* copy over components for new applications view EE-1236
* Add new applications datatable component
* Add more migrated files
* removed test not applicable to CE
* baclkported EE app data table code to CE
* removed redundant helm repo url
* resolved conflicts, updated code
* using endpoint middleware
* PR review fixes
* using constants, openapi updated
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* fixed test conflicts, go linted
* feat(helm/templates-add): helm templates add repo for user support EE-1278 (#5514)
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* feat(helm) helm chart backport from ee EE-1311 (#5436)
* Add missing defaultHelmRepoUrl and mock testing
* Backport EE-1477
* Backport updates to helm tests from EE
* add https by default changes and ssl to tls renaming from EE
* Port install integration test. Disabled by default to pass CI checks
* merged changes from EE for the integration test
* kube proxy whitelist updated to support internal helm install command
Co-authored-by: zees-dev <dev.786zshan@gmail.com>
* Pull in all changes from tech review in EE-943
* feat(helm): add helm chart backport to ce EE-1409 (#5425)
* EE-1311 Helm Chart Backport from EE
* backport to ce
Co-authored-by: Matt Hook <hookenz@gmail.com>
* Pull in all changes from tech review in EE-943
* added helm to sidebar after rebase, sync CE with EE
* backport EE-1278, squashed, diffed, updated
* helm install openapi spec update
* resolved conflicts, updated code
* - matching ee codebase at 0afe57034449ee0e9f333d92c252a13995a93019
- helm install using endpoint middleware
- remove trailing slash from added/persisted helm repo urls
* feat(helm) use libhelm url validator and improved path assembly EE-1554 (#5561)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562 (#5567)
* feat(helm/userrepos) fix getting global repo for ordinary users EE-1562
* post review changes and further backported changes from EE
* resolved conflicts, updated code
* fixed helm_install handler unit test
* user cannot add existing repo if suffix is '/' (#5571)
* feat(helm/docs) fix broken swagger docs EE-1278 (#5572)
* Fix swagger docs
* minor correction
* fix(helm): migrating code from user handler to helm handler (#5573)
* - migrated user_helm_repos to helm endpoint handler
- migrated api operations from user factory/service to helm factory/service
- passing endpointId into helm service/factory as endpoint provider is deprecated
* upgrade libhelm to hide secrets
Co-authored-by: Matt Hook <hookenz@gmail.com>
* removed duplicate file - due to merge conflict
* dependency injection in helm factory
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
* kubernetes.templates -> kubernetes.templates.helm name conflict fix
* Validate the URL added as a public helm repo (#5579)
* fix(helm): helm app deletion fix EE-1581 (#5582)
* updated helm lib to show correct error on uninstall failure
* passing down helm app namespace on deletion
* fix(k8s): EE-1591 non-admin users cannot deploy charts containing secrets (#5590)
Co-authored-by: Simon Meng <simon.meng@portainer.io>
* fix(helm): helm epic bugfixes EE-1582 EE-1593 (#5585)
* - trim trailing slash and lowercase before persisting helm repo
- browser helm templates url /kubernetes/templates/templates -> /kubernetes/templates/helm
- fix publish url
- fix helm repo add refresh
- semi-fix k8s app expansion
* Tidy up swagger documentation related to helm. Make json consistent
* fixed helm release page for non-default namespaces
* k8s app view table expansion bugfix
* EE-1593: publish url load balancer fallback
Co-authored-by: Matt Hook <hookenz@gmail.com>
* k8s app list fix for charts with deployments containing multiple pods - which use the same label (#5599)
* fix(kubernetes): app list view fix for secrets with long keys or values EE-1600 (#5600)
* k8s app secrets key value text overflow ellipses
* wrapping key value pairs instead of ellipses
* fix(helm): helm apps bundling issue across different namespaces EE-1619 (#5602)
* helm apps bundling issue across different namespaces
* - code comments and indentation to ease reading
- moved namespace calc out of loop
* feat(helm/test) disable slow helm search test by default EE-1599 (#5598)
* skip helm_repo_search as it's an integration test
* switch to portainer built in integration test checker
* make module order match EE
* don't print test struct out when skipping integration test
Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com>
Co-authored-by: Matt Hook <hookenz@gmail.com>
Co-authored-by: cong meng <mcpacino@gmail.com>
Co-authored-by: Simon Meng <simon.meng@portainer.io>
2021-09-10 02:06:57 +00:00
|
|
|
var helmTemplatesHandler = helm.NewTemplateHandler(requestBouncer, server.HelmPackageManager)
|
|
|
|
|
2021-10-06 06:24:26 +00:00
|
|
|
var ldapHandler = ldap.NewHandler(requestBouncer)
|
|
|
|
ldapHandler.DataStore = server.DataStore
|
|
|
|
ldapHandler.FileService = server.FileService
|
|
|
|
ldapHandler.LDAPService = server.LDAPService
|
|
|
|
|
2018-08-21 18:40:42 +00:00
|
|
|
var motdHandler = motd.NewHandler(requestBouncer)
|
|
|
|
|
2018-06-11 13:13:19 +00:00
|
|
|
var registryHandler = registries.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
registryHandler.DataStore = server.DataStore
|
2018-12-09 03:49:27 +00:00
|
|
|
registryHandler.FileService = server.FileService
|
2021-01-25 19:16:53 +00:00
|
|
|
registryHandler.ProxyManager = server.ProxyManager
|
2021-07-14 09:15:21 +00:00
|
|
|
registryHandler.K8sClientFactory = server.KubernetesClientFactory
|
2018-06-11 13:13:19 +00:00
|
|
|
|
|
|
|
var resourceControlHandler = resourcecontrols.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
resourceControlHandler.DataStore = server.DataStore
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2022-05-22 05:34:09 +00:00
|
|
|
var settingsHandler = settings.NewHandler(requestBouncer, server.DemoService)
|
2020-05-20 05:23:15 +00:00
|
|
|
settingsHandler.DataStore = server.DataStore
|
2018-06-11 13:13:19 +00:00
|
|
|
settingsHandler.FileService = server.FileService
|
2020-06-09 09:55:36 +00:00
|
|
|
settingsHandler.JWTService = server.JWTService
|
|
|
|
settingsHandler.LDAPService = server.LDAPService
|
2020-06-25 03:25:51 +00:00
|
|
|
settingsHandler.SnapshotService = server.SnapshotService
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2021-08-10 04:59:47 +00:00
|
|
|
var sslHandler = sslhandler.NewHandler(requestBouncer)
|
|
|
|
sslHandler.SSLService = server.SSLService
|
|
|
|
|
2022-01-23 19:48:04 +00:00
|
|
|
openAMTHandler := openamt.NewHandler(requestBouncer)
|
|
|
|
openAMTHandler.OpenAMTService = server.OpenAMTService
|
|
|
|
openAMTHandler.DataStore = server.DataStore
|
|
|
|
openAMTHandler.DockerClientFactory = server.DockerClientFactory
|
|
|
|
|
|
|
|
fdoHandler := fdo.NewHandler(requestBouncer, server.DataStore, server.FileService)
|
2021-11-29 13:06:50 +00:00
|
|
|
|
2018-06-11 13:13:19 +00:00
|
|
|
var stackHandler = stacks.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
stackHandler.DataStore = server.DataStore
|
2021-02-23 20:18:05 +00:00
|
|
|
stackHandler.DockerClientFactory = server.DockerClientFactory
|
2017-10-15 17:24:40 +00:00
|
|
|
stackHandler.FileService = server.FileService
|
2022-03-16 00:32:12 +00:00
|
|
|
stackHandler.KubernetesClientFactory = server.KubernetesClientFactory
|
2020-07-05 23:21:03 +00:00
|
|
|
stackHandler.KubernetesDeployer = server.KubernetesDeployer
|
2017-10-15 17:24:40 +00:00
|
|
|
stackHandler.GitService = server.GitService
|
2021-08-17 01:12:07 +00:00
|
|
|
stackHandler.Scheduler = server.Scheduler
|
|
|
|
stackHandler.SwarmStackManager = server.SwarmStackManager
|
|
|
|
stackHandler.ComposeStackManager = server.ComposeStackManager
|
|
|
|
stackHandler.StackDeployer = server.StackDeployer
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2021-11-03 10:41:59 +00:00
|
|
|
var storybookHandler = storybook.NewHandler(server.AssetsPath)
|
|
|
|
|
2018-06-15 07:18:25 +00:00
|
|
|
var tagHandler = tags.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
tagHandler.DataStore = server.DataStore
|
2018-06-15 07:18:25 +00:00
|
|
|
|
2018-06-11 13:13:19 +00:00
|
|
|
var teamHandler = teams.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
teamHandler.DataStore = server.DataStore
|
2018-06-11 13:13:19 +00:00
|
|
|
|
|
|
|
var teamMembershipHandler = teammemberships.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
teamMembershipHandler.DataStore = server.DataStore
|
2023-11-09 01:33:23 +00:00
|
|
|
teamMembershipHandler.K8sClientFactory = server.KubernetesClientFactory
|
2019-10-07 02:42:01 +00:00
|
|
|
|
2022-12-11 06:58:22 +00:00
|
|
|
var systemHandler = system.NewHandler(requestBouncer,
|
|
|
|
server.Status,
|
|
|
|
server.DemoService,
|
|
|
|
server.DataStore,
|
|
|
|
server.UpgradeService)
|
2018-06-11 13:13:19 +00:00
|
|
|
|
|
|
|
var templatesHandler = templates.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
templatesHandler.DataStore = server.DataStore
|
2020-07-06 23:18:39 +00:00
|
|
|
templatesHandler.FileService = server.FileService
|
|
|
|
templatesHandler.GitService = server.GitService
|
2018-06-11 13:13:19 +00:00
|
|
|
|
|
|
|
var uploadHandler = upload.NewHandler(requestBouncer)
|
|
|
|
uploadHandler.FileService = server.FileService
|
|
|
|
|
2022-06-03 04:00:13 +00:00
|
|
|
var userHandler = users.NewHandler(requestBouncer, rateLimiter, server.APIKeyService, server.DemoService, passwordStrengthChecker)
|
2020-05-20 05:23:15 +00:00
|
|
|
userHandler.DataStore = server.DataStore
|
2018-06-11 13:13:19 +00:00
|
|
|
userHandler.CryptoService = server.CryptoService
|
2023-05-04 23:45:03 +00:00
|
|
|
userHandler.AdminCreationDone = server.AdminCreationDone
|
2023-10-08 22:20:44 +00:00
|
|
|
userHandler.FileService = server.FileService
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2021-08-03 23:11:24 +00:00
|
|
|
var websocketHandler = websocket.NewHandler(server.KubernetesTokenCacheManager, requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
websocketHandler.DataStore = server.DataStore
|
2018-06-11 13:13:19 +00:00
|
|
|
websocketHandler.SignatureService = server.SignatureService
|
2019-07-25 22:38:07 +00:00
|
|
|
websocketHandler.ReverseTunnelService = server.ReverseTunnelService
|
2020-07-05 23:21:03 +00:00
|
|
|
websocketHandler.KubernetesClientFactory = server.KubernetesClientFactory
|
2016-12-18 05:21:29 +00:00
|
|
|
|
2018-09-03 10:08:03 +00:00
|
|
|
var webhookHandler = webhooks.NewHandler(requestBouncer)
|
2020-05-20 05:23:15 +00:00
|
|
|
webhookHandler.DataStore = server.DataStore
|
2018-09-03 10:08:03 +00:00
|
|
|
webhookHandler.DockerClientFactory = server.DockerClientFactory
|
|
|
|
|
2017-05-23 18:56:10 +00:00
|
|
|
server.Handler = &handler.Handler{
|
2022-12-01 06:40:52 +00:00
|
|
|
RoleHandler: roleHandler,
|
|
|
|
AuthHandler: authHandler,
|
|
|
|
BackupHandler: backupHandler,
|
|
|
|
CustomTemplatesHandler: customTemplatesHandler,
|
|
|
|
DockerHandler: dockerHandler,
|
|
|
|
EdgeGroupsHandler: edgeGroupsHandler,
|
|
|
|
EdgeJobsHandler: edgeJobsHandler,
|
|
|
|
EdgeStacksHandler: edgeStacksHandler,
|
|
|
|
EdgeTemplatesHandler: edgeTemplatesHandler,
|
|
|
|
EndpointGroupHandler: endpointGroupHandler,
|
|
|
|
EndpointHandler: endpointHandler,
|
|
|
|
EndpointHelmHandler: endpointHelmHandler,
|
|
|
|
EndpointEdgeHandler: endpointEdgeHandler,
|
|
|
|
EndpointProxyHandler: endpointProxyHandler,
|
2023-04-04 00:44:42 +00:00
|
|
|
GitOperationHandler: gitOperationHandler,
|
2022-12-01 06:40:52 +00:00
|
|
|
FileHandler: fileHandler,
|
|
|
|
LDAPHandler: ldapHandler,
|
|
|
|
HelmTemplatesHandler: helmTemplatesHandler,
|
|
|
|
KubernetesHandler: kubernetesHandler,
|
|
|
|
MOTDHandler: motdHandler,
|
|
|
|
OpenAMTHandler: openAMTHandler,
|
|
|
|
FDOHandler: fdoHandler,
|
|
|
|
RegistryHandler: registryHandler,
|
|
|
|
ResourceControlHandler: resourceControlHandler,
|
|
|
|
SettingsHandler: settingsHandler,
|
|
|
|
SSLHandler: sslHandler,
|
|
|
|
StackHandler: stackHandler,
|
|
|
|
StorybookHandler: storybookHandler,
|
2022-12-11 06:58:22 +00:00
|
|
|
SystemHandler: systemHandler,
|
2022-12-01 06:40:52 +00:00
|
|
|
TagHandler: tagHandler,
|
|
|
|
TeamHandler: teamHandler,
|
|
|
|
TeamMembershipHandler: teamMembershipHandler,
|
|
|
|
TemplatesHandler: templatesHandler,
|
|
|
|
UploadHandler: uploadHandler,
|
|
|
|
UserHandler: userHandler,
|
|
|
|
WebSocketHandler: websocketHandler,
|
|
|
|
WebhookHandler: webhookHandler,
|
2016-12-25 20:34:02 +00:00
|
|
|
}
|
|
|
|
|
2023-06-12 12:54:28 +00:00
|
|
|
errorLogger := NewHTTPLogger()
|
|
|
|
|
2022-04-05 04:29:57 +00:00
|
|
|
handler := adminMonitor.WithRedirect(offlineGate.WaitingMiddleware(time.Minute, server.Handler))
|
2023-07-05 12:25:05 +00:00
|
|
|
|
|
|
|
handler = middlewares.WithSlowRequestsLogger(handler)
|
|
|
|
|
2023-11-20 07:35:03 +00:00
|
|
|
handler, err := csrf.WithProtect(handler)
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrap(err, "failed to create CSRF middleware")
|
|
|
|
}
|
|
|
|
|
2021-08-10 04:59:47 +00:00
|
|
|
if server.HTTPEnabled {
|
|
|
|
go func() {
|
2022-09-16 16:18:44 +00:00
|
|
|
log.Info().Str("bind_address", server.BindAddress).Msg("starting HTTP server")
|
2021-08-10 04:59:47 +00:00
|
|
|
httpServer := &http.Server{
|
2023-06-12 12:54:28 +00:00
|
|
|
Addr: server.BindAddress,
|
|
|
|
Handler: handler,
|
|
|
|
ErrorLog: errorLogger,
|
2021-08-10 04:59:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
go shutdown(server.ShutdownCtx, httpServer)
|
2022-09-16 16:18:44 +00:00
|
|
|
|
2021-08-10 04:59:47 +00:00
|
|
|
err := httpServer.ListenAndServe()
|
|
|
|
if err != nil && err != http.ErrServerClosed {
|
2022-09-16 16:18:44 +00:00
|
|
|
log.Error().Err(err).Msg("HTTP server failed to start")
|
2021-08-10 04:59:47 +00:00
|
|
|
}
|
|
|
|
}()
|
2020-07-22 00:16:00 +00:00
|
|
|
}
|
|
|
|
|
2022-09-16 16:18:44 +00:00
|
|
|
log.Info().Str("bind_address", server.BindAddressHTTPS).Msg("starting HTTPS server")
|
2021-08-10 04:59:47 +00:00
|
|
|
httpsServer := &http.Server{
|
2023-01-06 19:25:41 +00:00
|
|
|
Addr: server.BindAddressHTTPS,
|
|
|
|
Handler: handler,
|
2023-06-12 12:54:28 +00:00
|
|
|
ErrorLog: errorLogger,
|
2023-01-06 19:25:41 +00:00
|
|
|
TLSNextProto: make(map[string]func(*http.Server, *tls.Conn, http.Handler)), // Disable HTTP/2
|
2017-04-25 09:51:22 +00:00
|
|
|
}
|
2021-04-06 10:08:43 +00:00
|
|
|
|
2023-02-09 19:13:35 +00:00
|
|
|
httpsServer.TLSConfig = crypto.CreateTLSConfiguration()
|
2021-08-10 04:59:47 +00:00
|
|
|
httpsServer.TLSConfig.GetCertificate = func(*tls.ClientHelloInfo) (*tls.Certificate, error) {
|
|
|
|
return server.SSLService.GetRawCertificate(), nil
|
|
|
|
}
|
2021-04-06 10:08:43 +00:00
|
|
|
|
2021-08-10 04:59:47 +00:00
|
|
|
go shutdown(server.ShutdownCtx, httpsServer)
|
2022-09-16 16:18:44 +00:00
|
|
|
|
2023-07-14 15:34:50 +00:00
|
|
|
go snapshot.NewBackgroundSnapshotter(server.DataStore, server.ReverseTunnelService)
|
|
|
|
|
2021-08-10 04:59:47 +00:00
|
|
|
return httpsServer.ListenAndServeTLS("", "")
|
2016-12-18 05:21:29 +00:00
|
|
|
}
|
2021-04-06 10:08:43 +00:00
|
|
|
|
2021-08-10 04:59:47 +00:00
|
|
|
func shutdown(shutdownCtx context.Context, httpServer *http.Server) {
|
|
|
|
<-shutdownCtx.Done()
|
2021-04-06 10:08:43 +00:00
|
|
|
|
2022-09-16 16:18:44 +00:00
|
|
|
log.Debug().Msg("shutting down the HTTP server")
|
2021-04-06 10:08:43 +00:00
|
|
|
shutdownTimeout, cancel := context.WithTimeout(context.Background(), 30*time.Second)
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
err := httpServer.Shutdown(shutdownTimeout)
|
|
|
|
if err != nil {
|
2022-09-16 16:18:44 +00:00
|
|
|
log.Error().
|
|
|
|
Err(err).
|
|
|
|
Msg("failed to shut down the HTTP server")
|
2021-04-06 10:08:43 +00:00
|
|
|
}
|
|
|
|
}
|