mirror of
https://github.com/portainer/portainer.git
synced 2025-07-21 14:29:40 +02:00
feat(k8s/applications): expose applications via ingress (#4136)
* feat(k8s/endpoint): expose ingress controllers on endpoints * feat(k8s/applications): add ability to expose applications over ingress - missing RP and app edits * feat(k8s/application): add validation for ingress routes * feat(k8s/resource-pools): edit available ingress classes * fix(k8s/ingress): var name refactor was partially applied * feat(kubernetes): double validation on RP edit * feat(k8s/application): app edit ingress update + formvalidation + UI rework * feat(k8s/ingress): dictionary for default annotations on ingress creation * fix(k8s/application): temporary fix + TODO dev notice * feat(k8s/application): select default ingress of selected resource pool * feat(k8s/ingress): revert ingressClassName removal * feat(k8s/ingress): admins can now add an host to ingress in a resource pool * feat(k8s/resource-pool): list applications using RP ingresses * feat(k8s/configure): minor UI update * feat(k8s/configure): minor UI update * feat(k8s/configure): minor UI update * feat(k8s/configure): minor UI update * feat(k8s/configure): minor UI update * fix(k8s/ingresses): remove host if undefined * feat(k8s/resource-pool): remove the activate ingresses switch * fix(k8s/resource-pool): edditing an ingress host was deleting all the routes of the ingress * feat(k8s/application): prevent app deploy if no ports to publish and publishing type not internal * feat(k8s/ingress): minor UI update * fix(k8s/ingress): allow routes without prepending / * feat(k8s/application): add form validation on ingress route Co-authored-by: Anthony Lapenna <lapenna.anthony@gmail.com>
This commit is contained in:
parent
201c3ac143
commit
f91d3f1ca3
31 changed files with 1595 additions and 443 deletions
|
@ -22,6 +22,7 @@ const _KubernetesApplicationFormValues = Object.freeze({
|
|||
DataAccessPolicy: KubernetesApplicationDataAccessPolicies.SHARED,
|
||||
Configurations: [], // KubernetesApplicationConfigurationFormValue list
|
||||
AutoScaler: {},
|
||||
OriginalIngresses: undefined,
|
||||
});
|
||||
|
||||
export class KubernetesApplicationFormValues {
|
||||
|
@ -106,18 +107,19 @@ export class KubernetesApplicationPersistedFolderFormValue {
|
|||
/**
|
||||
* KubernetesApplicationPublishedPortFormValue Model
|
||||
*/
|
||||
const _KubernetesApplicationPublishedPortFormValue = Object.freeze({
|
||||
ContainerPort: '',
|
||||
NodePort: '',
|
||||
LoadBalancerPort: '',
|
||||
LoadBalancerNodePort: undefined, // only filled to save existing loadbalancer nodePort and drop it when moving app exposure from LB to Internal/NodePort
|
||||
Protocol: 'TCP',
|
||||
});
|
||||
|
||||
export class KubernetesApplicationPublishedPortFormValue {
|
||||
constructor() {
|
||||
Object.assign(this, JSON.parse(JSON.stringify(_KubernetesApplicationPublishedPortFormValue)));
|
||||
}
|
||||
export function KubernetesApplicationPublishedPortFormValue() {
|
||||
return {
|
||||
NeedsDeletion: false,
|
||||
IsNew: true,
|
||||
ContainerPort: '',
|
||||
NodePort: '',
|
||||
LoadBalancerPort: '',
|
||||
LoadBalancerNodePort: undefined, // only filled to save existing loadbalancer nodePort and drop it when moving app exposure from LB to Internal/NodePort
|
||||
Protocol: 'TCP',
|
||||
IngressName: undefined,
|
||||
IngressRoute: undefined,
|
||||
IngressHost: undefined,
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue