@spinnaker/amazon 2026.0.3 → 2026.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/serverGroup/details/scalingPolicy/targetTracking/TargetTrackingAdditionalSettings.d.ts +1 -1
- package/package.json +3 -3
- package/src/deploymentStrategy/rollingPush.strategy.ts +1 -1
- package/src/pipeline/stages/deployLambda/components/function.constants.ts +17 -17
- package/src/serverGroup/details/scalingPolicy/targetTracking/TargetTrackingAdditionalSettings.tsx +1 -1
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import*as e from"angular";import{module as t}from"angular";import{SETTINGS as a,HelpField as n,DeploymentStrategyRegistry as r,FormValidator as i,FormikFormField as s,TextInput as l,AccountService as o,ReactSelectInput as c,CheckboxInput as d,MapEditorInput as u,NumberInput as p,NetworkReader as m,SubnetReader as g,ReactInjector as h,TetheredSelect as f,TaskMonitor as v,FunctionWriter as y,ReactModal as b,WizardModal as E,WizardPage as w,noop as C,ConfirmationModalService as S,ApplicationReader as k,AddEntityTagLinks as N,ReactInject as T,Details as I,AccountTag as G,Overrides as A,CollapsibleSection as x,HelpContentsRegistry as P,REST as D,LabeledValue as B,timestamp as z,useData as F,SubnetTag as M,withErrorBoundary as L,InstanceWriter as R,TaskExecutor as O,CloudProviderRegistry as V,FirewallLabels as U,RecentHistoryService as q,InstanceReader as H,LabeledValueList as W,LinkWithClipboard as j,robotToHuman as Z,Tooltip as _,InstanceLoadBalancerHealth as K,LoadBalancerServerGroup as Y,HealthCounts as X,LoadBalancerInstances as J,LoadBalancerClusterContainer as Q,logger as ee,LoadBalancerDataUtils as te,Spinner as ae,HoverablePopover as ne,NameUtils as re,Overridable as ie,relativeTime as se,SpinFormik as le,ModalClose as oe,SubmitButton as ce,SelectInput as de,CertificateReader as ue,ValidationMessage as pe,CustomLabels as me,Validators as ge,spelNumberCheck as he,SpInput as fe,SpelNumberInput as ve,ChecklistInput as ye,useDeepObjectDiff as be,useMountStatusRef as Ee,createFakeReactSyntheticEvent as we,Markdown as Ce,AccountSelectInput as Se,RegionSelectField as ke,InfrastructureCaches as Ne,LoadBalancerWriter as Te,ManagedMenuItem as Ie,SECURITY_GROUP_READER as Ge,LOAD_BALANCER_READ_SERVICE as Ae,MANAGED_RESOURCE_DETAILS_INDICATOR as xe,APPLICATION_STATE_PROVIDER as Pe,Registry as De,BakeExecutionLabel as Be,AuthenticationService as ze,PipelineTemplates as Fe,BakeryReader as Me,StageConstants as $e,AppListExtractor as Le,ExecutionDetailsSection as Re,StageFailureMessage as Oe,ExecutionDetailsTasks as Ve,FormikStageConfig as Ue,StageConfigField as qe,yamlDocumentsToString as He,ExecutionStepDetails as We,NgGenericArtifactDelegate as je,ExpectedArtifactSelectorViewController as Ze,ExecutionBarLabel as _e,ExpectedArtifactService as Ke,ArtifactReferenceService as Ye,EXECUTION_SERVICE as Xe,TetheredCreatable as Je,excludeAllTypesExcept as Qe,ArtifactTypePatterns as et,StageArtifactSelectorDelegate as tt,PipelineConfigService as at,ModalWizard as nt,SecurityGroupWriter as rt,filterObjectValues as it,CACHE_INITIALIZER_SERVICE as st,confirmNotManaged as lt,DeployInitializer as ot,DeployingIntoManagedClusterWarning as ct,ServerGroupDetailsField as dt,DeploymentStrategySelector as ut,ServerGroupNamePreview as pt,TaskReason as mt,parseNum as gt,ToggleButtonGroup as ht,ToggleSize as ft,usePrevious as vt,NgReact as yt,PlatformHealthOverride as bt,MapEditor as Et,UserVerification as wt,TaskMonitorWrapper as Ct,MinMaxDesiredChanges as St,ServerGroupWarningMessageService as kt,ModalInjector as Nt,ClusterTargetBuilder as Tt,ServerGroupReader as It,CloudMetricsReader as Gt,TaskMonitorModal as At,EntitySource as xt,ViewChangesLink as Pt,CapacityDetailsSection as Dt,ViewScalingActivitiesLink as Bt,ShowUserData as zt,SERVER_GROUP_COMMAND_REGISTRY_PROVIDER as Ft,setMatchingResourceSummary as Mt,INSTANCE_TYPE_SERVICE as $t,SERVER_GROUP_WRITER as Lt,ApplicationNameValidator as Rt}from"@spinnaker/core";import*as Ot from"react";import Vt,{useState as Ut,useEffect as qt}from"react";import Ht,{isEmpty as Wt,forOwn as jt,uniqBy as Zt,cloneDeep as _t,flatten as Kt,isNil as Yt,orderBy as Xt,isEqual as Jt,sortBy as Qt,filter as ea,chain as ta,map as aa,pickBy as na,groupBy as ra,get as ia,uniq as sa,difference as la,some as oa,isNumber as ca,set as da,partition as ua,every as pa,values as ma,head as ga,extend as ha,isString as fa,intersection as va,keyBy as ya,find as ba,flatMap as Ea,has as wa,clone as Ca,keys as Sa,xor as ka}from"lodash";import Na from"classnames";import{Subject as Ta,from as Ia,combineLatest as Ga,BehaviorSubject as Aa,of as xa,Observable as Pa}from"rxjs";import{map as Da,distinctUntilChanged as Ba,shareReplay as za,switchMap as Fa,withLatestFrom as Ma,takeUntil as $a,tap as La,mergeMap as Ra,catchError as Oa,debounceTime as Va,take as Ua}from"rxjs/operators";import{Dropdown as qa,Modal as Ha,Button as Wa,Tooltip as ja,OverlayTrigger as Za,Checkbox as _a,ModalFooter as Ka,MenuItem as Ya}from"react-bootstrap";import{$q as Xa}from"ngimport";import{react2angular as Ja}from"react2angular";import{UISref as Qa,UISrefActive as en}from"@uirouter/react";import{UIRouterContextComponent as tn}from"@uirouter/react-hybrid";import an from"@uirouter/angularjs";import nn from"angular-ui-bootstrap";import rn from"react-select";import{SortableHandle as sn,arrayMove as ln,SortableElement as on,SortableContainer as cn}from"react-sortable-hoc";import{Form as dn,Field as un}from"formik";import pn from"react-virtualized-select";import{Chart as mn,LineController as gn,LineElement as hn,PointElement as fn,LinearScale as vn,Title as yn,TimeScale as bn,Tooltip as En,Legend as wn,Filler as Cn}from"chart.js";import"chartjs-adapter-luxon";var Sn;const kn=a.providers.aws||{defaults:{}};kn&&(kn.adHocInfraWritesEnabled=null==(Sn=kn.adHocInfraWritesEnabled)||Sn,kn.resetToOriginal=a.resetProvider("aws"));const Nn={bindings:{action:"&",isValid:"&",cancel:"&",account:"=?",verification:"=?"},template:'\n <div class="modal-footer">\n <user-verification account="$ctrl.account" verification="$ctrl.verification"></user-verification>\n <button type="submit" ng-click="$ctrl.action()" style="display:none"></button> \x3c!-- Allows form submission via enter keypress--\x3e\n <button class="btn btn-default" ng-click="$ctrl.cancel()">Cancel</button>\n <button type="submit"\n class="btn btn-primary"\n ng-click="$ctrl.action()"\n ng-disabled="!$ctrl.isValid()">\n Submit\n </button>\n </div>\n ',controller:()=>{}},Tn="spinnaker.amazon.footer";t(Tn,[]).component("awsFooter",Nn);const In="spinnaker.amazon.common";t(In,[Tn]);class Gn extends Vt.Component{constructor(){super(...arguments),this.handleChange=(e,t)=>{this.props.command.termination[e]=t,this.forceUpdate()}}render(){var e;const{command:t}=this.props;return Vt.createElement("div",{className:"form-group",style:{marginTop:"20px"}},Vt.createElement("div",{className:"well-compact alert alert-warning"},Vt.createElement("strong",null,"Note:")," a rolling push only updates the"," ",Vt.createElement("em",null,"launch ",Boolean(null==(e=kn.serverGroups)?void 0:e.enableLaunchTemplates)?"template":"configuration")," ","for the auto scaling group.",Vt.createElement("br",null)," Changes to the following fields will be ignored:",Vt.createElement("ul",null,Vt.createElement("li",null,"Account, Region, Subnet Type"),Vt.createElement("li",null,"Capacity"),Vt.createElement("li",null,"Load Balancers"),Vt.createElement("li",null,"Health Check Configuration"),Vt.createElement("li",null,"Termination Policies, Enable Traffic flag"))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:t.termination.relaunchAllInstances,onChange:e=>this.handleChange("relaunchAllInstances",e.target.checked)}),Vt.createElement("b",null,"Relaunch all instances"),Vt.createElement(n,{id:"strategy.rollingPush.relaunchAll"})))),!t.termination.relaunchAllInstances&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},"Total relaunches",Vt.createElement(n,{id:"strategy.rollingPush.totalRelaunches"})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{className:"form-control input-sm",type:"number",value:t.termination.totalRelaunches,onChange:e=>this.handleChange("totalRelaunches",e.target.value),min:"0"}))),(t.termination.totalRelaunches>0||t.termination.relaunchAllInstances)&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},"Concurrent relaunches",Vt.createElement(n,{id:"strategy.rollingPush.concurrentRelaunches"})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{className:"form-control input-sm",type:"number",value:t.termination.concurrentRelaunches,onChange:e=>this.handleChange("concurrentRelaunches",e.target.value),min:"1"}))),(t.termination.totalRelaunches>0||t.termination.relaunchAllInstances)&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},"Order",Vt.createElement(n,{id:"strategy.rollingPush.order"})),Vt.createElement("div",{className:"col-md-3"},Vt.createElement("select",{className:"input input-sm",style:{width:"100px"},value:t.termination.order,onChange:e=>this.handleChange("order",e.target.value)},Vt.createElement("option",{value:"oldest"},"oldest first"),Vt.createElement("option",{value:"newest"},"newest first")))))}}var An;r.registerStrategy({label:"Rolling Push (not recommended)",description:`Updates the launch ${(null==(An=kn.serverGroups)?void 0:An.enableLaunchTemplates)?"template":"configuration"} for this server group, then terminates instances incrementally,\n replacing them with instances launched with the updated configuration. This is not a best practice - it goes against\n the principles of immutable infrastructure - but may be necessary in some cases.`,key:"rollingpush",providerRestricted:!0,additionalFields:["termination.totalRelaunches","termination.concurrentRelaunches","termination.order","termination.relaunchAllInstances"],AdditionalFieldsComponent:Gn,initializationMethod:e=>{var t,a;e.termination=e.termination||{order:"oldest",relaunchAllInstances:!0,concurrentRelaunches:1,totalRelaunches:null!=(a=Number(null==(t=null==e?void 0:e.capacity)?void 0:t.max))?a:1}}});class xn{constructor(){this.convertFunctionForEditing=e=>({...e,envVariables:e.environment?e.environment.variables:{},credentials:e.account,tracingConfig:{mode:e.tracingConfig?e.tracingConfig.mode:""},deadLetterConfig:{targetArn:e.deadLetterConfig?e.deadLetterConfig.targetArn:""},KMSKeyArn:e.kmskeyArn?e.kmskeyArn:"",subnetIds:e.vpcConfig?e.vpcConfig.subnetIds:[],securityGroupIds:e.vpcConfig?e.vpcConfig.securityGroupIds:[],vpcId:e.vpcConfig?e.vpcConfig.vpcId:"",operation:"",cloudProvider:e.cloudProvider,region:e.region,targetGroups:Wt(e.targetGroups)?"":e.targetGroups})}normalizeFunction(e){const t=e;return t.credentials=e.account,t}constructNewAwsFunctionTemplate(e){return{role:"",runtime:"",s3bucket:"",s3key:"",handler:"",functionName:"",publish:!1,tags:{},memorySize:128,description:"",credentials:e.defaultCredentials.aws||kn.defaults.account,cloudProvider:"aws",detail:"",region:e.defaultRegions.aws||kn.defaults.region,envVariables:{},tracingConfig:{mode:"PassThrough"},kmskeyArn:"",vpcId:"",subnetIds:[],securityGroupIds:[],timeout:3,deadLetterConfig:{targetArn:""},operation:"",targetGroups:""}}}const Pn=(e,t)=>e.match(/^arn:aws:iam::\d{12}:role\/?\/[a-zA-Z_0-9+=,.@\-/]+/)?void 0:`Invalid role. ${t} must match regular expression: arn:aws:iam::d{12}:role/?[a-zA-Z_0-9+=,.@-_/]+`,Dn=(e,t)=>e.match(/^[0-9A-Za-z.-]*[^.]$/)?void 0:`Invalid S3 Bucket name. ${t} must match regular expression: [0-9A-Za-z.-]*[^.]$`,Bn=(e,t)=>e.match(/arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./)?void 0:`Invalid ARN. ${t} must match regular expression: /arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./`,zn=(e,t)=>Wt(e)?`At least one ${t} is required`:void 0,Fn=(e,t)=>e.match(/^[0-9A-Za-z]*$/)?void 0:`Invalid String Value. ${t} must match regular expression: [0-9A-Za-z]`;class Mn extends Vt.Component{constructor(e){super(e)}validate(e){const t=new i(e);return t.field("role","Role ARN").required().withValidators(Pn),t.validateForm()}render(){return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-11"},Vt.createElement("div",{className:"sp-margin-m-bottom"},Vt.createElement(s,{name:"role",label:"Role ARN",input:e=>Vt.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"}),required:!0}))))}}const $n=["nodejs12.x","nodejs14.x","nodejs16.x","nodejs18.x","java8","java8.al2","java11","java17","python3.7","python3.8","python3.9","python3.10","dotnetcore3.1","dotnet7","dotnet6","dotnet5.0","go1.x","ruby2.7","provided","provided.al2"],Ln="(Optional) Stack is naming components of a function, used to create vertical stacks of dependent services for integration testing.",Rn="(Optional) Detail is a string of free-form alphanumeric characters to describe any other variables in naming a function.";class On extends Vt.Component{constructor(){super(...arguments),this.state={accounts:[],existingFunctionNames:[],regions:[]},this.props$=new Ta,this.destroy$=new Ta}validate(e){const t=new i(e);t.field("s3bucket","S3 Bucket Name").optional().withValidators(Dn);const a=t.validateForm();return this.props.isNew&&this.state.existingFunctionNames.includes(this.props.app.name.concat("-").concat(e.functionName))&&(a.functionName=`There is already a function in ${e.credentials}:${e.region} with that name.`),a}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}componentDidMount(){const e=this.props$.pipe(Da((e=>e.formik.values))),t={account$:e.pipe(Da((e=>e.credentials)),Ba()),region$:e.pipe(Da((e=>e.region)),Ba()),functionName$:e.pipe(Da((e=>e.functionName)),Ba()),runtime$:e.pipe(Da((e=>e.runtime)),Ba()),s3bucket$:e.pipe(Da((e=>e.s3bucket)),Ba()),s3key$:e.pipe(Da((e=>e.s3key)),Ba()),handler$:e.pipe(Da((e=>e.handler)),Ba())},a=Ia(o.listAccounts("aws")).pipe(za(1)),n=Ga([t.account$,a]).pipe(Fa((([e,t])=>o.getRegionsForAccount(e))),za(1)),r=this.props.app.getDataSource("functions").data$,i=Ga([r,t.account$,t.region$]).pipe(Da((([e,t,a])=>e.filter((e=>e.account===t&&e.region===a)).map((e=>e.functionName)))),za(1));n.pipe(Ma(t.region$),$a(this.destroy$)).subscribe((([e,t])=>{e.some((e=>e.name===t))||this.props.formik.setFieldValue("region",e[0]&&e[0].name)})),Ga([a,n,i]).pipe($a(this.destroy$)).subscribe((([e,t,a])=>this.setState({accounts:e,regions:t,existingFunctionNames:a})))}render(){const{isNew:e}=this.props,{errors:t,values:a}=this.props.formik,{accounts:r,regions:i}=this.state,o=Na({well:!0,"alert-danger":!!t.functionName,"alert-info":!t.functionName});return Vt.createElement("div",{className:"container-fluid form-horizontal "},e&&Vt.createElement("div",{className:o},Vt.createElement("strong",null,"Your function will be named: "),Vt.createElement(n,{id:"aws.function.name"}),Vt.createElement("span",null,this.props.app.name,"-",a.functionName),Vt.createElement(s,{name:"functionName",input:()=>null})),Vt.createElement(s,{name:"credentials",label:"Account",input:e=>Vt.createElement(c,{...e,stringOptions:r.map((e=>e.name)),clearable:!0})}),Vt.createElement(s,{name:"region",label:"Region",input:e=>Vt.createElement(c,{...e,stringOptions:i.map((e=>e.name)),clearable:!0})}),Vt.createElement(s,{name:"functionName",label:"Function Name",help:Vt.createElement(n,{id:"aws.function.name"}),input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"runtime",label:"Runtime",help:Vt.createElement(n,{id:"aws.function.runtime"}),input:e=>Vt.createElement(c,{...e,stringOptions:$n,clearable:!0})}),Vt.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Vt.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Vt.createElement(l,{...e,placeholder:"S3 bucket name"})}),Vt.createElement(s,{name:"s3key",label:"S3 Key",help:Vt.createElement(n,{id:"aws.function.s3key"}),input:e=>Vt.createElement(l,{...e,placeholder:"object.zip"})}),Vt.createElement(s,{name:"handler",label:"Handler",help:Vt.createElement(n,{id:"aws.function.handler"}),input:e=>Vt.createElement(l,{...e,placeholder:"filename.method"})}),Vt.createElement(s,{name:"publish",label:"Publish",input:e=>Vt.createElement(d,{...e})}))}}class Vn extends Vt.Component{constructor(e){super(e),this.validate=e=>{const t=new i(e);return t.field("deadLetterConfig.targetArn","Target ARN").optional().withValidators(Bn),t.validateForm()}}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},"Dead Letter Config",Vt.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Vt.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Vt.createElement(l,{...e})}),"X-Ray Tracing",Vt.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Vt.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Vt.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}}class Un extends Vt.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("kmskeyArn","KMS Key ARN").optional().withValidators(Bn),t.validateForm()}}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},Vt.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Vt.createElement(s,{name:"kmskeyArn",label:"Key ARN",help:Vt.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Vt.createElement(l,{...e})}))}}class qn extends Vt.Component{constructor(){super(...arguments),this.validate=()=>({})}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},Vt.createElement(s,{name:"description",label:"Description",input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Vt.createElement(p,{...e,min:128,max:3008})}),Vt.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Vt.createElement(p,{...e,min:1,max:900})}),Vt.createElement(s,{name:"targetGroups",label:"Target Group Name",input:e=>Vt.createElement(l,{...e})}))}}class Hn extends Vt.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("tags","Tag").required().withValidators(zn),t.validateForm()}}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},Vt.createElement(s,{name:"tags",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}))}}class Wn{static listVpcs(){return this.cache||(this.cache=m.listNetworksByProvider("aws").then((e=>e.map((e=>(e.label=e.name,e.deprecated=!!e.deprecated,e.deprecated&&(e.label+=" (deprecated)"),e)))))),this.cache}static resetCache(){this.cache=null}static getVpcName(e){return this.listVpcs().then((t=>{const a=t.find((t=>t.id===e));return a?a.name:null}))}}class jn extends Vt.Component{constructor(e){super(e),this.state={vpcOptions:[],accounts:null,regions:[],subnets:[],availableSubnets:[],securityGroups:null},this.props$=new Ta,this.destroy$=new Ta,this.handleSubnetUpdate=e=>{const t=e.map((e=>e.value));this.props.formik.setFieldValue("subnetIds",t)},this.handleSecurityGroupsUpdate=e=>{const t=e.map((e=>e.value));this.props.formik.setFieldValue("securityGroupIds",t)},this.setVpc=e=>{this.props.formik.setFieldValue("vpcId",e),this.props.formik.setFieldValue("subnetIds",[]);const{availableSubnets:t}=this.state,a=t.filter((function(t){return t.vpcId.includes(e)}));this.setState({subnets:a})},this.toSubnetOption=e=>({value:e.subnetId,label:e.subnetId}),this.getSecurityGroupsByVpc=e=>{const{values:t}=this.props.formik,a=[];return jt(e,(function(e,n){n===t.credentials&&jt(e,(function(e,n){"aws"===n&&jt(e,(function(e,n){n===t.region&&e.forEach((function(e){e.vpcId===t.vpcId&&a.push({value:e.id,label:e.name})}))}))}))})),a},this.getSubnetOptions=()=>{const{subnets:e,availableSubnets:t}=this.state,{values:a}=this.props.formik;return!this.props.isNew&&a.vpcId?t.filter((function(e){return e.vpcId.includes(a.vpcId)})).map(this.toSubnetOption):e.map(this.toSubnetOption)},this.getAllVpcs()}getAllVpcs(){Ia(Wn.listVpcs()).pipe($a(this.destroy$)).subscribe((e=>{this.setState({vpcOptions:e})}))}validate(){return{}}getAvailableSubnets(){return g.listSubnetsByProvider("aws")}getAvailableSecurityGroups(){return h.securityGroupReader.getAllSecurityGroups()}makeSubnetOptions(e){const t=e.map((e=>({subnetId:e.id,vpcId:e.vpcId})));return Zt(t,"subnetId")}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}componentDidMount(){const e=Promise.resolve(this.getAvailableSubnets()).then((e=>(e.forEach((e=>{e.label=e.id,e.deprecated=!!e.deprecated,e.deprecated&&(e.label+=" (deprecated)")})),e.filter((e=>e.label))))).then((e=>this.makeSubnetOptions(e))),t=Promise.resolve(this.getAvailableSecurityGroups());Ga([e,t]).pipe($a(this.destroy$)).subscribe((([e,t])=>this.setState({availableSubnets:e,securityGroups:t})))}render(){const{vpcOptions:e,securityGroups:t}=this.state,{values:a}=this.props.formik,r=this.getSubnetOptions(),i=t?this.getSecurityGroupsByVpc(t):[];return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-11"},Vt.createElement("div",{className:"sp-margin-m-bottom"},a.credentials&&Vt.createElement(s,{name:"vpcId",label:"VPC Id",help:Vt.createElement(n,{id:"aws.function.vpc.id"}),input:t=>Vt.createElement(c,{...t,stringOptions:e.filter((e=>e.account===a.credentials)).map((e=>e.id)),clearable:!0}),onChange:this.setVpc,required:!1})),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Subnets "),Vt.createElement(n,{id:"aws.function.subnet"})),Vt.createElement("div",{className:"col-md-7"},0===r.length&&Vt.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC"),a.vpcId?Vt.createElement(f,{multi:!0,options:r,value:a.subnetIds,onChange:this.handleSubnetUpdate}):null)),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Security Groups "),Vt.createElement(n,{id:"aws.function.subnet"})),Vt.createElement("div",{className:"col-md-7"},0===i.length&&Vt.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC"),a.credentials&&a.vpcId?Vt.createElement(f,{multi:!0,options:i,value:a.securityGroupIds,onChange:this.handleSecurityGroupsUpdate}):null))))}}const Zn=class extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.submit=e=>{const{app:t}=this.props,{isNew:a}=this.state,n=_t(e),r=a?"Create":"Update",i=new v({application:t,title:(a?"Creating":"Updating")+" your function",modalInstance:v.modalInstanceEmulation((()=>this.props.dismissModal())),onTaskComplete:()=>{this.checkForS3Update(n,r)}});i.submit((()=>(n.type="lambdaFunction",n.operation=a?"createLambdaFunction":"updateLambdaFunctionConfiguration",y.upsertFunction(n,t,r)))),this.setState({taskMonitor:i})};const t=new xn,a=e.functionDef?t.convertFunctionForEditing(e.functionDef):t.constructNewAwsFunctionTemplate(e.app);this.state={isNew:!e.functionDef,functionCommand:a,taskMonitor:null}}static show(e){return b.show(Zn,e,{dialogClassName:"wizard-modal modal-lg"})}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.functionDetails")?h.$state.go("^.functionDetails",t):h.$state.go(".functionDetails",t)}onTaskComplete(e){this.props.app.functions.refresh(),this.refreshUnsubscribe=this.props.app.functions.onNextRefresh(null,(()=>this.onApplicationRefresh(e)))}checkForS3Update(e,t){const{isNew:a}=this.state;if(!a&&(e.s3bucket||e.s3key)){e.operation="updateLambdaFunctionCode";const{app:a}=this.props;y.upsertFunction(e,a,t)}this.onTaskComplete(e)}render(){const{app:e,dismissModal:t,forPipelineConfig:a,functionDef:n}=this.props,{isNew:r,functionCommand:i,taskMonitor:s}=this.state;let l=a?"Configure Existing Function":"Create New Function";return r||(l=`Edit ${i.functionName}: ${i.region}: ${i.credentials}`),Vt.createElement(E,{heading:l,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",render:({formik:t,nextIdx:a,wizard:i})=>Vt.createElement(Vt.Fragment,null,Vt.createElement(w,{label:"Basic information",wizard:i,order:a(),render:({innerRef:a})=>Vt.createElement(On,{ref:a,app:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Execution Role",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Mn,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Environment",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Un,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Tags",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Hn,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Settings",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(qn,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Network",wizard:i,order:a(),render:({innerRef:a})=>Vt.createElement(jn,{ref:a,app:e,formik:t,isNew:r})}),Vt.createElement(w,{label:"Debugging and Error Handling",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Vn,{ref:e,formik:t,isNew:r,functionDef:n})}))})}};let _n=Zn;_n.defaultProps={closeModal:C,dismissModal:C};class Kn extends Vt.Component{constructor(e){super(e),this.editFunction=()=>{const{functionDef:e}=this.props,{application:t}=this.state;_n.show({app:t,functionDef:e})},this.deleteFunction=()=>{const{app:e,functionDef:t,functionFromParams:a}=this.props,n={application:e,title:"Deleting "+a.functionName},r={cloudProvider:t.cloudProvider,functionName:t.functionName,region:t.region,credentials:t.credentials};S.confirm({header:`Really delete ${a.functionName} in ${a.region}: ${a.account}?`,buttonText:`Delete ${a.functionName}`,account:a.account,taskMonitorConfig:n,submitMethod:()=>y.deleteFunction(r,e)})},this.entityTagUpdate=()=>{this.props.app.functions.refresh()},this.state={application:e.app}}componentDidMount(){const{app:e,functionDef:t}=this.props;let a;const n=t.functionName.split("-")[0];n===e.name?a=e:k.getApplication(n).then((e=>{this.setState({application:e})})).catch((()=>{this.setState({application:this.props.app})})),this.setState({application:a})}render(){const{app:e,functionDef:t}=this.props,{application:n}=this.state;return Vt.createElement("div",{style:{display:"inline-block"}},kn.adHocInfraWritesEnabled&&Vt.createElement(qa,{className:"dropdown",id:"function-actions-dropdown"},Vt.createElement(qa.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Vt.createElement("span",null,"Function Actions")),Vt.createElement(qa.Menu,{className:"dropdown-menu"},Vt.createElement("li",{className:n?"":"disabled"},Vt.createElement("a",{className:"clickable",onClick:this.editFunction},"Edit Function")),t.functionName&&Vt.createElement("li",null,Vt.createElement("a",{className:"clickable",onClick:this.deleteFunction},"Delete Function")),a&&a.feature.entityTags&&Vt.createElement(N,{component:t,application:e,entityType:"function",onUpdate:this.entityTagUpdate}))))}}class Yn extends T{get awsInstanceTypeService(){return this.$injector.get("awsInstanceTypeService")}get awsServerGroupCommandBuilder(){return this.$injector.get("awsServerGroupCommandBuilder")}get awsServerGroupConfigurationService(){return this.$injector.get("awsServerGroupConfigurationService")}get awsServerGroupTransformer(){return this.$injector.get("awsServerGroupTransformer")}get functionReader(){return this.$injector.get("functionReader")}get evaluateCloudFormationChangeSetExecutionService(){return this.$injector.get("evaluateCloudFormationChangeSetExecutionService")}initialize(e){this.$injector=e}}const Xn=new Yn;var Jn=Object.defineProperty,Qn=Object.getOwnPropertyDescriptor;let er=class extends Vt.Component{constructor(e){super(e),this.destroy$=new Ta,this.state={loading:!0}}extractFunction(){const{app:e,functionObj:t}=this.props;e.functions.data.find((e=>e.functionName===t.functionName&&e.region===t.region&&e.account===t.account))?Ia(Xn.functionReader.getFunctionDetails("aws",t.account,t.region,t.functionName)).pipe($a(this.destroy$)).subscribe((e=>{e.length&&this.setState({functionDef:e[0],loading:!1})})):this.setState({functionDef:{},loading:!1})}componentDidMount(){const{app:e}=this.props,t=e.functions;Ia(t.ready()).pipe($a(this.destroy$)).subscribe((()=>{const e=t.onRefresh(null,(()=>this.extractFunction()));this.setState({dataSourceUnsubscribe:e}),this.extractFunction()}))}componentWillUnmount(){this.state.dataSourceUnsubscribe&&this.state.dataSourceUnsubscribe(),this.destroy$.next()}render(){const{app:e}=this.props,{loading:t,functionDef:a}=this.state;if(t)return Vt.createElement(I,{loading:t});const n=Vt.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Last Modified "),Vt.createElement("dd",null,a.lastModified),Vt.createElement("dt",null,"In"),Vt.createElement("dd",null,Vt.createElement(G,{account:a.account})," ",a.region),Vt.createElement("dt",null,"VPC"),Vt.createElement("dd",null,a.vpcConfig?a.vpcConfig.vpcId:"Default"),Vt.createElement("dt",null,"Function ARN"),Vt.createElement("dd",null,a.functionArn),Vt.createElement("dt",null,"Revision ID"),Vt.createElement("dd",null,a.revisionId),Vt.createElement("dt",null,"Version"),Vt.createElement("dd",null,a.version)),r=Vt.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.eventSourceMappings&&0!==a.eventSourceMappings.length?a.eventSourceMappings.map((e=>Vt.createElement(Vt.Fragment,null,Vt.createElement("h5",null,Vt.createElement("strong",null,"Event Source")),Vt.createElement("dl",null,Vt.createElement("dt",null,"ARN"),Vt.createElement("dd",null,e.eventSourceArn),Vt.createElement("dt",null,"State"),Vt.createElement("dd",null,e.state))))):"None"),i=Vt.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.aliasConfigurations&&0!==a.aliasConfigurations.length?a.aliasConfigurations.map((e=>Vt.createElement(Vt.Fragment,null,Vt.createElement("h5",null,Vt.createElement("strong",null,"Alias Details")),Vt.createElement("dl",null,Vt.createElement("dt",null,"Name"),Vt.createElement("dd",null,e.name),Vt.createElement("dt",null,"ARN"),Vt.createElement("dd",null,e.aliasArn))))):"None"),s=Vt.createElement(x,{heading:"Function Details"},n),l=Vt.createElement(x,{heading:"Event Source Details"},r),o=Vt.createElement(x,{heading:"Alias Configuration Details"},i);return Vt.createElement(I,{loading:this.state.loading},Wt(this.state.functionDef)?"Function not found.":Vt.createElement(I.Header,{icon:Vt.createElement("i",{className:"fa fa-xs fa-fw fa-asterisk"}),name:this.state.functionDef.functionName},Vt.createElement("div",{className:"actions"},Vt.createElement(Kn,{app:e,functionDef:a,functionFromParams:{account:this.state.functionDef.account,region:this.state.functionDef.region,functionName:this.state.functionDef.functionName}}))),Wt(this.state.functionDef)?"":s,Wt(this.state.functionDef)||Wt(this.state.functionDef.eventSourceMappings)?"":l,Wt(this.state.functionDef)||Wt(this.state.functionDef.aliasConfigurations)?"":o)}};er=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Qn(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&Jn(t,a,i),i})([A("function.details","aws")],er);const tr="spinnaker.amazon.function";t(tr,[]);const ar={"aws.associateElasticIp.elasticIp":"<p>(Optional) <b>Elastic IP</b> is an IP address that Spinnaker will associate with this cluster.</p>\n <p>If specified, this elastic IP must exist and not already be attached to an instance or cluster.</p>\n <p>If left blank, Spinnaker will make a selection from the list of available elastic IPs in the provided account and region.</p>","aws.associateElasticIp.type":"<p><b>Type</b> of elastic IP to associate:'\n <ul>\n <li><b>standard</b> is usable in EC2 Classic</li>\n <li><b>vpc</b> is usable in VPC</li>\n </ul>","aws.serverGroup.subnet":"The subnet selection determines the VPC in which your server group will run. Options vary by account and region; the most common ones are:\n <ul>\n <li><b>None (EC2 Classic)</b>: instances will not run in a VPC</li>\n <li><b>internal</b> instances will be restricted to internal clients (i.e. require VPN access)</li>\n <li><b>external</b> instances will be publicly accessible and running in VPC</li>\n </ul>","aws.loadBalancer.subnet":"The subnet selection determines the VPC in which your load balancer will run.<br/>\n This also restricts the server groups which can be serviced by the load balancer.\n Options vary by account and region; the most common ones are:\n <ul>\n <li><b>None (EC2 Classic)</b>: the load balancer will not run in a VPC</li>\n <li><b>internal</b> access to the load balancer will be restricted to internal clients (i.e. require VPN access)</li>\n <li><b>external</b> the load balancer will be publicly accessible and running in VPC</li>\n </ul>","aws.loadBalancer.detail":'<p>(Optional) <b>Detail</b> is a string of free-form alphanumeric characters; by convention, we recommend using "frontend".</p>\n <p>However, if your stack name needs to be longer (load balancer names are limited to 32 characters), consider changing it to "elb", or omit it altogether.</p>',"aws.loadBalancer.internal":"Controls the load balancer scheme, <strong>not</strong> the subnet. By default, load balancers are created with a DNS name that resolves to public IP addresses. Specify internal to create a load balancer with a DNS name that resolves to private IP addresses.","aws.loadBalancer.stack":"(Optional) <b>Stack</b> is one of the core naming components of a cluster, used to create vertical stacks of dependent services for integration testing.","aws.loadBalancer.name":"<p>The load balancer name is formed by combining the application name, the <b>Stack</b> field, and the <b>Detail</b> field.</p>","aws.loadBalancer.targetGroups":"Add a target group if you want to associate this with an Application Load Balancer (ALB) or Network Load Balancer (NLB)","aws.loadBalancer.loadBalancers":"Add a load balancer directly if you created a Classic Load Balancer (a classic load balancer does not have target groups)","aws.loadBalancer.ruleCondition.host":"<p>You can specify a single host name (for example, <em>my.example.com</em>). A host name is case insensitive, can be up to 128 characters in length, and can contain any of the following characters. Note that you can include up to three wildcard characters.</p>\n <ul>\n <li>A-Z, a-z, 0-9</li>\n <li>- .</li>\n <li>* (matches 0 or more characters)</li>\n <li>? (matches exactly 1 character)</li>\n </ul>\n <p>Note that <strong>*.example.com</strong> will match <strong>test.example.com</strong> but won't match <strong>example.com</strong>.</p>","aws.loadBalancer.ruleCondition.path":"<p>You can specify a single path pattern (for example, <em>/img/*</em>). A path pattern is case sensitive, can be up to 128 characters in length, and can contain any of the following characters. Note that you can include up to three wildcard characters.</p>\n <ul>\n <li>A-Z, a-z, 0-9</li>\n <li>_ - . $ / ~ \" ' @ : +</li>\n <li>& (using &amp;)</li>\n <li>* (matches 0 or more characters)</li>\n <li>? (matches exactly 1 character)</li>\n </ul>\n <p>Note that the path pattern is used to route requests but does not alter them. For example, if a rule has a path pattern of <em>/img/*</em>, the rule would forward a request for <em>/img/picture.jpg</em> to the specified target group as a request for <em>/img/picture.jpg</em>.</p>","aws.loadBalancer.oidcAuthentication":"Authentication requires a configured OIDC client.","aws.serverGroup.stack":"(Optional) <b>Stack</b> is one of the core naming components of a cluster, used to create vertical stacks of dependent services for integration testing.","aws.serverGroup.detail":"(Optional) <b>Detail</b> is a string of free-form alphanumeric characters and hyphens to describe any other variables.","aws.serverGroup.imageName":"(Required) <b>Image</b> is the deployable Amazon Machine Image. Images are restricted to the account and region selected.","aws.serverGroup.storageType":"AWS offers various storage options like temporary block-level storage via instance store (SSD, HDD) and Amazon Elastic Block Store (EBS). This column lists the storage type supported for the instance type.","aws.serverGroup.instancesDistribution":'Learn more in <a target="_blank" href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/asg-purchase-options.html">AWS docs</a>.',"aws.serverGroup.spotMaxPrice":"The maximum price per unit hour to pay for a Spot instance. By <b>default (empty)</b>, Amazon EC2 Auto Scaling uses the On-Demand price as the maximum Spot price.","aws.serverGroup.spotAllocationStrategy":"<p>Indicates how to allocate instances across Spot Instance pools.</p>\n <ul>\n <li><b>capacity-optimized (recommended)</b>: Instances launched using Spot pools that are optimally chosen based on the available Spot capacity.</li>\n <li><b>capacity-optimized-prioritized</b>: Instances launched using the priority on a best-effort basis to determine which launch template override to use first, but AWS optimizes for capacity first.</li>\n <li><b>lowest-price (default)</b>: Instances launched using Spot pools with the lowest price, and evenly allocated across the number of Spot pools specified</li>\n </ul>","aws.serverGroup.spotInstancePoolCount":"Number of lowest priced Spot Instance pools to diversify across. Only applicable for strategy 'lowest-price'. <b>Default: 2.</b>","aws.serverGroup.odAllocationStrategy":"The only strategy / <b>default is 'prioritized'</b>. The order specified in the list of selected instance types is used to determine which instance type to use first when fulfilling On-Demand capacity.","aws.serverGroup.odBase":"Minimum amount of the Auto Scaling Group's capacity that must be fulfilled by On-Demand Instances. This base portion is provisioned first as the group scales. <b>Default: 0.</b>","aws.serverGroup.odPercentAboveBase":"Percentages of On-Demand and Spot instances for additional capacity beyond OnDemandBaseCapacity.<b>Default: 100.</b>","aws.serverGroup.instanceTypeWeight":'The number of capacity units gives the instance type a proportional weight to other instance types. When specified, weights count towards desired capacity.\nLearn more in <a target="_blank" href="https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates/#convert-a-server-group-with-launch-template-to-use-mixed-instances-policy-with-multiple-instance-types-and-capacity-weighting">examples and docs</a>.',"aws.serverGroup.instanceTypes":"Specify up to 20 instance types.","aws.serverGroup.instanceTypesSelect":"<p>Filter instance types on one or more criteria, comma separated:\n <ul>\n <li>Minimum vCPU e.g. 16vcpu</li>\n <li>Minimum memory e.g. 32gib</li>\n <li>Spot support</li>\n <li>EBS support</li>\n <li>GPU support</li>\n <li>Instance storage type e.g. ssd</li>\n <li>Generation with 'currentGen' / 'oldGen'</li>\n <li>Instance family / size / type e.g. c3 / large / c3.large</li>\n </ul>\n Examples:\n <ul>\n <li>16vcpu, 32gib, spot, oldGen</li>\n <li>medium, ebs</li>\n <li>ssd,ebs,gpu,currentgen</li>\n </ul>","aws.serverGroup.multipleInstanceTypes":"Instance types a server group can launch, first (highest priority) to last (lowest priority).","aws.serverGroup.unlimitedCpuCredits":"<p>CPU credits can be configured with 2 modes:</p><br/>\n <ul>\n <li><b>Unlimited (i.e. Unlimited On)</b>: Can sustain high CPU utilization for any period of time whenever required.<br/>\n If the average CPU usage over a rolling 24-hour period exceeds the baseline, charges for surplus credits will apply.</li>\n <li><b>Standard (i.e. Unlimited Off)</b>: <b>Default mode in Spinnaker.</b> Suited to workloads with an average CPU utilization that is consistently below the baseline CPU utilization of the instance.<br/>\n To burst above the baseline, the instance spends credits that it has accrued in its CPU credit balance.</li>\n </ul>","aws.serverGroup.capacityRebalance":"Enabling <b>Capacity Rebalance</b> allows EC2 Auto Scaling to proactively replace Spot Instances that have received a rebalance recommendation, <b>before</b> it is interrupted by AWS EC2.","aws.serverGroup.advancedMode":'Advanced mode allows you to configure allocation strategies, multiple instance types with weighting, instance distribution across Spot / On-Demand and their proportions in the server group. Learn more in <a target="_blank" href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/asg-purchase-options.html">AWS docs</a>.',"aws.serverGroup.legacyUdf":"<p>(Optional) <b>User Data Format</b> allows overriding of the format used when generating user data during deployment. The default format used is configured\n in the application's attributes, editable via the 'Config' tab.</p>\n <p><b>Default</b> will use the value from the application's configuration.</p>\n <p><b>Modern</b> will use the modern template.</p>\n <p><b>Legacy</b> will use the legacy (<b>deprecated</b>) template.</p>\n <p>This option is intended to allow testing migration from legacy to modern before configuring it for the entire application. If unsure, pick <b>Default</b>.</p>","aws.serverGroup.base64UserData":"(Optional) <b>UserData</b> is a base64 encoded string.","aws.serverGroup.enabledMetrics":"(Optional) <b>Enabled Metrics</b> are the Auto Scaling Group metrics to enable on this group. Existing metrics are not modified.","aws.serverGroup.imdsv2":"(Recommended) <b>IMDSv2</b> helps mitigate AWS credential theft from the exploitation of SSRF vulnerabilities in web applications. All modern AWS SDKs support IMDSv2 and it should not be disabled unless you're using a legacy SDK.","aws.serverGroup.instanceMonitoring":"(Optional) <b>Instance Monitoring</b> whether to enable detailed monitoring of instances. Group metrics must be disabled to update an ASG with Instance Monitoring set to false.","aws.serverGroup.tags":"(Optional) <b>Tags</b> are propagated to the instances in this cluster.","aws.serverGroup.allImages":"Search for an image that does not match the name of your application.","aws.serverGroup.filterImages":"Select from a pre-filtered list of images matching the name of your application.","aws.serverGroup.traffic":'<p>Enables the "AddToLoadBalancer" scaling process, which is used by Spinnaker and discovery services to determine if the server group is enabled.</p>\n <p>Will be automatically enabled when any non "custom" deployment strategy is selected.</p>',"aws.securityGroup.vpc":'\n <p>The VPC to which this {{firewall}} will apply.</p>\n <p>If you wish to use VPC but are unsure which VPC to use, the most common one is "Main".</p>\n <p>If you do not wish to use VPC, select "None".</p>',"aws.securityGroup.name":"<p>The {{firewall}} name is formed by combining the application name, the <b>Stack</b> field, and the <b>Detail</b> field.</p>","aws.securityGroup.cross.account.ingress.help":"<p>Accounts that are excluded will not show up in this list</p>","aws.scalingPolicy.search.restricted":'<p>Resets dimensions to "AutoScalingGroupName: {name of the ASG}" and provides\n a simpler, combined input for the namespace and metric name fields.</p>',"aws.scalingPolicy.search.all":"\n <p>Allows you to edit the dimensions and namespace to find a specific metric for this alarm.</p>","aws.blockDeviceMappings.useSource":'\n <p>Spinnaker will use the block device mappings of the existing server group when deploying a new server group.</p>\n <p>In the event that there is no existing server group, the\n <a target="_blank" href="https://github.com/spinnaker/clouddriver/blob/master/clouddriver-aws/src/main/groovy/com/netflix/spinnaker/clouddriver/aws/deploy/InstanceTypeUtils.java">defaults</a>\n for the selected instance type will be used.</p>',"aws.blockDeviceMappings.useAMI":"<p>Spinnaker will use the block device mappings from the selected AMI when deploying a new server group.</p>","aws.blockDeviceMappings.useDefaults":'<p>Spinnaker will use the <a target="_blank" href="https://github.com/spinnaker/clouddriver/blob/master/clouddriver-aws/src/main/groovy/com/netflix/spinnaker/clouddriver/aws/deploy/InstanceTypeUtils.java">default block device mappings</a> for the selected instance type when deploying a new server group.</p>',"aws.targetGroup.protocol":"The protocol to use for routing traffic to the targets. Cannot be edited after being saved; if you want to use a different protocol, create a new target group, save the load balancer, move your targets, and then delete this target group.","aws.targetGroup.targetType":"Determines how targets are specified. Only set to ip if you need to attach individual ips. Cannot be edited after being saved; if you want to use a different target type, create a new target group, save the load balancer, move your targets, and then delete this target group.","aws.targetGroup.port":"The port on which the targets receive traffic. Cannot be edited after being saved; if you want to use a different port, create a new target group, save the load balancer, move your targets, and then delete this target group.","aws.targetGroup.attributes.deregistrationDelay":"The amount of time for the load balancer to wait before changing the state of a deregistering target from draining to unused. The range is 0-3600 seconds. The default value is 300 seconds.","aws.targetGroup.attributes.stickinessEnabled":" Indicates whether sticky sessions are enabled.","aws.targetGroup.attributes.deregistrationDelayConnectionTermination":"If enabled, your Network Load Balancer will terminate active connections when deregistration delay is reached.","aws.targetGroup.attributes.preserveClientIp":"If enabled, your Network Load Balancer will preserve client IP addresses to the target.","aws.targetGroup.attributes.stickinessType":"The type of sticky sessions. The only current possible value is <code>lb_cookie</code>.","aws.targetGroup.attributes.stickinessDuration":"The time period, in seconds, during which requests from a client should be routed to the same target. After this time period expires, the load balancer-generated cookie is considered stale. The range is 1 second to 1 week (604800 seconds). The default value is 1 day (86400 seconds).","aws.targetGroup.attributes.healthCheckPort.trafficPort":"The port the load balancer uses when performing health checks on targets. The default is <b>traffic-port</b>, which is the port on which each target receives traffic from the load balancer.","aws.targetGroup.healthCheckProtocol":"TCP health checks only support 10s and 30s intervals","aws.targetGroup.healthCheckTimeout":"Target groups with TCP or TLS protocol must have a 6s timeout for HTTP health checks or a 10s timeout for HTTPS/TLS health checks.","aws.targetGroup.nlbHealthcheckThreshold":"The healthy and unhealthy threshold for NLBs must be equal. This represents the number of successful and failed healthchecks required for healthy and unhealthy targets, respectively.","aws.serverGroup.capacityConstraint":"\n <p>Ensures that the capacity of this server group has not changed in the background (i.e. due to autoscaling activity).</p>\n <p>If the capacity has changed, this resize operation will be rejected.</p>","aws.tagImage.consideredStages":"Limit which previous stages will be considered when locating AMI's to tag. If left unchecked, AMI's generated by any upstream stage will be tagged.","aws.loadBalancer.redirect.host":"The hostname. This component is not percent-encoded. The hostname can contain <code>#{host}</code>.","aws.loadBalancer.redirect.path":'The absolute path, starting with the leading "/". This component is not percent-encoded. The path can contain <code>#{host}</code>, <code>#{path}</code>, and <code>#{port}</code>.',"aws.loadBalancer.redirect.port":"The port. You can specify a value from 1 to 65535 or <code>#{port}</code>.","aws.loadBalancer.redirect.protocol":"The protocol. You can specify HTTP, HTTPS, or <code>#{protocol}</code>. You can redirect HTTP to HTTP, HTTP to HTTPS, and HTTPS to HTTPS. You cannot redirect HTTPS to HTTP.","aws.loadBalancer.redirect.query":'The query parameters, URL-encoded when necessary, but not percent-encoded. Do not include the leading "?", as it is automatically added. You can specify any of the reserved keywords.',"aws.loadBalancer.redirect.statusCode":"The HTTP redirect code. The redirect is either permanent (HTTP 301) or temporary (HTTP 302).","aws.loadBalancer.redirect":'<p>A URI consists of the following components: protocol://hostname:port/path?query. You must modify at least one of the following components to avoid a redirect loop: protocol, hostname, port, or path. Any components that you do not modify retain their original values.\n\n <p>You can reuse URI components using the following reserved keywords:\n\n <ul><li>#{protocol}\n <li>#{host}\n <li>#{port}\n <li>#{path} (the leading "/" is removed)\n <li>#{query}\n </ul>\n <p>For example, you can change the path to "/new/#{path}", the hostname to "example.#{host}", or the query to "#{query}&value=xyz".',"aws.cloudformation.source":"\n <p>Where the template file content is read from.</p>\n <p>\n <b>text:</b> The template is supplied statically to the pipeline from the below text-box.\n </p>\n <p>\n <b>artifact:</b> The template is read from an artifact supplied/created upstream. The expected artifact must be referenced here, and will be bound at runtime.\n </p>\n ","aws.cloudformation.expectedArtifact":"The artifact that is to be applied to this stage. The artifact should represent a valid cloudformation template.","aws.function.name":"Enter a name that describes the purpose of your function. Function name will be prefixed with the application name.","aws.function.runtime":"Choose the language to use to write your function","aws.function.s3key":"The Amazon S3 key of the deployment package","aws.function.handler":"The name of the method within your code that Lambda calls to execute your function. The format includes the file name. It can also include namespaces and other qualifiers, depending on the runtime.","aws.function.s3bucket":"An Amazon S3 bucket in the same AWS Region as your function. The bucket can be in a different AWS account.","aws.function.execution.role":"Lambda will create an execution role with permission to upload logs to Amazon CloudWatch Logs. You can also choose an existing role that defines the permissions of your function.","aws.function.env.vars":"You can define environment variables as key-value pairs that are accessible from your function code. These are useful to store configuration settings without the need to change function code","aws.function.tags":"You can use tags to group and filter your functions. A tag consists of a case-sensitive key-value pair","aws.functionBasicSettings.memorySize":"Your function is allocated CPU proportional to the memory configured.","aws.functionBasicSettings.timeout":"The amount of time that Lambda allows a function to run before stopping it. The default is 3 seconds. The maximum allowed value is 900 seconds.","aws.function.publish":"Set to true to publish the first version of the function during creation.","aws.function.deadletterqueue":"A dead letter queue configuration that specifies the queue or topic where Lambda sends asynchronous events when they fail processing. (SNS or SQS)","aws.function.tracingConfig.mode":"The function's AWS X-Ray tracing configuration.","aws.function.kmsKeyArn":"The ARN of the AWS Key Management Service (AWS KMS) key that's used to encrypt your function's environment variables. If it's not provided, AWS Lambda uses a default service key.","aws.cloudformation.changeSet.options":"<p>Action to take when the created ChangeSet contains a replacement.</p>\n <p>\n <b>ask:</b> Execution will be put on hold asking for user feedback.\n </p>\n <p>\n <b>skip it:</b> ChangeSet will not be executed and stage will continue.\n </p>\n <p>\n <b>execute it</b> ChangeSet will be executed.\n </p>\n <p>\n <b>fail stage</b> ChangeSet will not be executed and the stage will fail.\n </p>"};Object.keys(ar).forEach((e=>P.register(e,ar[e])));class nr{findImages(e){return!e.q||e.q.length<3?Xa.when([{message:"Please enter at least 3 characters...",disabled:!0}]):D("/images/find").query(e).get().catch((()=>[]))}getImage(e,t,a){return D("/images").path(a,t,e).query({provider:"aws"}).get().then((e=>e&&e.length?e[0]:null)).catch((()=>null))}}var rr,ir,sr,lr,or,cr;const dr={type:"m5",description:"m5 instances provide a balance of compute, memory, and network resources. They are a good choice for most applications.",instanceTypes:[{name:"m5.large",label:"Large",cpu:2,memory:8,storage:{type:"EBS"},costFactor:2},{name:"m5.xlarge",label:"XLarge",cpu:4,memory:16,storage:{type:"EBS"},costFactor:3},{name:"m5.2xlarge",label:"2XLarge",cpu:8,memory:32,storage:{type:"EBS"},costFactor:4}]},ur=[{type:"general",label:"General Purpose",families:[dr,{type:"t2",description:"t2 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t2.small",label:"Small",cpu:1,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:12},{name:"t2.medium",label:"Medium",cpu:2,memory:4,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24},{name:"t2.large",label:"Large",cpu:2,memory:8,storage:{type:"EBS"},costFactor:2,cpuCreditsPerHour:36},{name:"t2.xlarge",label:"XLarge",cpu:4,memory:16,storage:{type:"EBS"},costFactor:3,cpuCreditsPerHour:54},{name:"t2.2xlarge",label:"2XLarge",cpu:8,memory:32,storage:{type:"EBS"},costFactor:4,cpuCreditsPerHour:81}]},{type:"t3",description:"t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t3.small",label:"Small",cpu:2,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24},{name:"t3.medium",label:"Medium",cpu:2,memory:4,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24},{name:"t3.large",label:"Large",cpu:2,memory:8,storage:{type:"EBS"},costFactor:2,cpuCreditsPerHour:36},{name:"t3.xlarge",label:"XLarge",cpu:4,memory:16,storage:{type:"EBS"},costFactor:3,cpuCreditsPerHour:96},{name:"t3.2xlarge",label:"2XLarge",cpu:8,memory:32,storage:{type:"EBS"},costFactor:4,cpuCreditsPerHour:192}]}],icon:"hdd",showCpuCredits:!0,descriptionListOverride:[dr.description,"t2/t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases)."]},{type:"memory",label:"High Memory",families:[{type:"r5",description:"r5 instances are optimized for memory-intensive applications and have the lowest cost per GiB of RAM among Amazon EC2 instance types.",instanceTypes:[{name:"r5.large",label:"Large",cpu:2,memory:16,storage:{type:"EBS"},costFactor:1},{name:"r5.xlarge",label:"XLarge",cpu:4,memory:32,storage:{type:"EBS"},costFactor:2},{name:"r5.2xlarge",label:"2XLarge",cpu:8,memory:64,storage:{type:"EBS"},costFactor:2},{name:"r5.4xlarge",label:"4XLarge",cpu:16,memory:128,storage:{type:"EBS"},costFactor:3}]}],icon:"hdd"},{type:"micro",label:"Micro Utility",families:[{type:"t2",description:"t2 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t2.nano",label:"Nano",cpu:1,memory:.5,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:3},{name:"t2.micro",label:"Micro",cpu:1,memory:1,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:6},{name:"t2.small",label:"Small",cpu:1,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:12}]},{type:"t3",description:"t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t3.nano",label:"Nano",cpu:2,memory:.5,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:6},{name:"t3.micro",label:"Micro",cpu:2,memory:1,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:12},{name:"t3.small",label:"Small",cpu:2,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24}]}],icon:"hdd",showCpuCredits:!0,descriptionListOverride:["t2/t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases)."]},{type:"custom",label:"Custom Type",families:[],icon:"asterisk"}],pr=null!=(sr=null==(ir=null==(rr=kn.instanceTypes)?void 0:rr.exclude)?void 0:ir.categories)?sr:[],mr=null!=(cr=null==(or=null==(lr=kn.instanceTypes)?void 0:lr.exclude)?void 0:or.families)?cr:[],gr=ur.filter((({type:e})=>!pr.includes(e))).map((e=>Object.assign({},e,{families:e.families.filter((({type:e})=>!mr.includes(e)))}))),hr="spinnaker.amazon.instanceType.service";t(hr,[]).factory("awsInstanceTypeService",["$q",function(e){const t=["xlarge","large","medium","small","micro","nano"];const a={ec2ClassicSupported:["m1","m3","t1","c1","c3","cc2","cr1","m2","r3","d2","hs1","i2","g2"],ebsOptimized:["c4","d2","f1","g3","i3","m4","m5","p2","r4","r5","x1"],burstablePerf:["t2","t3","t3a","t4g"]};return{getCategories:function(){return e.when(gr)},getAvailableTypesForRegions:function(e,a){let n=[];return(a=a||[])&&a.length&&(n=e[a[0]]||[]),a.forEach((function(t){e[t]&&(n=Ht.intersectionBy(n,e[t],"name"))})),null==n?void 0:n.sort(((e,a)=>function(e,a){const n=e.split("."),r=a.split("."),[i,s=""]=n,[l,o=""]=r;if(i!==l)return i>l?1:i<l?-1:0;const c=t.findIndex((e=>s.endsWith(e))),d=t.findIndex((e=>o.endsWith(e)));if(-1===c||-1===d)return 0;if(0===c&&0===d){const e=parseInt(s.replace("xlarge",""))||0,t=parseInt(o.replace("xlarge",""))||0;return t<e?1:t>e?-1:0}return c>d?-1:c<d?1:0}(e.name,a.name)))},getAllTypesByRegion:function(){return D("/instanceTypes").get().then((function(e){return Ht.chain(e).map((function(e){return{...e,key:[e.region,e.account,e.name].join(":")}})).uniqBy("key").groupBy("region").value()}))},filterInstanceTypes:function(e,t,n,r){return Ht.filter(e,(function(e){return"*"===t&&"*"===r||!(!n&&!a.ec2ClassicSupported.includes(e.name.split(".")[0]))&&(!(t&&e.supportedVirtualizationTypes&&!e.supportedVirtualizationTypes.includes(t))&&!(r&&e.supportedArchitectures&&!e.supportedArchitectures.includes(r)))}))},isEbsOptimized:function(e){if(!e)return!1;const t=Ht.split(e,".",1)[0];return a.ebsOptimized.includes(t)},isBurstingSupportedForAllTypes:function(e){return!(!e||!e.length)&&e.every((e=>function(e){if(!e)return!1;const t=Ht.split(e,".",1)[0];return a.burstablePerf.includes(t)}(e)))},getInstanceTypesInCategory:function(e,t){var a;if(!e||!e.length||!t)return[];if("custom"===t)return e;const n=Ht.flatten(null==(a=Ht.find(ur,{type:t}))?void 0:a.families.map((e=>e.instanceTypes.map((e=>e.name)))));return Ht.intersection(e,n)}}}]);const fr=({account:e,availabilityZone:t,instanceType:a,capacityType:n,launchTime:r,provider:i,region:s,serverGroup:l,showInstanceType:o})=>Vt.createElement(Vt.Fragment,null,Vt.createElement(B,{label:"Launched",value:r?z(r):"Unknown"}),Vt.createElement(B,{label:"In",value:Vt.createElement("div",null,Vt.createElement(G,{account:e}),t||"Unknown")}),o&&Vt.createElement(B,{label:"Type",value:a||"Unknown"}),o&&n&&Vt.createElement(B,{label:"Capacity Type",value:n||"Unknown"}),l&&Vt.createElement(B,{label:"Server Group",value:Vt.createElement("div",null,Vt.createElement(tn,null,Vt.createElement(Qa,{to:"^.serverGroup",params:{region:s,accountId:e,serverGroup:l,provider:i}},Vt.createElement("a",null,l))))})),vr="None (EC2 Classic)";function yr(e){const{vpcId:t}=e,a=F((async()=>{const t=await Wn.getVpcName(e.vpcId);return t?`${t} (${e.vpcId})`:`(${e.vpcId})`}),vr,[t]),n=t?a.result:vr;return Vt.createElement("span",{className:"vpc-tag"},n)}const br="spinnaker.application.amazonInstanceInformation.component";t(br,[]).component("amazonInstanceInformation",Ja(L((({instance:e})=>{const{imageId:t,serverGroup:a,subnetId:n,vpcId:r}=e;return Vt.createElement(x,{heading:"Instance Information",defaultExpanded:!0},Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement(fr,{account:e.account,availabilityZone:e.availabilityZone,instanceType:e.instanceType,capacityType:e.capacityType,launchTime:e.launchTime,provider:e.provider,region:e.region,serverGroup:e.serverGroup,showInstanceType:!0}),a&&Vt.createElement(B,{label:"VPC",value:Vt.createElement(yr,{vpcId:r})}),n&&Vt.createElement(B,{label:"Subnet",value:Vt.createElement(M,{subnetId:n})}),t&&Vt.createElement(B,{label:"Image ID",value:t})))}),"amazonInstanceInformation"),["instance"]));class Er extends R{static deregisterInstancesFromTargetGroup(e,t,a){const n=super.buildMultiInstanceJob(e,"deregisterInstancesFromLoadBalancer");n.forEach((e=>e.targetGroupNames=a));const r=super.buildMultiInstanceDescriptor(n,"Deregister",`from ${a.join(" and ")}`);return O.executeTask({job:n,application:t,description:r})}static deregisterInstanceFromTargetGroup(e,t,a={}){return a.type="deregisterInstancesFromLoadBalancer",a.instanceIds=[e.id],a.targetGroupNames=e.targetGroups,a.region=e.region,a.credentials=e.account,a.cloudProvider=e.cloudProvider,O.executeTask({job:[a],application:t,description:`Deregister instance: ${e.id}`})}static registerInstancesWithTargetGroup(e,t,a){const n=super.buildMultiInstanceJob(e,"registerInstancesWithLoadBalancer");n.forEach((e=>e.targetGroupNames=a));const r=super.buildMultiInstanceDescriptor(n,"Register",`with ${a.join(" and ")}`);return O.executeTask({job:n,application:t,description:r})}static registerInstanceWithTargetGroup(e,t,a={}){return a.type="registerInstancesWithLoadBalancer",a.instanceIds=[e.id],a.targetGroupNames=e.targetGroups,a.region=e.region,a.credentials=e.account,a.cloudProvider=e.cloudProvider,O.executeTask({job:[a],application:t,description:`Register instance: ${e.id}`})}}const wr=e=>{const t=e.map((e=>e.targetGroups));return Kt(t)},Cr=(e,t,a)=>{e.forEach((e=>{"TargetGroup"===e.type&&e.targetGroups.forEach((e=>{var n,r,i;const s=null!=(n=t.find((t=>t.name===e.name&&t.account===a)))?n:{},l="traffic-port"===s.healthCheckPort||Yt(s.healthCheckPort)?s.port:s.healthCheckPort;e.healthCheckProtocol=null==(r=s.healthCheckProtocol)?void 0:r.toLowerCase(),e.healthCheckPath=`:${l}${null!=(i=s.healthCheckPath)?i:""}`}))}))},Sr="spinnaker.amazon.instance.details.controller";t(Sr,[an,nn]).controller("awsInstanceDetailsCtrl",["$scope","$state","instance","app","moniker","environment","$q","overrides",function(e,t,n,r,i,s,l,o){function c(){const t={};let a,i,s,c,u,p,m;return r.serverGroups?(r.serverGroups.data.some((function(e){return e.instances.some((function(r){if(r.id===n.instanceId)return a=r,i=e.loadBalancers,s=e.targetGroups,c=e.account,u=e.region,p=e.vpcId,m=e.isDisabled,t.serverGroup=e.name,t.vpcId=e.vpcId,!0}))})),a||(r.loadBalancers.data.some((function(e){return e.instances.some((function(t){if(t.id===n.instanceId)return a=t,i=[e.name],c=e.account,u=e.region,p=e.vpcId,!0}))||e.targetGroups.some((function(t){return t.instances.some((function(r){if(r.id===n.instanceId)return a=r,s=[t.name],c=e.account,u=e.region,p=e.vpcId,!0}))}))})),a||r.loadBalancers.data.some((function(e){return e.serverGroups.some((function(t){return!!t.isDisabled&&t.instances.some((function(t){if(t.id===n.instanceId)return a=t,i=[e.name],c=e.account,u=e.region,p=e.vpcId,!0}))}))||e.targetGroups.some((function(t){t.serverGroups.some((function(t){return!!t.isDisabled&&t.instances.some((function(t){if(t.id===n.instanceId)return a=t,i=[e.name],c=e.account,u=e.region,p=e.vpcId,!0}))}))}))})))):(a={id:n.instanceId},i=[],s=[],c=n.account,u=n.region),a&&c&&u?(a.account=c,t.account=c,t.region=u,q.addExtraDataToLatest("instances",t),H.getInstanceDetails(c,u,n.instanceId).then((t=>{if(!e.$$destroyed){if(e.state.loading=!1,function(t,a){r.isStandalone&&(t.health=a.health),t.health=t.health||[];const n=t.health.filter((function(e){return"Amazon"!==e.type||"Unknown"!==e.state}));if(!r.isStandalone){const e=wr(r.loadBalancers.data.filter((function(e){return"aws"===e.cloudProvider})));Cr(n,e,t.account)}a.health&&n.forEach((function(e){const t=a.health.filter((function(t){return t.type===e.type}));t.length&&Ht.defaults(e,t[0])})),e.healthMetrics=n}(a,t),e.instance=Ht.defaults(t,a),e.instance.account=c,e.instance.region=u,e.instance.vpcId=p,e.instance.serverGroupDisabled=m,e.instance.loadBalancers=i,e.instance.targetGroups=s,e.instance.networkInterfaces){e.instance.ipv6Addresses=Ht.flatMap(e.instance.networkInterfaces,(t=>t.ipv6Addresses.map((t=>({ip:t.ipv6Address,url:`http://${t.ipv6Address}:${e.state.instancePort}`})))));const t=e.instance.networkInterfaces.filter((e=>!1===e.attachment.deleteOnTermination));t.length&&(e.instance.permanentIps=t.map((e=>e.privateIpAddress)))}e.baseIpAddress=t.publicDnsName||t.privateIpAddress,o.instanceDetailsLoaded&&o.instanceDetailsLoaded()}}),d)):(a||(e.instanceIdNotFound=n.instanceId,e.state.loading=!1),l.when(null))}function d(){e.$$destroyed||(r.isStandalone?(e.state.loading=!1,e.instanceIdNotFound=n.instanceId,e.state.notFoundStandalone=!0,q.removeLastItem("instances")):t.go("^",{allowModalToStayOpen:!0},{location:"replace"}))}e.isDisabled=!kn.adHocInfraWritesEnabled,e.detailsTemplateUrl=V.getValue("aws","instance.detailsTemplateUrl"),e.state={loading:!0,standalone:r.isStandalone,instancePort:Ht.get(r,"attributes.instancePort")||a.defaultInstancePort||80},e.application=r,e.moniker=i,e.environment=s,e.securityGroupsLabel=U.get("Firewalls"),this.canDeregisterFromLoadBalancer=function(){return(e.instance.health||[]).some((function(e){return"LoadBalancer"===e.type}))},this.canRegisterWithLoadBalancer=function(){const t=e.instance,a=t.health||[];if(!t.loadBalancers||!t.loadBalancers.length)return!1;const n=a.some((function(e){return"LoadBalancer"===e.type&&"OutOfService"===e.state})),r=a.some((function(e){return"LoadBalancer"===e.type}));return n||!r},this.canDeregisterFromTargetGroup=function(){return(e.instance.health||[]).some((function(e){return"TargetGroup"===e.type&&"OutOfService"!==e.state}))},this.canRegisterWithTargetGroup=function(){const t=e.instance,a=t.health||[];if(!t.targetGroups||!t.targetGroups.length)return!1;const n=a.some((function(e){return"TargetGroup"===e.type&&"OutOfService"===e.state})),r=a.some((function(e){return"TargetGroup"===e.type}));return n||!r},this.canRegisterWithDiscovery=function(){const t=(e.instance.health||[]).filter((function(e){return"Discovery"===e.type}));return!!t.length&&"OutOfService"===t[0].state},this.terminateInstance=function(){const a=e.instance,n={application:r,title:"Terminating "+a.instanceId,onTaskComplete:function(){t.includes("**.instanceDetails",{instanceId:a.instanceId})&&t.go("^")}};S.confirm({header:"Really terminate "+a.instanceId+"?",buttonText:"Terminate "+a.instanceId,account:a.account,taskMonitorConfig:n,submitMethod:function(){return Er.terminateInstance(a,r)}})},this.terminateInstanceAndShrinkServerGroup=function(){const a=e.instance,n={application:r,title:"Terminating "+a.instanceId+" and shrinking server group",onTaskComplete:function(){t.includes("**.instanceDetails",{instanceId:a.instanceId})&&t.go("^")}};S.confirm({header:"Really terminate "+a.instanceId+" and shrink "+a.serverGroup+"?",buttonText:"Terminate "+a.instanceId+" and shrink "+a.serverGroup,account:a.account,taskMonitorConfig:n,submitMethod:function(){return Er.terminateInstanceAndShrinkServerGroup(a,r)}})},this.rebootInstance=function(){const t=e.instance,a={application:r,title:"Rebooting "+t.instanceId};S.confirm({header:"Really reboot "+t.instanceId+"?",buttonText:"Reboot "+t.instanceId,account:t.account,platformHealthOnlyShowOverride:r.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon",taskMonitorConfig:a,submitMethod:(e={})=>(r.attributes&&r.attributes.platformHealthOnlyShowOverride&&r.attributes.platformHealthOnly&&(e.interestingHealthProviderNames=["Amazon"]),Er.rebootInstance(t,r,e))})},this.registerInstanceWithLoadBalancer=function(){const t=e.instance,a=t.loadBalancers.join(" and "),n={application:r,title:"Registering "+t.instanceId+" with "+a};S.confirm({header:"Really register "+t.instanceId+" with "+a+"?",buttonText:"Register "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return Er.registerInstanceWithLoadBalancer(t,r)}})},this.deregisterInstanceFromLoadBalancer=function(){const t=e.instance,a=t.loadBalancers.join(" and "),n={application:r,title:"Deregistering "+t.instanceId+" from "+a};S.confirm({header:"Really deregister "+t.instanceId+" from "+a+"?",buttonText:"Deregister "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return Er.deregisterInstanceFromLoadBalancer(t,r)}})},this.registerInstanceWithTargetGroup=function(){const t=e.instance,a=t.targetGroups.join(" and "),n={application:r,title:"Registering "+t.instanceId+" with "+a};S.confirm({header:"Really register "+t.instanceId+" with "+a+"?",buttonText:"Register "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return Er.registerInstanceWithTargetGroup(t,r)}})},this.deregisterInstanceFromTargetGroup=function(){const t=e.instance,a=t.targetGroups.join(" and "),n={application:r,title:"Deregistering "+t.instanceId+" from "+a};S.confirm({header:"Really deregister "+t.instanceId+" from "+a+"?",buttonText:"Deregister "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return Er.deregisterInstanceFromTargetGroup(t,r)}})},this.enableInstanceInDiscovery=function(){const t=e.instance,a={application:r,title:"Enabling "+t.instanceId+" in discovery"};S.confirm({header:"Really enable "+t.instanceId+" in discovery?",buttonText:"Enable "+t.instanceId,account:t.account,taskMonitorConfig:a,submitMethod:function(){return Er.enableInstanceInDiscovery(t,r)}})},this.disableInstanceInDiscovery=function(){const t=e.instance,a={application:r,title:"Disabling "+t.instanceId+" in discovery"};S.confirm({header:"Really disable "+t.instanceId+" in discovery?",buttonText:"Disable "+t.instanceId,account:t.account,taskMonitorConfig:a,submitMethod:function(){return Er.disableInstanceInDiscovery(t,r)}})},this.hasHealthState=function(t,a){return(e.instance.health||[]).some((function(e){return e.type===t&&e.state===a}))};const u=e=>{const t=[{label:"Reboot",triggerAction:this.rebootInstance},{label:"Terminate",triggerAction:this.terminateInstance},{label:"Terminate and Shrink Server Group",triggerAction:this.terminateInstanceAndShrinkServerGroup}],a=[];return this.canRegisterWithDiscovery()&&!e.serverGroupDisabled&&a.push({label:"Enable In Discovery",triggerAction:this.enableInstanceInDiscovery}),(this.hasHealthState("Discovery","Up")||this.hasHealthState("Discovery","Down"))&&a.push({label:"Disable in Discovery",triggerAction:this.disableInstanceInDiscovery}),this.canRegisterWithLoadBalancer()&&a.push({label:"Register with Load Balancer",triggerAction:this.registerInstanceWithLoadBalancer}),this.canDeregisterFromLoadBalancer()&&a.push({label:"Deregister from Load Balancer",triggerAction:this.deregisterInstanceFromLoadBalancer}),this.canRegisterWithTargetGroup()&&a.push({label:"Register with Target Group",triggerAction:this.registerInstanceWithTargetGroup}),this.canDeregisterFromTargetGroup()&&a.push({label:"Deregister from Target Group",triggerAction:this.deregisterInstanceFromTargetGroup}),a.concat(t)};(r.isStandalone?c():l.all([r.serverGroups.ready(),r.loadBalancers.ready()]).then(c)).then((()=>{e.instanceActions=u(e.instance),e.$$destroyed||r.isStandalone||r.serverGroups.onRefresh(e,c)})),e.account=n.account}]);const kr=({instancePort:e,ipv6Addresses:t,permanentIps:a,privateDnsName:n,privateIpAddress:r,publicDnsName:i,publicIpAddress:s})=>{const l=e?`:${e}`:"";return Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},n&&Ot.createElement(B,{label:"Private DNS Name",value:Ot.createElement(j,{text:n,url:`http://${n}${l}`})}),i&&Ot.createElement(B,{label:"Public DNS Name",value:Ot.createElement(j,{text:i,url:`http://${i}${l}`})}),r&&Ot.createElement(B,{label:"Private IP Address",value:Ot.createElement(j,{text:r,url:`http://${r}${l}`})}),Boolean(null==a?void 0:a.length)&&Ot.createElement(B,{label:"Permanent IP Address",value:a.map((e=>Ot.createElement(j,{key:e,text:e,url:`http://${e}${l}`})))}),s&&Ot.createElement(B,{label:"Public IP Address",value:Ot.createElement(j,{text:s,url:`http://${s}${l}`})}),Boolean(null==t?void 0:t.length)&&Ot.createElement(B,{label:"IPv6 Address"+(t.length>1?"es":""),value:t.map((e=>Ot.createElement(j,{key:e.ip,text:e.ip,url:e.url})))}))},Nr="spinnaker.application.instanceDns.component";t(Nr,[]).component("instanceDns",Ja(L(kr,"instanceDns"),["instancePort","ipv6Addresses","permanentIps","privateDnsName","privateIpAddress","publicDnsName","publicIpAddress"]));const Tr="spinnaker.application.instanceSecurityGroups.component";t(Tr,[]).component("instanceSecurityGroups",Ja(L((({instance:e})=>{const{account:t,region:a,provider:n,securityGroups:r,vpcId:i}=e,s=Xt(r,["groupName"],["asc"]),l=U.get("Firewalls");return Vt.createElement(x,{heading:l,defaultExpanded:!0},Vt.createElement(tn,null,Vt.createElement("ul",null,(s||[]).map((e=>Vt.createElement("li",{key:e.groupId},Vt.createElement(Qa,{to:"^.firewallDetails",params:{name:e.groupName,accountId:t,region:a,vpcId:i,provider:n}},Vt.createElement("a",null,e.groupName," (",e.groupId,")"))))))))}),"instanceSecurityGroups"),["instance"]));const Ir=({healthMetrics:e,healthState:t,metricTypes:a,customHealthUrl:n,privateIpAddress:r})=>{const i=a.includes("LoadBalancer"),s=a.includes("TargetGroup");return Vt.createElement(x,{heading:"Status",defaultExpanded:!0},!e.length&&Vt.createElement("p",null,"Starting"===t?"Starting":"No health metrics found for this instance"),Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},e.sort(((e,t)=>e.type<t.type?-1:e.type>t.type?1:0)).map((e=>Vt.createElement(Vt.Fragment,{key:`${e.type}-${e.description}`},Vt.createElement("dt",null,Z(e.type)),Vt.createElement("dd",null,!a.includes(e.type)&&Vt.createElement("div",null,Vt.createElement(_,{value:"down"===e.state.toLowerCase()?e.description:"",placement:"left"},Vt.createElement("span",null,Vt.createElement("span",{className:`glyphicon glyphicon-${e.state}-triangle`}),Vt.createElement("span",null,Z(e.state)))),Vt.createElement("span",{className:"pad-left small"},e.healthCheckUrl&&Vt.createElement("a",{target:"_blank",href:e.healthCheckUrl},"Health Check"),e.healthCheckUrl&&e.statusPageUrl&&Vt.createElement("span",null," | "),e.statusPageUrl&&Vt.createElement("a",{target:"_blank",href:e.statusPageUrl},"Status"),n&&e.type===n.type&&Vt.createElement("span",null," ","|"," ",Vt.createElement("a",{target:"_blank",href:n.href},n.text)))),i&&"LoadBalancer"===e.type&&(e.loadBalancers||[]).map((e=>Vt.createElement(K,{key:`lb-${e.name}`,loadBalancer:e}))),s&&"TargetGroup"===e.type&&(e.targetGroups||[]).map((e=>Vt.createElement(K,{key:`tg-${e.name}`,loadBalancer:e,ipAddress:r})))))))))},Gr="spinnaker.application.instanceStatus.component";t(Gr,[]).component("instanceStatus",Ja(L(Ir,"instanceStatus"),["healthMetrics","healthState","metricTypes","customHealthUrl","privateIpAddress"]));const Ar="spinnaker.application.instanceTags.component";function xr(e,t){void 0===t&&(t={});var a=t.insertAt;if(e&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],r=document.createElement("style");r.type="text/css","top"===a&&n.firstChild?n.insertBefore(r,n.firstChild):n.appendChild(r),r.styleSheet?r.styleSheet.cssText=e:r.appendChild(document.createTextNode(e))}}t(Ar,[]).component("instanceTags",Ja(L((({tags:e})=>{const t=Xt(e,["key"],["asc"]);return Vt.createElement(x,{heading:"Tags",defaultExpanded:!0},!e.length&&Vt.createElement("div",null,"No tags associated with this server"),e.length&&t.map((e=>Vt.createElement(B,{key:e.key,label:e.key,value:e.value}))))}),"instanceTags"),["tags"]));xr(".target-group-title {\n color: var(--color-mineshaft);\n font-weight: 600;\n font-size: 14px;\n padding-right: 15px;\n text-transform: uppercase;\n padding-left: 10px;\n}\n.cluster-container .target-group-container {\n margin-top: 3px;\n}\n.cluster-container .target-group-container:not(:first-child) {\n padding-top: 5px;\n}\n.target-group-container .target-group-header {\n padding: 4px 0;\n}\n.target-group-container .server-group-title {\n padding-top: 0;\n}\n.target-group-container .server-group-title .clickable-row {\n margin-top: -1px;\n}\n.target-group-container .no-margin-y {\n margin-top: -1px !important;\n margin-bottom: 0 !important;\n}\n.target-group-container > div > .text-right {\n padding-right: 10px;\n font-weight: 600;\n}\n.listener-targets {\n display: inline-block;\n vertical-align: top;\n}\n");class Pr extends Vt.Component{render(){const{targetGroup:e,showInstances:t,showServerGroups:a,loadBalancer:n}=this.props,r=Xt(e.serverGroups,["isDisabled","name"],["asc","desc"]).map((e=>Vt.createElement(Y,{key:e.name,account:e.account,region:e.region,serverGroup:e,showInstances:t}))),i={loadBalancerName:n.name,region:e.region,accountId:e.account,name:e.name,vpcId:e.vpcId,provider:e.cloudProvider};return Vt.createElement("div",{className:"target-group-container container-fluid no-padding"},Vt.createElement(en,{class:"active"},Vt.createElement(Qa,{to:".targetGroupDetails",params:i},Vt.createElement("div",{className:"clickable clickable-row row no-margin-y target-group-header"},Vt.createElement("div",{className:"col-md-8 target-group-title"},e.name),Vt.createElement("div",{className:"col-md-4 text-right"},Vt.createElement(X,{container:e.instanceCounts}))))),a&&r,!a&&t&&Vt.createElement(J,{serverGroups:e.serverGroups,instances:e.instances}))}}class Dr extends Vt.Component{shouldComponentUpdate(e){return e.showInstances!==this.props.showInstances||e.showServerGroups!==this.props.showServerGroups||e.loadBalancer!==this.props.loadBalancer||(()=>!Jt((e.serverGroups||[]).map((e=>e.name)),(this.props.serverGroups||[]).map((e=>e.name))))()||(()=>!Jt((e.loadBalancer.targetGroups||[]).map((e=>e.name)),(this.props.loadBalancer.targetGroups||[]).map((e=>e.name))))()}render(){const{loadBalancer:e,showInstances:t,showServerGroups:a}=this.props;if("classic"!==e.loadBalancerType){const n=e.targetGroups.map((n=>Vt.createElement(Pr,{key:n.name,loadBalancer:e,targetGroup:n,showInstances:t,showServerGroups:a})));return Vt.createElement("div",{className:"cluster-container"},n)}return Vt.createElement(Q,{...this.props})}}class Br{static buildTargetGroup(e,t){if(!e)return null;const a={name:e.name,vpcId:e.vpcId,cloudProvider:e.cloudProvider,account:e.account,region:e.region,loadBalancerNames:e.loadBalancerNames,instanceCounts:{up:0,down:0,succeeded:0,failed:0,outOfService:0,unknown:0,starting:0}};return t.instances.forEach((t=>{const n=t.health.find((e=>"TargetGroup"===e.type));if(n){const t=n.targetGroups.find((t=>t.name===e.name));if(void 0!==t&&void 0!==t.healthState){const e=t.healthState.toLowerCase();void 0!==a.instanceCounts[e]&&a.instanceCounts[e]++}}})),a}static populateTargetGroups(e,t){return Xa.all([o.getAccountDetails(t.account),e.getDataSource("loadBalancers").ready()]).then((a=>{const n=a[0]&&a[0].awsAccount||t.account,r=e.loadBalancers.data.filter((e=>"application"===e.loadBalancerType||"network"===e.loadBalancerType));return t.targetGroups.map((e=>{const a=Kt(r.map((e=>e.targetGroups||[]))).find((a=>a.name===e&&a.region===t.region&&a.account===n));return this.buildTargetGroup(a,t)})).filter((e=>e))}))}}class zr extends Vt.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Vt.createElement("a",{onClick:this.onClick},Vt.createElement("span",{className:"name"},this.props.loadBalancer.name),Vt.createElement(X,{container:this.props.loadBalancer.instanceCounts}))}}class Fr extends Vt.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Vt.createElement(_,{value:`${this.props.label||"Load Balancer"}: ${this.props.loadBalancer.name}`},Vt.createElement("button",{className:"btn btn-link no-padding",onClick:this.onClick},Vt.createElement("span",{className:"badge badge-counter"},Vt.createElement("span",{className:"icon"},Vt.createElement("i",{className:"fa icon-sitemap"})))))}}class Mr extends Vt.Component{constructor(e){super(e),this.mounted=!1,this.showLoadBalancerDetails=e=>{const{$state:t}=h,a=this.props.serverGroup;ee.log({category:"Cluster Pod",action:"Load Load Balancer Details (multiple menu)"});const n=t.current.name.endsWith(".clusters")?".loadBalancerDetails":"^.loadBalancerDetails";t.go(n,{region:a.region,accountId:a.account,name:e.name,provider:a.type})},this.showTargetGroupDetails=e=>{const{$state:t}=h;ee.log({category:"Cluster Pod",action:"Load Target Group Details (multiple menu)"});const a=t.current.name.endsWith(".clusters")?".targetGroupDetails":"^.targetGroupDetails";t.go(a,{region:e.region,accountId:e.account,name:e.name,provider:"aws",loadBalancerName:e.loadBalancerNames[0]})},this.handleShowPopover=()=>{ee.log({category:"Cluster Pod",action:"Show Load Balancers Menu"})},this.handleClick=e=>{e.preventDefault(),e.stopPropagation()},this.state={loadBalancers:[],targetGroups:[],isLoading:!0}}componentDidMount(){this.mounted=!0,this.loadBalancersRefreshUnsubscribe=this.props.application.getDataSource("loadBalancers").onRefresh(null,(()=>{this.forceUpdate()})),te.populateLoadBalancers(this.props.application,this.props.serverGroup).then((e=>{this.mounted&&this.setState({loadBalancers:e,isLoading:!1})})),Br.populateTargetGroups(this.props.application,this.props.serverGroup).then((e=>{this.mounted&&this.setState({targetGroups:e})}))}componentWillUnmount(){this.mounted=!1,this.loadBalancersRefreshUnsubscribe()}render(){const{loadBalancers:e,targetGroups:t,isLoading:a}=this.state,n=t&&t.length||0,r=e&&e.length||0,i=n+r;if(!i)return a?Vt.createElement(ae,{size:"nano"}):null;const s="load-balancers-tag "+(i>1?"overflowing":""),l=Vt.createElement("div",{className:"menu-load-balancers"},r>0&&Vt.createElement("div",{className:"menu-load-balancers-header"},"Load Balancers"),Qt(e,"name").map((e=>Vt.createElement(zr,{key:e.name,loadBalancer:e,onItemClick:this.showLoadBalancerDetails}))),n>0&&Vt.createElement("div",{className:"menu-load-balancers-header"},"Target Groups"),Qt(t,"name").map((e=>Vt.createElement(zr,{key:e.name,loadBalancer:e,onItemClick:this.showTargetGroupDetails}))));return Vt.createElement("span",{className:s},i>1&&Vt.createElement(ne,{delayShow:100,delayHide:150,onShow:this.handleShowPopover,placement:"bottom",template:l,hOffsetPercent:"80%",container:this.props.container,className:"no-padding menu-load-balancers"},Vt.createElement("button",{onClick:this.handleClick,className:"btn btn-link btn-multiple-load-balancers clearfix no-padding"},Vt.createElement("span",{className:"badge badge-counter"},Vt.createElement("span",{className:"icon"},Vt.createElement("i",{className:"fa icon-sitemap"}))," ",i))),1===e.length&&0===t.length&&Vt.createElement("span",{className:"btn-load-balancer"},Vt.createElement(Fr,{key:e[0].name,label:"Load Balancer",loadBalancer:e[0],onItemClick:this.showLoadBalancerDetails})),1===t.length&&0===e.length&&Vt.createElement("span",{className:"btn-load-balancer"},Vt.createElement(Fr,{key:t[0].name,label:"Target Group",loadBalancer:t[0],onItemClick:this.showTargetGroupDetails})))}}class $r{updateHealthCounts(e){const t=e.instances;if(e.instanceCounts={up:t.filter((e=>"InService"===e.health[0].state)).length,down:t.filter((e=>"Down"===e.healthState)).length,outOfService:t.filter((e=>"OutOfService"===e.healthState)).length,starting:void 0,succeeded:void 0,failed:void 0,unknown:void 0},e.serverGroups){const t=Kt(e.serverGroups.map((e=>e.instances)));e.instanceCounts.up=t.filter((e=>"InService"===e.health[0].state)).length,e.instanceCounts.down=t.filter((e=>"Down"===e.healthState)).length,e.instanceCounts.outOfService=t.filter((e=>"OutOfService"===e.healthState)).length}}transformInstance(e,t,a,n){const r=e.health||{};"healthy"===r.state&&(r.state="InService"),e.provider=t,e.account=a,e.region=n,e.healthState=r.state?"InService"===r.state?"Up":"Down":"OutOfService",e.health=[r]}addVpcNameToContainer(e){return t=>{const a=t.find((t=>t.id===e.vpcId));return e.vpcName=a?a.name:"",e}}normalizeServerGroups(e,t,a,n){e.forEach((e=>{e.account=e.account||t.account,e.region=e.region||t.region,e.cloudProvider=e.cloudProvider||t.cloudProvider,e.detachedInstances?(e.detachedInstances=e.detachedInstances.map((e=>({id:e}))),e.instances=e.instances.concat(e.detachedInstances)):e.detachedInstances=[],e.instances.forEach((e=>{this.transformInstance(e,t.type,t.account,t.region),e[a]=[t.name],e.health.type=n})),this.updateHealthCounts(e)}))}normalizeTargetGroup(e){this.normalizeServerGroups(e.serverGroups,e,"targetGroups","TargetGroup");const t=ea(e.serverGroups,{isDisabled:!1});return e.provider=e.type,e.instances=ta(t).map("instances").flatten().value(),e.detachedInstances=ta(t).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Xa.all([Wn.listVpcs(),o.listAllAccounts()]).then((([t,a])=>{const n=this.addVpcNameToContainer(e)(t);return n.serverGroups=n.serverGroups.map((e=>{const t=a.find((t=>t.name===e.account)),n=t&&t.cloudProvider||e.cloudProvider;return e.cloudProvider=n,e.instances.forEach((e=>{e.cloudProvider=n,e.provider=n})),{...e,cloudProvider:n}})),n}))}normalizeActions(e){if("application"===e.loadBalancerType){e.listeners.forEach((e=>{e.defaultActions.sort(((e,t)=>e.order-t.order)),e.rules.forEach((e=>e.actions.sort(((e,t)=>e.order-t.order))))}))}}normalizeLoadBalancer(e){this.normalizeServerGroups(e.serverGroups,e,"loadBalancers","LoadBalancer");let t=e.serverGroups;if(e.targetGroups){const a=e;a.targetGroups.forEach((e=>this.normalizeTargetGroup(e))),t=Kt(aa(a.targetGroups,"serverGroups"))}e.loadBalancerType=e.loadBalancerType||"classic",e.provider=e.type,this.normalizeActions(e);const a=ea(t,{isDisabled:!1});return e.instances=ta(a).map("instances").flatten().value(),e.detachedInstances=ta(a).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Wn.listVpcs().then((t=>this.addVpcNameToContainer(e)(t)))}static convertClassicLoadBalancerForEditing(e){const t={availabilityZones:void 0,isInternal:e.isInternal,region:e.region,cloudProvider:e.cloudProvider,credentials:e.credentials||e.account,listeners:e.listeners,loadBalancerType:"classic",name:e.name,regionZones:e.availabilityZones,securityGroups:e.securityGroups,vpcId:e.vpcId,healthCheck:void 0,healthTimeout:e.healthTimeout,healthInterval:e.healthInterval,healthyThreshold:e.healthyThreshold,unhealthyThreshold:e.unhealthyThreshold,healthCheckProtocol:e.healthCheckProtocol,healthCheckPort:e.healthCheckPort,healthCheckPath:e.healthCheckPath,idleTimeout:e.idleTimeout||60,subnetType:e.subnetType};if(e.elb){const a=e.elb;if(t.securityGroups=a.securityGroups,t.vpcId=a.vpcid||a.vpcId,a.listenerDescriptions&&(t.listeners=a.listenerDescriptions.map((e=>{const t=e.listener;if(t.sslcertificateId){const e=t.sslcertificateId.split("/");t.sslcertificateId=e[1],t.sslCertificateType=e[0].split(":")[2]}return{internalProtocol:t.instanceProtocol,internalPort:t.instancePort,externalProtocol:t.protocol,externalPort:t.loadBalancerPort,sslCertificateId:t.sslcertificateId,sslCertificateName:t.sslcertificateId,sslCertificateType:t.sslCertificateType,policyNames:e.policyNames}}))),a.healthCheck&&a.healthCheck.target){t.healthTimeout=a.healthCheck.timeout,t.healthInterval=a.healthCheck.interval,t.healthyThreshold=a.healthCheck.healthyThreshold,t.unhealthyThreshold=a.healthCheck.unhealthyThreshold;const e=a.healthCheck.target,n=e.indexOf(":");let r=e.indexOf("/");if(-1===r&&(r=e.length),-1!==n){t.healthCheckProtocol=e.substring(0,n);const a=Number(e.substring(n+1,r));t.healthCheckPath=e.substring(r),isNaN(a)||(t.healthCheckPort=a)}}}return t}static convertApplicationLoadBalancerForEditing(e){const t=re.parseLoadBalancerName(e.name).application,a={availabilityZones:void 0,isInternal:e.isInternal,region:e.region,loadBalancerType:"application",cloudProvider:e.cloudProvider,credentials:e.account||e.credentials,listeners:[],targetGroups:[],name:e.name,regionZones:e.availabilityZones,securityGroups:[],subnetType:e.subnetType,vpcId:void 0,idleTimeout:e.idleTimeout||60,deletionProtection:e.deletionProtection||!1,ipAddressType:e.ipAddressType||"ipv4",dualstack:"dualstack"===e.ipAddressType};if(e.elb){const n=e.elb;a.securityGroups=n.securityGroups,a.vpcId=n.vpcid||n.vpcId,n.listeners&&(a.listeners=n.listeners.map((e=>{const a=[];return e.certificates&&e.certificates.forEach((e=>{const t=e.certificateArn.split(":"),n=t[5].split("/");a.push({certificateArn:e.certificateArn,type:t[2],name:n[1]})})),(e.defaultActions||[]).forEach((e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,"")),e.redirectActionConfig=e.redirectConfig})),e.rules=(e.rules||[]).filter((e=>!e.default)),e.rules.forEach((e=>{(e.actions||[]).forEach((e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,"")),e.redirectActionConfig=e.redirectConfig})),(e.conditions||[]).forEach((e=>{"http-request-method"===e.field&&(e.values=e.httpRequestMethodConfig.values)})),e.conditions=e.conditions||[]})),e.rules.sort(((e,t)=>e.priority-t.priority)),{protocol:e.protocol,port:e.port,defaultActions:e.defaultActions,certificates:a,rules:e.rules||[],sslPolicy:e.sslPolicy}}))),n.targetGroups&&(a.targetGroups=n.targetGroups.map((e=>({name:e.targetGroupName.replace(`${t}-`,""),protocol:e.protocol,port:e.port,targetType:e.targetType,healthCheckProtocol:e.healthCheckProtocol,healthCheckPort:e.healthCheckPort,healthCheckPath:e.healthCheckPath,healthCheckTimeout:e.healthCheckTimeoutSeconds,healthCheckInterval:e.healthCheckIntervalSeconds,healthyThreshold:e.healthyThresholdCount,unhealthyThreshold:e.unhealthyThresholdCount,attributes:{deregistrationDelay:Number(e.attributes["deregistration_delay.timeout_seconds"]),stickinessEnabled:"true"===e.attributes["stickiness.enabled"],stickinessType:e.attributes["stickiness.type"],stickinessDuration:Number(e.attributes["stickiness.lb_cookie.duration_seconds"]),multiValueHeadersEnabled:"true"===e.attributes["lambda.multi_value_headers.enabled"]}}))))}return a}static convertNetworkLoadBalancerForEditing(e){const t=re.parseLoadBalancerName(e.name).application,a={availabilityZones:void 0,isInternal:e.isInternal,region:e.region,loadBalancerType:"network",cloudProvider:e.cloudProvider,credentials:e.account||e.credentials,listeners:[],targetGroups:[],name:e.name,regionZones:e.availabilityZones,securityGroups:[],subnetType:e.subnetType,vpcId:void 0,deletionProtection:e.deletionProtection,loadBalancingCrossZone:e.loadBalancingCrossZone,ipAddressType:e.ipAddressType||"ipv4",dualstack:"dualstack"===e.ipAddressType};if(e.elb){const n=e.elb;a.securityGroups=n.securityGroups,a.vpcId=n.vpcid||n.vpcId,n.listeners&&(a.listeners=n.listeners.map((e=>{const a=[];return e.certificates&&e.certificates.forEach((e=>{const t=e.certificateArn.split(":"),n=t[5].split("/");a.push({certificateArn:e.certificateArn,type:t[2],name:n[1]})})),(e.defaultActions||[]).forEach((e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,""))})),e.rules=(e.rules||[]).filter((e=>!e.default)),e.rules.forEach((e=>{(e.actions||[]).forEach((e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,""))})),e.conditions=e.conditions||[]})),e.rules.sort(((e,t)=>e.priority-t.priority)),{protocol:e.protocol,port:e.port,defaultActions:e.defaultActions,certificates:a,rules:e.rules||[],sslPolicy:e.sslPolicy}}))),n.targetGroups&&(a.targetGroups=n.targetGroups.map((e=>({name:e.targetGroupName.replace(`${t}-`,""),protocol:e.protocol,port:e.port,targetType:e.targetType,healthCheckProtocol:e.healthCheckProtocol,healthCheckPort:e.healthCheckPort,healthCheckTimeout:e.healthCheckTimeoutSeconds,healthCheckInterval:e.healthCheckIntervalSeconds,healthyThreshold:e.healthyThresholdCount,unhealthyThreshold:e.unhealthyThresholdCount,healthCheckPath:e.healthCheckPath,attributes:{deregistrationDelay:Number(e.attributes["deregistration_delay.timeout_seconds"]),deregistrationDelayConnectionTermination:Boolean("true"===e.attributes["deregistration_delay.connection_termination.enabled"]),preserveClientIp:Boolean("true"===e.attributes["preserve_client_ip.enabled"])}}))))}return a}static constructNewClassicLoadBalancerTemplate(e){return{availabilityZones:void 0,name:"",stack:"",detail:"",loadBalancerType:"classic",isInternal:!1,cloudProvider:"aws",credentials:e.defaultCredentials.aws||kn.defaults.account,region:e.defaultRegions.aws||kn.defaults.region,vpcId:null,subnetType:kn.defaults.subnetType,healthCheck:void 0,healthCheckProtocol:"HTTP",healthCheckPort:7001,healthCheckPath:"/healthcheck",healthTimeout:5,healthInterval:10,healthyThreshold:10,unhealthyThreshold:2,idleTimeout:60,regionZones:[],securityGroups:[],listeners:[{externalPort:80,externalProtocol:"HTTP",internalPort:7001,internalProtocol:"HTTP"}]}}static constructNewApplicationLoadBalancerTemplate(e){const t="targetgroup";return{name:"",availabilityZones:void 0,stack:"",detail:"",loadBalancerType:"application",ipAddressType:"ipv4",dualstack:!1,isInternal:!1,cloudProvider:"aws",credentials:e.defaultCredentials.aws||kn.defaults.account,region:e.defaultRegions.aws||kn.defaults.region,vpcId:null,subnetType:kn.defaults.subnetType,idleTimeout:60,deletionProtection:!1,targetGroups:[{name:t,protocol:"HTTP",port:e.attributes.instancePort||a.defaultInstancePort,targetType:"instance",healthCheckProtocol:"HTTP",healthCheckPort:"traffic-port",healthCheckPath:"/healthcheck",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:2,attributes:{deregistrationDelay:300,stickinessEnabled:!1,stickinessType:"lb_cookie",stickinessDuration:8400,multiValueHeadersEnabled:!1}}],regionZones:[],securityGroups:[],listeners:[{certificates:[],protocol:"HTTP",port:80,defaultActions:[{type:"forward",targetGroupName:t}],rules:[]}]}}static constructNewNetworkLoadBalancerTemplate(e){const t="targetgroup";return{name:"",availabilityZones:void 0,stack:"",detail:"",loadBalancerType:"network",isInternal:!1,ipAddressType:"ipv4",dualstack:!1,cloudProvider:"aws",credentials:e.defaultCredentials.aws||kn.defaults.account,region:e.defaultRegions.aws||kn.defaults.region,vpcId:null,subnetType:kn.defaults.subnetType,deletionProtection:!1,loadBalancingCrossZone:!0,securityGroups:[],targetGroups:[{name:t,protocol:"TCP",port:7001,targetType:"instance",healthCheckProtocol:"TCP",healthCheckPath:"/healthcheck",healthCheckPort:"traffic-port",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:10,attributes:{deregistrationDelay:300}}],regionZones:[],listeners:[{certificates:[],protocol:"TCP",port:80,defaultActions:[{type:"forward",targetGroupName:t}],rules:[]}]}}}var Lr=Object.defineProperty,Rr=Object.getOwnPropertyDescriptor;let Or=class extends Vt.Component{render(){return Vt.createElement("h3",null,"Target Group Details")}};Or=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Rr(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&Lr(t,a,i),i})([ie("loadBalancer.targetGroupDetails")],Or);var Vr=Object.defineProperty,Ur=Object.getOwnPropertyDescriptor;let qr=class extends Vt.Component{render(){const{certificates:e,accountName:t,onCertificateSelect:a,currentValue:n}=this.props,r=e[t]||[],i=r.map((e=>({label:e.serverCertificateName,value:e.serverCertificateName}))),s=r.find((e=>e.serverCertificateName===n));return Vt.createElement("div",{style:{width:"100%"}},Vt.createElement(rn,{className:"input-sm",wrapperStyle:{width:"100%"},clearable:!0,required:!0,options:i,onChange:e=>a(e.value),value:n}),s&&Vt.createElement("div",{className:"small sp-margin-xs-top sp-margin-m-bottom sp-margin-m-left"},Vt.createElement("div",null,"Uploaded ",se(s.uploadDate)," (",z(s.uploadDate),")"),Vt.createElement("b",null,"Expires ",se(s.expiration))," (",z(s.expiration),")"))}};qr=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Ur(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&Vr(t,a,i),i})([ie("amazon.certificateSelectField")],qr);const Hr=Vt.forwardRef(((e,t)=>Vt.createElement("div",{ref:t},Vt.createElement(s,{name:"idleTimeout",label:"Idle Timeout",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"deletionProtection",label:"Protection",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Vt.createElement(d,{...e,text:"Enable delete protection"})}),Vt.createElement(s,{name:"dualstack",label:"Dualstack",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.albIpAddressType"}),input:e=>Vt.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})}))));xr(".configure-config-modal .StandardFieldLayout .sm-label-right {\n min-width: 160px;\n}\n");const Wr=class extends Vt.Component{constructor(e){super(e),this.close=e=>{this.props.dismissModal(e)},this.submit=e=>{this.props.closeModal(e)},this.validate=()=>({});const t=e.config||{};this.state={initialValues:{authorizationEndpoint:t.authorizationEndpoint||"",clientId:t.clientId||"",clientSecret:t.clientSecret||"",issuer:t.issuer||"",scope:t.scope||"openid",sessionCookieName:t.sessionCookieName||"AWSELBAuthSessionCookie",tokenEndpoint:t.tokenEndpoint||"",userInfoEndpoint:t.userInfoEndpoint||""}}}static show(e){return b.show(Wr,e)}render(){const{initialValues:e}=this.state;return Vt.createElement("div",{className:"configure-config-modal"},Vt.createElement(le,{initialValues:e,onSubmit:this.submit,validate:this.validate,render:({isValid:e})=>Vt.createElement(dn,{className:"form-horizontal"},Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Configure OIDC Client")),Vt.createElement(Ha.Body,null,Vt.createElement(s,{name:"issuer",label:"Issuer",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter the OpenId Provider"})}),Vt.createElement(s,{name:"authorizationEndpoint",label:"Authorization Endpoint",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter OpenID provider server endpoint"})}),Vt.createElement(s,{name:"tokenEndpoint",label:"Token Endpoint",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter a URI for your token endpoint"})}),Vt.createElement(s,{name:"userInfoEndpoint",label:"User info Endpoint",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter a URI for your user info endpoint"})}),Vt.createElement(s,{name:"clientId",label:"Client ID",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter the client ID"})}),Vt.createElement(s,{name:"clientSecret",label:"Client secret",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter the client secret"})})),Vt.createElement(Ha.Footer,null,Vt.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Vt.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Client"})))}))}};let jr=Wr;jr.defaultProps={closeModal:C,dismissModal:C};const Zr=class extends Vt.Component{constructor(e){super(e),this.close=e=>{this.props.dismissModal(e)},this.submit=e=>{const t=na(e,(e=>e&&""!==e));this.props.closeModal(t)};const t=e.config||{};this.initialValues={host:t.host||"",path:t.path||"",port:t.port||"",protocol:t.protocol||void 0,query:t.query||"",statusCode:t.statusCode||"HTTP_301"}}static show(e){return b.show(Zr,e)}render(){return Vt.createElement("div",{className:"configure-config-modal"},Vt.createElement(le,{initialValues:this.initialValues,onSubmit:this.submit,render:({isValid:e})=>Vt.createElement(dn,{className:"form-horizontal"},Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Configure Redirect ",Vt.createElement(n,{id:"aws.loadBalancer.redirect"}))),Vt.createElement(Ha.Body,null,Vt.createElement(s,{name:"host",label:"Host",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.host"})}),Vt.createElement(s,{name:"path",label:"Path",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.path"})}),Vt.createElement(s,{name:"port",label:"Port",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.port"})}),Vt.createElement(s,{name:"protocol",label:"Protocol",required:!1,input:e=>Vt.createElement(c,{...e,stringOptions:["HTTP","HTTPS","#{protocol}"],placeholder:"Select Protocol",clearable:!1,style:{width:"130px"}}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.protocol"})}),Vt.createElement(s,{name:"query",label:"Query",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.query"})}),Vt.createElement(s,{name:"statusCode",label:"Status Code",required:!0,input:e=>Vt.createElement(de,{...e,options:["HTTP_301","HTTP_302"]}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.statusCode"})})),Vt.createElement(Ha.Footer,null,Vt.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Vt.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Config"})))}))}};let _r=Zr;_r.defaultProps={closeModal:C,dismissModal:C};class Kr{static getOidcConfigsByApp(e){return D("/oidcConfigs").query({app:e}).get()}}class Yr{static listCertificates(){return ue.listCertificatesByProvider("aws").then((e=>o.listAllAccounts("aws").then((t=>{const a=t.reduce(((e,t)=>(e[t.accountId]=t.name,e)),{}),n=Qt(e,"serverCertificateName");return ra(n,(e=>{const[,,,,t]=e.arn.split(":");return a[t]||"unknown"}))}))))}}const Xr=sn((()=>Vt.createElement("span",{className:"pipeline-drag-handle clickable glyphicon glyphicon-resize-vertical"}))),Jr={authenticateOidcConfig:{authorizationEndpoint:"",clientId:"",issuer:"",scope:"openid",sessionCookieName:"AWSELBAuthSessionCookie",tokenEndpoint:"",userInfoEndpoint:""},type:"authenticate-oidc"};class Qr extends Vt.Component{constructor(e){super(e),this.protocols=["HTTP","HTTPS"],this.initialActionsWithAuth=new Set,this.initialListenersWithDefaultAuth=new Set,this.removedAuthActions=new Map,this.attachClientSecret=(e,t)=>{if("authenticate-oidc"===e.type){const a=t.find((t=>t.clientId===e.authenticateOidcConfig.clientId));a&&(e.authenticateOidcConfig.clientSecret=a.clientSecret)}},this.addListener=()=>{this.props.formik.values.listeners.push({certificates:[],protocol:"HTTP",port:80,defaultActions:[{type:"forward",targetGroupName:""}],rules:[]}),this.updateListeners()},this.addRule=e=>{e.rules.push({priority:null,actions:[{type:"forward",targetGroupName:""}],conditions:[{field:"path-pattern",values:[""]}]}),this.updateListeners()},this.removeRule=(e,t)=>{e.rules.splice(t,1),this.updateListeners()},this.handleConditionFieldChanged=(e,t)=>{e.field=t,"http-request-method"===t&&(e.values=[]),this.updateListeners()},this.handleConditionValueChanged=(e,t)=>{e.values[0]=t,this.updateListeners()},this.handleHttpRequestMethodChanged=(e,t,a)=>{let n=e.values||[];a?n.push(t):n=n.filter((e=>e!==t)),e.values=n,e.httpRequestMethodConfig={values:n},this.updateListeners()},this.addCondition=e=>{if(1===e.conditions.length){const t="path-pattern"===e.conditions[0].field?"host-header":"path-pattern";e.conditions.push({field:t,values:[""]})}this.updateListeners()},this.removeCondition=(e,t)=>{e.conditions.splice(t,1),this.updateListeners()},this.handleRuleActionTargetChanged=(e,t)=>{e.targetGroupName=t,this.updateListeners()},this.handleRuleActionTypeChanged=(e,t)=>{e.type=t,"forward"===e.type?delete e.redirectActionConfig:"redirect"===e.type&&(e.redirectActionConfig={statusCode:"HTTP_301"},delete e.targetGroupName),this.updateListeners()},this.handleSortEnd=(e,t)=>{t.rules=ln(t.rules,e.oldIndex,e.newIndex),this.updateListeners()},this.configureOidcClient=e=>{jr.show({config:e.authenticateOidcConfig}).then((t=>{e.authenticateOidcConfig=t,this.updateListeners()})).catch((()=>{}))},this.configureRedirect=e=>{_r.show({config:e.redirectActionConfig}).then((t=>{e.redirectActionConfig=t,this.updateListeners()})).catch((()=>{}))},this.authenticateRuleToggle=(e,t)=>{const a=e.rules[t],n=a&&a.actions||e.defaultActions;if(n){const a=n.findIndex((e=>"authenticate-oidc"===e.type));if(-1!==a)this.removeAuthAction(e,n,a,t);else{const a=(this.removedAuthActions.has(e)?this.removedAuthActions.get(e)[t||-1]:void 0)||{...Jr};n.unshift({...a})}this.updateListeners()}},this.oidcConfigChanged=(e,t)=>{e.authenticateOidcConfig={...t},this.updateListeners()},this.redirectConfigChanged=(e,t)=>{e.redirectActionConfig={...t},this.updateListeners()},this.state={certificates:[],certificateTypes:ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),oidcConfigs:void 0},this.props.formik.initialValues.listeners.forEach((e=>{"authenticate-oidc"===e.defaultActions[0].type&&this.initialListenersWithDefaultAuth.add(e),e.rules.forEach((e=>{"authenticate-oidc"===e.actions[0].type&&this.initialActionsWithAuth.add(e.actions)}))}))}getAllTargetGroupsFromListeners(e){const t=Kt(e.map((e=>e.defaultActions))),a=Kt(e.map((e=>e.rules)));return t.push(...Kt(a.map((e=>e.actions)))),sa(t.map((e=>e.targetGroupName)))}validate(e){const t={},a=e.targetGroups.map((e=>e.name)),n=this.getAllTargetGroupsFromListeners(e.listeners),r=la(a,n);1===r.length?t.listeners=`Target group ${r[0]} is unused.`:r.length>1&&(t.listeners=`Target groups ${r.join(", ")} are unused.`);const{listeners:i}=e;Zt(i,"port").length<i.length&&(t.listenerPorts="Multiple listeners cannot use the same port.");return e.listeners.find((e=>{const t=!!e.defaultActions.find((e=>"forward"===e.type&&!e.targetGroupName||"authenticate-oidc"===e.type&&!e.authenticateOidcConfig.clientId||"redirect"===e.type&&(!e.redirectActionConfig||!oa(e.redirectActionConfig,(e=>e&&""!==e))))),a=!!e.rules.find((e=>{const t=!!e.actions.find((e=>"forward"===e.type&&!e.targetGroupName)),a=!!e.actions.find((e=>"authenticate-oidc"===e.type&&!e.authenticateOidcConfig.clientId)),n=!!e.conditions.find((e=>"http-request-method"===e.field?!e.values.length:e.values.includes("")));return t||a||n}));return t||a}))&&(t.listeners="Missing fields in rule configuration."),t}componentDidMount(){this.loadCertificates(),this.loadOidcClients()}loadCertificates(){Yr.listCertificates().then((e=>{this.setState({certificates:e})}))}loadOidcClients(){Kr.getOidcConfigsByApp(this.props.app.name).then((e=>{e&&e.length&&this.props.formik.values.listeners.forEach((t=>{t.defaultActions.forEach((t=>this.attachClientSecret(t,e))),t.rules.forEach((t=>t.actions.forEach((t=>this.attachClientSecret(t,e)))))})),this.setState({oidcConfigs:e}),this.updateListeners()})).catch((()=>{}))}updateListeners(){this.props.formik.setFieldValue("listeners",this.props.formik.values.listeners)}needsCert(e){return"HTTPS"===e.protocol}showCertificateSelect(e){return"iam"===e.type&&this.state.certificates&&Object.keys(this.state.certificates).length>0}addListenerCertificate(e){e.certificates=e.certificates||[],e.certificates.push({certificateArn:void 0,type:"iam",name:void 0})}removeAuthActions(e){const t=e.defaultActions.findIndex((e=>"authenticate-oidc"===e.type));-1!==t&&this.removeAuthAction(e,e.defaultActions,t,-1),e.rules.forEach(((t,a)=>{const n=t.actions.findIndex((e=>"authenticate-oidc"===e.type));-1!==n&&this.removeAuthAction(e,t.actions,n,a)})),this.updateListeners()}reenableAuthActions(e){const t=this.removedAuthActions.has(e)?this.removedAuthActions.get(e):[],a=t[-1];a&&(t[-1]=void 0,e.defaultActions.unshift({...a})),e.rules.forEach(((e,a)=>{const n=t[a];t[a]=void 0,n&&e.actions.unshift({...n})}))}listenerProtocolChanged(e,t){e.protocol=t,"HTTPS"===e.protocol&&(e.port=443,e.certificates&&0!==e.certificates.length||this.addListenerCertificate(e),this.reenableAuthActions(e)),"HTTP"===e.protocol&&(e.port=80,e.certificates.length=0,this.removeAuthActions(e)),this.updateListeners()}listenerPortChanged(e,t){e.port=Number.parseInt(t,10),this.updateListeners()}certificateTypeChanged(e,t){e.type=t,this.updateListeners()}handleCertificateChanged(e,t){e.name=t,this.updateListeners()}removeListener(e){this.props.formik.values.listeners.splice(e,1),this.updateListeners()}removeAuthActionInternal(e,t,a,n=-1){const r=t.splice(a,1)[0];this.removedAuthActions.has(e)||this.removedAuthActions.set(e,[]),this.removedAuthActions.get(e)[n||-1]=r,this.updateListeners()}removeAuthAction(e,t,a,n=-1){const r=-1===n&&this.initialListenersWithDefaultAuth.has(e),i=n>-1&&this.initialActionsWithAuth.has(t);r||i?S.confirm({header:"Really remove authentication?",buttonText:"Remove Auth",submitMethod:()=>(this.removeAuthActionInternal(e,t,a,n),r&&this.initialListenersWithDefaultAuth.delete(e),i&&this.initialActionsWithAuth.delete(t),Xa.resolve())}):this.removeAuthActionInternal(e,t,a,n)}render(){const{errors:e,values:t}=this.props.formik,{certificates:a,certificateTypes:n,oidcConfigs:r}=this.state;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},t.listeners.map(((e,i)=>Vt.createElement("div",{key:i,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Vt.createElement("div",{className:"wizard-pod-row-contents spread"},Vt.createElement("div",null,Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol"),Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"80px"},value:e.protocol,onChange:t=>this.listenerProtocolChanged(e,t.target.value)},this.protocols.map((e=>Vt.createElement("option",{key:e},e))))),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port"),Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",min:0,value:e.port||"",onChange:t=>this.listenerPortChanged(e,t.target.value),style:{width:"80px"},required:!0}))),Vt.createElement("div",null,Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(i)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))))),this.needsCert(e)&&Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Vt.createElement("div",{className:"wizard-pod-row-contents"},e.certificates.map(((e,r)=>Vt.createElement("div",{key:r,style:{width:"100%",display:"flex",flexDirection:"row"}},Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"45px"},value:e.type,onChange:t=>this.certificateTypeChanged(e,t.target.value)},n.map((e=>Vt.createElement("option",{key:e},e)))),this.showCertificateSelect(e)&&Vt.createElement(qr,{certificates:a,accountName:t.credentials,currentValue:e.name,app:this.props.app,onCertificateSelect:t=>this.handleCertificateChanged(e,t)}),!this.showCertificateSelect(e)&&Vt.createElement("input",{className:"form-control input-sm no-spel",style:{display:"inline-block"},type:"text",value:e.name,onChange:t=>this.handleCertificateChanged(e,t.target.value),required:!0})))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Vt.createElement("table",{className:"table table-condensed packed rules-table"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{style:{width:"15px",padding:"0"}}),Vt.createElement("th",null,"If"),Vt.createElement("th",{style:{width:"315px"}},"Then"),Vt.createElement("th",{style:{width:"45px"}}))),Vt.createElement(ni,{addCondition:this.addCondition,addRule:this.addRule,authenticateRuleToggle:this.authenticateRuleToggle,distance:10,handleConditionFieldChanged:this.handleConditionFieldChanged,handleConditionValueChanged:this.handleConditionValueChanged,handleHttpRequestMethodChanged:this.handleHttpRequestMethodChanged,handleRuleActionTargetChanged:this.handleRuleActionTargetChanged,handleRuleActionTypeChanged:this.handleRuleActionTypeChanged,listener:e,helperClass:"rule-sortable-helper",removeRule:this.removeRule,removeCondition:this.removeCondition,targetGroups:t.targetGroups,oidcConfigs:r,oidcConfigChanged:this.oidcConfigChanged,redirectConfigChanged:this.redirectConfigChanged,onSortEnd:t=>this.handleSortEnd(t,e),configureOidcClient:this.configureOidcClient,configureRedirect:this.configureRedirect})))))))),e.listenerPorts&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listenerPorts})),e.listeners&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listeners})),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}const ei=on((e=>Vt.createElement("tr",{className:"listener-rule"},Vt.createElement("td",{className:"handle"},Vt.createElement(Xr,null)),Vt.createElement("td",null,e.rule.conditions.map(((t,a)=>Vt.createElement("div",{key:a,className:"listener-rule-condition"},Vt.createElement("select",{className:"form-control input-sm inline-number",value:t.field,onChange:a=>e.handleConditionFieldChanged(t,a.target.value),style:{width:"40%"},required:!0},(1===e.rule.conditions.length||"host-header"===t.field)&&Vt.createElement("option",{value:"host-header"},"Host"),(1===e.rule.conditions.length||"path-pattern"===t.field)&&Vt.createElement("option",{value:"path-pattern"},"Path"),(1===e.rule.conditions.length||"http-request-method"===t.field)&&Vt.createElement("option",{value:"http-request-method"},"Method(s)")),"path-pattern"===t.field&&Vt.createElement(n,{id:"aws.loadBalancer.ruleCondition.path"}),"host-header"===t.field&&Vt.createElement(n,{id:"aws.loadBalancer.ruleCondition.host"}),"http-request-method"!==t.field&&Vt.createElement("input",{className:"form-control input-sm",type:"text",value:t.values[0],onChange:a=>e.handleConditionValueChanged(t,a.target.value),maxLength:128,required:!0,style:{width:"63%"}}),"http-request-method"===t.field&&Vt.createElement("div",{className:"col-md-6 checkbox"},["DELETE","GET","PATCH","POST","PUT"].map((a=>Vt.createElement("label",{key:`${a}-checkbox`},Vt.createElement("input",{type:"checkbox",checked:t.values.includes(a),onChange:n=>e.handleHttpRequestMethodChanged(t,a,n.target.checked)}),a)))),Vt.createElement("span",{className:"remove-condition"},1===a&&Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeCondition(e.rule,a),style:{padding:"0"}},Vt.createElement(_,{value:"Remove Condition"},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))))))),1===e.rule.conditions.length&&Vt.createElement("div",{className:"add-new-container"},Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addCondition(e.rule)},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new condition")),Vt.createElement("span",{style:{minWidth:"15px"}}))),Vt.createElement("td",null,e.rule.actions.map(((t,a)=>Vt.createElement(ti,{key:a,action:t,actionTypeChanged:a=>e.handleRuleActionTypeChanged(t,a),oidcConfigChanged:a=>e.oidcConfigChanged(t,a),redirectConfigChanged:a=>e.redirectConfigChanged(t,a),targetChanged:a=>e.handleRuleActionTargetChanged(t,a),targetGroups:e.targetGroups,oidcConfigs:e.oidcConfigs,configureOidcClient:e.configureOidcClient,configureRedirect:e.configureRedirect})))),Vt.createElement("td",null,Vt.createElement(ai,{ruleIndex:e.ruleIndex,listener:e.listener,authenticateRuleToggle:e.authenticateRuleToggle,removeRule:e.removeRule,actions:e.rule.actions}))))),ti=e=>{var t;if("authenticate-oidc"!==e.action.type){const t=e.action.redirectActionConfig||e.action.redirectConfig;return Vt.createElement("div",{className:"horizontal top"},Vt.createElement("select",{className:"form-control input-sm",style:{width:"80px"},value:e.action.type,onChange:t=>e.actionTypeChanged(t.target.value)},Vt.createElement("option",{value:"forward"},"forward to"),Vt.createElement("option",{value:"redirect"},"redirect to")),"forward"===e.action.type&&Vt.createElement("select",{className:"form-control input-sm",value:e.action.targetGroupName,onChange:t=>e.targetChanged(t.target.value),required:!0},Vt.createElement("option",{value:""}),sa(e.targetGroups.map((e=>e.name))).map((e=>Vt.createElement("option",{key:e},e)))),"redirect"===e.action.type&&Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Host"),Vt.createElement("dd",null,t.host),Vt.createElement("dt",null,"Path"),Vt.createElement("dd",null,t.path),Vt.createElement("dt",null,"Port"),Vt.createElement("dd",null,t.port),Vt.createElement("dt",null,"Protocol"),Vt.createElement("dd",null,t.protocol),Vt.createElement("dt",null,"Query"),Vt.createElement("dd",null,t.query),Vt.createElement("dt",null,"Status Code"),Vt.createElement("dd",null,t.statusCode),Vt.createElement("dt",null,Vt.createElement("button",{className:"btn btn-link no-padding",type:"button",onClick:()=>e.configureRedirect(e.action)},"Configure..."))))}if("authenticate-oidc"===e.action.type){const a=e.action.authenticateOidcConfig.clientId,n=ia(kn,"loadBalancers.disableManualOidcDialog",!1)||e.oidcConfigs&&e.oidcConfigs.length>0&&(!a||e.oidcConfigs.find((e=>e.clientId===a))),r=(null==(t=e.oidcConfigs)?void 0:t.length)?e.oidcConfigs.map((e=>Vt.createElement("option",{key:e.clientId},e.clientId))):Vt.createElement("option",{disabled:!0},"No ",me.get("OIDC client")," config found");return Vt.createElement("div",{className:"horizontal middle",style:{height:"30px"}},Vt.createElement("span",{style:{whiteSpace:"pre"}},"auth with ",me.get("OIDC client")," "),n&&Vt.createElement("select",{className:"form-control input-sm",value:a,onChange:t=>e.oidcConfigChanged(e.oidcConfigs.find((e=>e.clientId===t.target.value))),required:!0},Vt.createElement("option",{value:""}),r),!n&&Vt.createElement("a",{onClick:()=>e.configureOidcClient(e.action),className:"clickable"},a||"Configure..."),Vt.createElement("span",{style:{whiteSpace:"pre"}},Vt.createElement("em",null," and then")))}return null},ai=e=>{const t=Boolean(e.actions.find((e=>"authenticate-oidc"===e.type))),a="HTTPS"===e.listener.protocol,r=t?"Remove authentication from rule":"Authenticate rule",i=t?"fas fa-fw fa-lock-open":"fas fa-fw fa-user-lock";return Vt.createElement("span",null,a&&Vt.createElement(Vt.Fragment,null,Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.authenticateRuleToggle(e.listener,e.ruleIndex),style:{padding:"0"}},Vt.createElement(_,{value:r},Vt.createElement("i",{className:i}))),Vt.createElement(n,{id:"aws.loadBalancer.oidcAuthentication"})),void 0!==e.ruleIndex&&e.ruleIndex>=0&&e.removeRule&&Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeRule(e.listener,e.ruleIndex),style:{padding:"0"}},Vt.createElement(_,{value:"Remove Rule"},Vt.createElement("i",{className:"far fa-fw fa-trash-alt"}))))},ni=cn((e=>Vt.createElement("tbody",null,Vt.createElement("tr",{className:"not-sortable"},Vt.createElement("td",null),Vt.createElement("td",null,"Default"),Vt.createElement("td",null,e.listener.defaultActions.map(((t,a)=>Vt.createElement(ti,{key:a,action:t,actionTypeChanged:a=>e.handleRuleActionTypeChanged(t,a),targetChanged:a=>e.handleRuleActionTargetChanged(t,a),targetGroups:e.targetGroups,oidcConfigs:e.oidcConfigs,oidcConfigChanged:a=>e.oidcConfigChanged(t,a),redirectConfigChanged:a=>e.redirectConfigChanged(t,a),configureOidcClient:e.configureOidcClient,configureRedirect:e.configureRedirect})))),Vt.createElement("td",null,Vt.createElement(ai,{listener:e.listener,actions:e.listener.defaultActions,authenticateRuleToggle:e.authenticateRuleToggle}))),e.listener.rules.sort(((e,t)=>e.priority-t.priority)).map(((t,a)=>Vt.createElement(ei,{key:a,rule:t,addCondition:e.addCondition,handleConditionFieldChanged:e.handleConditionFieldChanged,handleConditionValueChanged:e.handleConditionValueChanged,handleHttpRequestMethodChanged:e.handleHttpRequestMethodChanged,handleRuleActionTargetChanged:e.handleRuleActionTargetChanged,handleRuleActionTypeChanged:e.handleRuleActionTypeChanged,oidcConfigChanged:e.oidcConfigChanged,redirectConfigChanged:e.redirectConfigChanged,removeCondition:e.removeCondition,authenticateRuleToggle:e.authenticateRuleToggle,removeRule:e.removeRule,targetGroups:e.targetGroups,oidcConfigs:e.oidcConfigs,listener:e.listener,index:a,ruleIndex:a,configureOidcClient:e.configureOidcClient,configureRedirect:e.configureRedirect}))),Vt.createElement("tr",{className:"not-sortable"},Vt.createElement("td",{colSpan:5},Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addRule(e.listener)},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new rule"))))))),ri=(e,t,a)=>n=>ia(e,[t,a],[]).includes(n.toLowerCase())?`There is already a target group in ${t}:${a} with that name.`:null,ii=e=>t=>t.length<32-e?null:"Target group names are automatically prefixed with their application name and cannot exceed 32 characters in length.";class si extends Vt.Component{constructor(e){super(e),this.protocols=["HTTP","HTTPS"],this.targetTypes=["instance","ip","lambda"],this.destroy$=new Ta,this.addTargetGroup=()=>{const{setFieldValue:e,values:t}=this.props.formik,a=t.targetGroups.length;t.targetGroups.push({name:"targetgroup"+(a?`${a}`:""),protocol:"HTTP",port:7001,targetType:"instance",healthCheckProtocol:"HTTP",healthCheckPort:"7001",healthCheckPath:"/healthcheck",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:2,attributes:{deregistrationDelay:300,stickinessEnabled:!1,stickinessType:"lb_cookie",stickinessDuration:8400}}),e("targetGroups",t.targetGroups)};const t=e.isNew?0:e.formik.initialValues.targetGroups.length;this.state={existingTargetGroupNames:{},oldTargetGroupCount:t}}validate(e){const t=sa(Kt(ea(ra(e.targetGroups,"name"),(e=>e.length>1))).map((e=>e.name))),a=new i(e),{arrayForEach:n}=a;return a.field("targetGroups").withValidators(n(((a,n)=>{var r;a.field("name","Name").withValidators(ri(this.state.existingTargetGroupNames,e.credentials,e.region),ii(this.props.app.name.length),ge.valueUnique(t,"There is already a target group in this load balancer with the same name.")),a.field("healthCheckInterval","Health Check Interval").withValidators((r=n,e=>"TCP"!==r.healthCheckProtocol||"TCP"===r.healthCheckProtocol&&(10===Number.parseInt(e,10)||30===Number.parseInt(e,10))?null:"TCP health checks only support 10s and 30s intervals"),ge.checkBetween("healthCheckInterval",5,300)),a.field("healthyThreshold","Healthy Threshold").withValidators(ge.checkBetween("healthyThreshold",2,10)),a.field("unhealthyThreshold","Unhealthy Threshold").spelAware().withValidators(ge.checkBetween("unhealthyThreshold",2,10)),a.field("healthCheckTimeout","Timeout").withValidators((e=>t=>{const a=ca(t)?t:Number.parseInt(t,10),{protocol:n,healthCheckProtocol:r}=e;if("TCP"===n||"TLS"===n){if("HTTP"===r&&6!==a)return"HTTP health check timeouts for TCP/TLS target groups must be 6s";if(("HTTPS"===r||"TLS"===r)&&10!==a)return"HTTPS/TLS health check timeouts for TCP/TLS target groups must be 10s"}return null})(n),ge.checkBetween("healthCheckTimeout",2,120)),"lambda"!==n.targetType&&(a.field("protocol","Protocol").required(),a.field("healthCheckPath","Health Check Path").required(),a.field("healthCheckProtocol","Health Check Protocol").required(),a.field("name","Name").required(),a.field("healthyThreshold","Healthy Threshold").required().spelAware().withValidators((e=>he(e))),a.field("unhealthyThreshold","Unhealthy Threshold").required().spelAware().withValidators((e=>he(e))),a.field("healthCheckInterval","Health Check Interval").required().spelAware().withValidators((e=>he(e))),a.field("healthCheckPort","Health Check Port").required().spelAware().withValidators((e=>"traffic-port"===e?null:he(e))),a.field("port","Port").required().spelAware().withValidators((e=>he(e))),a.field("healthyThreshold","Healthy Threshold").required().spelAware().withValidators((e=>he(e)),ge.checkBetween("healthyThreshold",2,10)),a.field("unhealthyThreshold","Unhealthy Threshold").required().spelAware().withValidators((e=>he(e)),ge.checkBetween("unhealthyThreshold",2,10)))}))),a.validateForm()}removeAppName(e){return e.replace(`${this.props.app.name}-`,"")}updateLoadBalancerNames(e){const{app:t,loadBalancer:a}=e,n={};Ia(t.getDataSource("loadBalancers").refresh(!0)).pipe($a(this.destroy$)).subscribe((()=>{t.getDataSource("loadBalancers").data.forEach((e=>{"classic"!==e.loadBalancerType&&(a&&e.name===a.name||e.targetGroups.forEach((t=>{n[e.account]=n[e.account]||{},n[e.account][e.region]=n[e.account][e.region]||[],n[e.account][e.region].push(this.removeAppName(t.name))})))})),this.setState({existingTargetGroupNames:n},(()=>this.props.formik.validateForm()))}))}targetGroupFieldChanged(e,t,a){const{setFieldValue:n,values:r}=this.props.formik,i=r.targetGroups[e];"targetType"===t&&"lambda"===a&&delete i.port,da(i,t,a),n("targetGroups",r.targetGroups)}removeTargetGroup(e){const{setFieldValue:t,values:a}=this.props.formik,{oldTargetGroupCount:n}=this.state;a.targetGroups.splice(e,1),e<n&&this.setState({oldTargetGroupCount:n-1}),t("targetGroups",a.targetGroups)}componentDidMount(){this.updateLoadBalancerNames(this.props)}componentWillUnmount(){this.destroy$.next(),this.destroy$.complete()}render(){const{app:e}=this.props,{errors:t,values:a}=this.props.formik,{oldTargetGroupCount:r}=this.state,i=this.protocols.map((e=>Vt.createElement("option",{key:e},e))),s=this.targetTypes.map((e=>Vt.createElement("option",{key:e},e)));return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},a.targetGroups.map(((a,l)=>{const o=t.targetGroups&&t.targetGroups[l]||{},c=("TCP"===a.protocol||"TLS"===a.protocol)&&"HTTP"===a.healthCheckProtocol,d=("TCP"===a.protocol||"TLS"===a.protocol)&&"HTTPS"===a.healthCheckProtocol;return Vt.createElement("div",{key:l,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"group-name-prefix"},e.name,"-"),Vt.createElement("input",{className:"form-control input-sm target-group-name",type:"text",value:a.name,onChange:e=>this.targetGroupFieldChanged(l,"name",e.target.value),required:!0,disabled:l<r}),Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(l)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))),o.name&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:o.name})))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},Vt.createElement(n,{id:"aws.targetGroup.targetType"})," ",Vt.createElement("span",null,"Target Type ")),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("select",{className:"form-control input-sm",value:a.targetType,onChange:e=>this.targetGroupFieldChanged(l,"targetType",e.target.value),disabled:l<r},s))))),"lambda"!==a.targetType&&Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),Vt.createElement(n,{id:"aws.targetGroup.protocol"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",value:a.protocol,onChange:e=>this.targetGroupFieldChanged(l,"protocol",e.target.value),disabled:l<r},i)),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(n,{id:"aws.targetGroup.port"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",value:a.port,onChange:e=>this.targetGroupFieldChanged(l,"port",e.target.value),type:"text",required:!0,disabled:l<r}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},"lambda"!==a.targetType&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),"TCP"===a.healthCheckProtocol&&Vt.createElement(n,{id:"aws.targetGroup.healthCheckProtocol"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",value:a.healthCheckProtocol,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckProtocol",e.target.value)},i)),"lambda"!==a.targetType&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(n,{id:"aws.targetGroup.attributes.healthCheckPort.trafficPort"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"90px"},value:"traffic-port"===a.healthCheckPort?"traffic-port":"manual",onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPort","traffic-port"===e.target.value?"traffic-port":"")},Vt.createElement("option",{value:"traffic-port"},"Traffic Port"),Vt.createElement("option",{value:"manual"},"Manual"))," ",Vt.createElement(fe,{className:"form-control input-sm inline-number",error:o.healthCheckPort,style:{visibility:"traffic-port"===a.healthCheckPort?"hidden":"inherit"},name:"healthCheckPort",required:!0,value:a.healthCheckPort,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPort",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Path "),Vt.createElement(fe,{error:o.healthCheckPath,name:"healthCheckPath",required:!0,value:a.healthCheckPath,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPath",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Timeout "),(c||d)&&Vt.createElement(n,{id:"aws.targetGroup.healthCheckTimeout"}),Vt.createElement(ve,{error:o.healthCheckTimeout,disabled:c||d,required:!0,value:c?6:d?10:a.healthCheckTimeout,min:2,max:120,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckTimeout",e)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Interval "),Vt.createElement(ve,{error:o.healthCheckInterval,required:!0,value:a.healthCheckInterval,min:5,max:300,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckInterval",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck Threshold"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Healthy "),Vt.createElement(ve,{error:o.healthyThreshold,value:a.healthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"healthyThreshold",e)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Unhealthy "),Vt.createElement(ve,{error:o.unhealthyThreshold,required:!0,value:a.unhealthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"unhealthyThreshold",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),"lambda"!==a.targetType?Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Dereg. Delay"),Vt.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",value:a.attributes.deregistrationDelay,onChange:e=>this.targetGroupFieldChanged(l,"attributes.deregistrationDelay",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Vt.createElement("input",{type:"checkbox",checked:a.attributes.stickinessEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.stickinessEnabled",e.target.checked)})," ",Vt.createElement("label",null,"Sticky"),Vt.createElement(n,{id:"aws.targetGroup.attributes.stickinessEnabled"}))),a.attributes.stickinessEnabled&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Duration "),Vt.createElement(n,{id:"aws.targetGroup.attributes.stickinessDuration"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",value:a.attributes.stickinessDuration,onChange:e=>this.targetGroupFieldChanged(l,"attributes.stickinessDuration",e.target.value),type:"text"})))):Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Vt.createElement("input",{type:"checkbox",checked:a.attributes.multiValueHeadersEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.multiValueHeadersEnabled",e.target.checked)})," ",Vt.createElement("label",null,"Enable Multi Value Headers"))))))})),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}}class li extends Vt.Component{constructor(e){super(e),this.handleUsePreferredZonesChanged=e=>{const t="true"===e.target.value;this.setState({usePreferredZones:t}),t&&this.setDefaultZones(t,this.props)},this.handleSelectedZonesChanged=e=>{this.props.onChange([...e])},this.state={defaultZones:[],usePreferredZones:e.usePreferredZones||!e.selectedZones||0===e.selectedZones.length},this.setDefaultZones(this.state.usePreferredZones,e)}componentWillReceiveProps(e){e.region===this.props.region&&e.credentials===this.props.credentials||this.setDefaultZones(this.state.usePreferredZones,e)}setDefaultZones(e,t){const{credentials:a,region:n}=t;o.getAvailabilityZonesForAccountAndRegion("aws",a,n).then((a=>{this.setState({defaultZones:a}),e&&a&&t.onChange(a.slice())}))}render(){const{region:e,allZones:t,selectedZones:a}=this.props,{defaultZones:n,usePreferredZones:r}=this.state;return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Availability Zones"),e&&Vt.createElement("div",{className:"col-md-7"},Vt.createElement("p",{className:"form-control-static"},"Automatic Availability Zone Balancing:"),Vt.createElement("select",{className:"form-control input-sm",value:r?"true":"false",onChange:this.handleUsePreferredZonesChanged},Vt.createElement("option",{value:"true"},"Enabled"),Vt.createElement("option",{value:"false"},"Manual")),Vt.createElement("br",null),r&&Vt.createElement("div",null,Vt.createElement("p",{className:"form-control-static"},"Server group will be available in:"),Vt.createElement("ul",null,n.map((e=>Vt.createElement("li",{key:e},e))))),!r&&Vt.createElement("div",null,"Restrict server group instances to:",Vt.createElement(ye,{stringOptions:t,value:a,onChange:e=>this.handleSelectedZonesChanged(e.target.value)}))))}}function oi(e){const{application:t,credentials:a,defaultSubnetTypes:n,hideClassic:r,name:i,onChange:s,readOnly:l,region:o,subnets:c,value:d,...u}=e,p=be(c),m=Vt.useMemo((()=>{const e=r||function(e,t,a){const{classicLaunchLockout:n,classicLaunchAllowlist:r}=kn,i=Number(ia(a,"attributes.createTs",0))>(n||0),s=!!r&&r.some((a=>a.region===e&&a.credentials===t));return i||!s}(o,a,t);return function(e,t){const a=(e,t)=>e.label.localeCompare(t.label),n=e=>({value:e.purpose,label:e.label}),r=t?[]:[{label:"None (EC2 Classic)",value:""}],i=e.filter((e=>!e.deprecated)).sort(a).map(n),s=e.filter((e=>e.deprecated)).sort(a).map(n);return s.length&&s.unshift({label:"-----------",value:"",disabled:!0}),r.concat(i).concat(s)}(c,e)}),[r,o,a,t,p]),g=function(e,t=[]){for(const a of t){const t=e.find((e=>a===e.purpose));if(t)return t}}(c,n)||c[0],h=Ee().current;return Vt.useEffect((()=>{const e=m.some((e=>e.value===d));g&&(!e||"FIRST_RENDER"!==h)&&s(we({name:i,value:g.purpose}))}),[m]),l?Vt.createElement("p",{className:"form-control-static"},e.value||"None (EC2 Classic)"):Vt.createElement(de,{options:m,value:d,onChange:s,...u})}class ci extends Ot.Component{constructor(){super(...arguments),this.handleChange=e=>{const{component:t,onChange:a,field:n}=this.props;t[n]=e.target.value,a()}}render(){var e,t,a;const{component:r,defaultSubnetTypes:i,field:s,helpKey:l,labelColumns:o,recommendedSubnetTypes:c,region:d,showSubnetWarning:u,...p}=this.props,m=r[s],g=null!=(t=null!=c?c:null==(e=kn.serverGroups)?void 0:e.recommendedSubnets)?t:[],h=null!=i?i:[kn.defaults.subnetType],f=g.some((e=>m&&m.includes(e))),v=null==(a=kn.serverGroups)?void 0:a.subnetWarning;return Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:`col-md-${o} sm-label-right`},"VPC Subnet ",Ot.createElement(n,{id:l})),Ot.createElement("div",{className:"col-md-7"},d?Ot.createElement(oi,{...p,inputClassName:"form-control input-sm",credentials:r.credentials,defaultSubnetTypes:h,region:d,value:m,onChange:this.handleChange}):"(Select an account)",u&&!f&&Boolean(v)&&Ot.createElement("div",{className:"alert alert-warning sp-margin-s-top horizontal center"},Ot.createElement("i",{className:"fa fa-exclamation-triangle sp-margin-s-top"}),Ot.createElement("div",{className:"sp-margin-s-left"},Ot.createElement(Ce,{message:v,style:{display:"inline-block",marginLeft:"2px"}})))))}}class di extends Vt.Component{constructor(){super(...arguments),this.state={accounts:void 0,availabilityZones:[],existingLoadBalancerNames:[],hideInternalFlag:!1,internalFlagToggled:!1,regions:[],subnets:[]},this.props$=new Ta,this.destroy$=new Ta,this.internalFlagChanged=e=>{this.setState({internalFlagToggled:!0}),this.props.formik.handleChange(e)},this.handleSubnetUpdated=e=>{this.props.formik.setFieldValue("subnetType",e)},this.accountUpdated=e=>{this.props.formik.setFieldValue("credentials",e)},this.regionUpdated=e=>{this.props.formik.setFieldValue("region",e)},this.stackChanged=e=>{this.props.formik.setFieldValue("stack",e.target.value)},this.detailChanged=e=>{this.props.formik.setFieldValue("detail",e.target.value)},this.handleAvailabilityZonesChanged=e=>{this.props.formik.setFieldValue("regionZones",e)}}validate(e){const t={};return this.state.existingLoadBalancerNames.includes(e.name)&&(t.name=`There is already a load balancer in ${e.credentials}:${e.region} with that name.`),e.name&&e.name.length>32&&(t.name="Load balancer names cannot exceed 32 characters in length"),e.stack&&!e.stack.match(/^[a-zA-Z0-9]*$/)&&(t.stack="Stack can only contain letters and numbers."),e.detail&&!e.detail.match(/^[a-zA-Z0-9-]*$/)&&(t.detail="Detail can only contain letters, numbers, and dashes."),t}buildName(){const{values:e}=this.props.formik;if(Yt(e.moniker)){const t=re.parseLoadBalancerName(e.name);e.stack=t.stack,e.detail=t.freeFormDetails}else e.stack=e.moniker.stack,e.detail=e.moniker.detail;delete e.name}shouldHideInternalFlag(){return!!(kn&&kn.loadBalancers&&kn.loadBalancers.inferInternalFlagFromSubnet)&&(delete this.props.formik.values.isInternal,!0)}componentDidMount(){this.setState({hideInternalFlag:this.shouldHideInternalFlag()}),this.props.loadBalancer&&this.props.isNew&&this.buildName();const e=this.props$.pipe(Da((e=>e.formik.values))),t=this.props$.pipe(Da((e=>e.app.name)),Ba()),a={account$:e.pipe(Da((e=>e.credentials)),Ba()),region$:e.pipe(Da((e=>e.region)),Ba()),subnetPurpose$:e.pipe(Da((e=>e.subnetType)),Ba()),stack$:e.pipe(Da((e=>e.stack)),Ba()),detail$:e.pipe(Da((e=>e.detail)),Ba())},n=Ia(o.listAccounts("aws")).pipe(za(1)),r=Ga([a.account$,n]).pipe(Fa((([e,t])=>o.getRegionsForAccount(e))),za(1)),i=this.props.app.getDataSource("loadBalancers").data$,s=Ga([i,a.account$,a.region$]).pipe(Da((([e,t,a])=>e.filter((e=>e.account===t&&e.region===a)).map((e=>e.name)))),za(1)),l=Ga([a.account$,a.region$]).pipe(Fa((([e,t])=>this.getAvailableSubnets(e,t))),Da((e=>this.makeSubnetOptions(e))),za(1)),c=Ga([l,a.subnetPurpose$]).pipe(Da((([e,t])=>e&&e.find((e=>e.purpose===t))))),d=c.pipe(Da((e=>e?sa(e.availabilityZones).sort():[]))),u=a.region$.pipe(Ma(r),Da((([e,t])=>t.find((t=>t.name===e)))),Da((e=>e?e.availabilityZones:[]))),p=Ga([t,a.stack$,a.detail$]).pipe(Da((([e,t,a])=>({app:e,stack:t,detail:a,cluster:re.getClusterName(e,t,a)}))));r.pipe(Ma(a.region$),$a(this.destroy$)).subscribe((([e,t])=>{e.some((e=>e.name===t))||this.props.formik.setFieldValue("region",e[0]&&e[0].name)})),u.pipe($a(this.destroy$)).subscribe((e=>{this.props.formik.setFieldValue("regionZones",e)})),c.pipe($a(this.destroy$)).subscribe((e=>{this.props.formik.setFieldValue("vpcId",e&&e.vpcIds[0]),this.props.formik.setFieldValue("subnetType",e&&e.purpose),!this.state.hideInternalFlag&&!this.state.internalFlagToggled&&e&&e.purpose&&this.props.formik.setFieldValue("isInternal",e.purpose.includes("internal"))})),p.pipe($a(this.destroy$)).subscribe((e=>{this.props.formik.setFieldValue("moniker",e),this.props.formik.setFieldValue("name",e.cluster)})),Ga([n,r,d,s,l]).pipe($a(this.destroy$)).subscribe((([e,t,a,n,r])=>this.setState({accounts:e,regions:t,availabilityZones:a,existingLoadBalancerNames:n,subnets:r})))}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}getAvailableSubnets(e,t){return g.listSubnets().then((a=>ta(a).filter({account:e,region:t}).reject({target:"ec2"}).reject({purpose:null}).value()))}makeSubnetOptions(e){const t=ra(e,(e=>e.purpose));return Object.keys(t).map((e=>t[e])).map((e=>(e=>{const{purpose:t,label:a,deprecated:n}=e[0];return{purpose:t,label:a,deprecated:n,vpcIds:sa(e.map((e=>e.vpcId))),availabilityZones:sa(e.map((e=>e.availabilityZone)))}})(e)))}render(){const{app:e}=this.props,{errors:t,values:a}=this.props.formik,{accounts:r,availabilityZones:i,hideInternalFlag:s,regions:l,subnets:o}=this.state,c=Na({"col-md-12":!0,well:!0,"alert-danger":!!t.name,"alert-info":!t.name});return Vt.createElement("div",{className:"container-fluid form-horizontal"},!r&&Vt.createElement("div",{style:{height:"200px"}},Vt.createElement(ae,{size:"medium"})),r&&Vt.createElement("div",{className:"modal-body"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:c},Vt.createElement("strong",null,"Your load balancer will be named: "),Vt.createElement("span",null,a.name),Vt.createElement(n,{id:"aws.loadBalancer.name"}),Vt.createElement(un,{type:"text",style:{display:"none"},className:"form-control input-sm no-spel",name:"name"}),t.name&&Vt.createElement(pe,{type:"error",message:t.name}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Vt.createElement("div",{className:"col-md-7"},Vt.createElement(Se,{value:a.credentials,onChange:e=>this.accountUpdated(e.target.value),accounts:r,provider:"aws"}))),Vt.createElement(ke,{labelColumns:3,component:a,field:"region",account:a.credentials,onChange:this.regionUpdated,regions:l}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Vt.createElement(n,{id:"aws.loadBalancer.stack"})),Vt.createElement("div",{className:"col-md-3"},Vt.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.stack?"invalid":""),value:a.stack,name:"stack",onChange:this.stackChanged})),Vt.createElement("div",{className:"col-md-6 form-inline"},Vt.createElement("label",{className:"sm-label-right"},Vt.createElement("span",null,"Detail ",Vt.createElement(n,{id:"aws.loadBalancer.detail"})," ")),Vt.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.detail?"invalid":""),value:a.detail,name:"detail",onChange:this.detailChanged})),t.stack&&Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement(pe,{type:"error",message:t.stack})),t.detail&&Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement(pe,{type:"error",message:t.detail}))),Vt.createElement(li,{credentials:a.credentials,region:a.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:a.regionZones,allZones:i}),Vt.createElement(ci,{labelColumns:3,helpKey:"aws.loadBalancer.subnet",component:a,field:"subnetType",region:a.region,subnets:o,application:e,onChange:()=>this.handleSubnetUpdated(a.subnetType)}),a.vpcId&&!s&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},Vt.createElement("b",null,"Internal")," ",Vt.createElement(n,{id:"aws.loadBalancer.internal"})),Vt.createElement("div",{className:"col-md-7 checkbox"},Vt.createElement("label",null,Vt.createElement(un,{name:"isInternal",onChange:this.internalFlagChanged,render:({field:{value:e,...t}})=>Vt.createElement("input",{type:"checkbox",...t,checked:!!e})}),"Create an internal load balancer")))))}}class ui extends Vt.Component{constructor(e){super(e),this.destroy$=new Ta,this.props$=new Ta,this.refresh$=new Ta,this.clearRemoved=()=>{this.setState({removed:[]},(()=>this.props.formik.validateForm()))},this.handleSecurityGroupsChanged=e=>{this.props.formik.setFieldValue("securityGroups",e.map((e=>e.value)))};const t=ia(kn,"defaultSecurityGroups",[]);this.state={availableSecurityGroups:[],defaultSecurityGroups:t,loaded:!1,refreshing:!1,removed:[],refreshTime:Ne.get("securityGroups").getStats().ageMax}}validate(){const{removed:e}=this.state;if(e&&e.length){return{securityGroupsRemoved:`${U.get("Firewalls")} removed: ${e.join(", ")}`}}return{}}updateRemovedSecurityGroups(e,t){const{isNew:a}=this.props,{defaultSecurityGroups:n,removed:r}=this.state,i=e=>t.find((t=>t.name===e||t.id===e)),[s,l]=ua((()=>{const t=e.concat(r).sort();return sa((a?n:[]).concat(t))})(),(e=>!!i(e))),o=s.map((e=>i(e).name));Jt(e,o)||this.props.formik.setFieldValue("securityGroups",o),this.setState({removed:l},(()=>this.props.formik.validateForm()))}onRefreshStart(){this.props.onLoadingChanged(!0),this.setState({refreshing:!0})}onRefreshComplete(){this.props.onLoadingChanged(!1);const e=Ne.get("securityGroups").getStats().ageMax;this.setState({refreshing:!1,loaded:!0,refreshTime:e})}componentDidMount(){const e=this.refresh$.pipe(La((()=>this.onRefreshStart())),Fa((()=>h.cacheInitializer.refreshCache("securityGroups"))),Ra((()=>h.securityGroupReader.getAllSecurityGroups())),La((()=>this.onRefreshComplete()))),t=this.props$.pipe(Da((e=>e.formik.values))),a=t.pipe(Da((e=>e.vpcId)),Ba());Ga([a,e]).pipe(Ma(t),Da((([[e,t],a])=>{const n=t[a.credentials]||{};return(n.aws&&n.aws[a.region]||[]).filter((t=>e===t.vpcId)).sort()}))).pipe(Ma(t),$a(this.destroy$)).subscribe((([e,t])=>{this.setState({availableSecurityGroups:e.map((e=>({label:`${e.name} (${e.id})`,value:e.name})))}),this.updateRemovedSecurityGroups(t.securityGroups,e)})),this.refresh$.next()}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next(),this.destroy$.complete()}render(){const{securityGroups:e}=this.props.formik.values,{availableSecurityGroups:t,loaded:a,refreshing:n,removed:r,refreshTime:i}=this.state;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",null,r.length>0&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following ",U.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,r.map((e=>Vt.createElement("li",{key:e},e)))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:this.clearRemoved},"Okay"))))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},U.get("Firewalls")),Vt.createElement("div",{className:"col-md-9"},!a&&Vt.createElement("div",{style:{paddingTop:"13px"}},Vt.createElement(ae,{size:"small"})),a&&Vt.createElement(pn,{multi:!0,value:e,options:t,onChange:this.handleSecurityGroupsChanged,clearable:!1}))),Vt.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Vt.createElement("div",{className:"col-md-9 col-md-offset-3"},Vt.createElement("p",null,n&&Vt.createElement("span",null,Vt.createElement("span",{className:"fa fa-sync-alt fa-spin"})," "),U.get("Firewalls"),!n&&Vt.createElement("span",null," last refreshed ",z(i)),n&&Vt.createElement("span",null," refreshing...")),Vt.createElement("p",null,"If you're not finding a ",U.get("firewall")," that was recently added,"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.refresh$.next()},"click here")," ","to refresh the list.")))))}}xr(".wizard-pod {\n padding-bottom: 15px;\n}\n.wizard-pod > div {\n border: 1px solid var(--color-cirrus);\n}\n.wizard-pod .wizard-pod-row {\n display: flex;\n padding: 5px;\n border-bottom: 1px solid var(--color-cirrus);\n}\n.wizard-pod .wizard-pod-row label {\n font-weight: 400;\n padding-right: 5px;\n}\n.wizard-pod .wizard-pod-row.header {\n background-color: var(--color-cirrus);\n}\n.wizard-pod .wizard-pod-row.header .glyphicon-trash {\n padding: 0 8px;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-title {\n font-weight: 800;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-data {\n flex-wrap: nowrap;\n padding: 0;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-data label {\n font-weight: 600;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-data .wizard-pod-content {\n padding: 0 10px 0 0;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-title {\n display: flex;\n align-items: center;\n max-height: 37px;\n flex-basis: 120px;\n flex-direction: row-reverse;\n font-weight: 600;\n text-align: right;\n margin-right: 10px;\n width: 100px;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents {\n display: flex;\n width: 100%;\n align-items: baseline;\n flex-wrap: wrap;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data {\n display: flex;\n width: 100%;\n align-items: baseline;\n flex-wrap: wrap;\n padding: 5px 0;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data.spread {\n justify-content: space-between;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .wizard-pod-content {\n padding: 0 10px 5px 0;\n display: flex;\n align-items: center;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .group-name-prefix {\n flex-grow: 2;\n white-space: nowrap;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .rules-table thead th {\n font-weight: 600;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .rules-table td {\n vertical-align: middle;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .rules-table > tbody > tr:first-child > td {\n border-top: none;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-errors {\n display: flex;\n width: 100%;\n}\n.wizard-pod .listener-rule .handle {\n cursor: move;\n width: 10px;\n padding: 0;\n}\n.wizard-pod .listener-rule .listener-rule-condition {\n display: flex;\n}\n.wizard-pod .listener-rule .listener-rule-condition label {\n white-space: nowrap;\n}\n.wizard-pod .listener-rule .listener-rule-condition .help-field > span {\n top: 4px;\n padding: 0 2px;\n}\n.wizard-pod .listener-rule .listener-rule-condition .remove-condition {\n min-width: 15px;\n padding-top: 4px;\n}\n.wizard-pod .listener-rule .add-new-container {\n display: flex;\n}\n.wizard-pod .listener-rule .add-new-container .add-new {\n padding: 2px;\n margin-bottom: 0;\n}\n.rule-sortable-helper {\n z-index: 99999;\n width: 500px;\n}\n");const pi=class extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.submit=e=>{const{app:t,forPipelineConfig:a,closeModal:n}=this.props,{isNew:r}=this.state,i=r?"Create":"Update",s=_t(e);if(s.listeners.forEach((e=>{e.defaultActions.forEach((e=>{e.authenticateOidcConfig&&(e.authenticateOidcActionConfig=e.authenticateOidcConfig,delete e.authenticateOidcConfig)})),e.rules.forEach((e=>e.actions.forEach((e=>{e.authenticateOidcConfig&&(e.authenticateOidcActionConfig=e.authenticateOidcConfig,delete e.authenticateOidcConfig)}))))})),a)this.formatListeners(s).then((()=>{this.setIpAddressType(s),n&&n(s)}));else{const e=new v({application:t,title:(r?"Creating":"Updating")+" your load balancer",modalInstance:v.modalInstanceEmulation((()=>this.props.dismissModal())),onTaskComplete:()=>this.onTaskComplete(s)});e.submit((()=>this.formatListeners(s).then((()=>(this.formatCommand(s),Te.upsertLoadBalancer(s,t,i)))))),this.setState({taskMonitor:e})}};const t=e.command?e.command:e.loadBalancer?$r.convertApplicationLoadBalancerForEditing(e.loadBalancer):$r.constructNewApplicationLoadBalancerTemplate(e.app);this.state={includeSecurityGroups:!!t.vpcId,isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(pi,e,{dialogClassName:"wizard-modal modal-lg"})}certificateIdAsARN(e,t,a,n){if(t&&(0!==t.indexOf("arn:aws:iam::")||0!==t.indexOf("arn:aws:acm:"))){if("iam"===n)return`arn:aws:iam::${e}:server-certificate/${t}`;if("acm"===n)return`arn:aws:acm:${a}:${e}:certificate/${t}`}return t}formatListeners(e){return o.getAccountDetails(e.credentials).then((t=>{e.listeners.forEach((a=>{"HTTP"===a.protocol&&(delete a.sslPolicy,a.certificates=[]),a.certificates.forEach((a=>{a.certificateArn=this.certificateIdAsARN(t.accountId,a.name,e.region,a.type||this.certificateTypes[0])}))}))}))}setAvailabilityZones(e){const t={};t[e.region]=e.regionZones||[],e.availabilityZones=t}addAppName(e){return`${this.props.app.name}-${e}`}manageTargetGroupNames(e){(e.targetGroups||[]).forEach((e=>{e.name=this.addAppName(e.name)})),(e.listeners||[]).forEach((e=>{e.defaultActions.forEach((e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))})),(e.rules||[]).forEach((e=>{e.actions.forEach((e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))}))}))}))}manageRules(e){e.listeners.forEach((e=>{e.rules.forEach(((e,t)=>{e.priority=t+1,e.conditions=e.conditions.filter((e=>"http-request-method"!==e.field?e.values[0].length>0:e.values.length>0))}))}))}setIpAddressType(e){e.ipAddressType=e.dualstack?"dualstack":"ipv4",delete e.dualstack}formatCommand(e){this.setAvailabilityZones(e),this.manageTargetGroupNames(e),this.manageRules(e),this.setIpAddressType(e)}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.loadBalancerDetails")?h.$state.go("^.loadBalancerDetails",t):h.$state.go(".loadBalancerDetails",t)}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onTaskComplete(e){this.props.app.loadBalancers.refresh(),this.refreshUnsubscribe=this.props.app.loadBalancers.onNextRefresh(null,(()=>this.onApplicationRefresh(e)))}render(){const{app:e,dismissModal:t,forPipelineConfig:a,loadBalancer:n}=this.props,{isNew:r,loadBalancerCommand:i,taskMonitor:s}=this.state;let l=a?"Configure Application Load Balancer":"Create New Application Load Balancer";return r||(l=`Edit ${i.name}: ${i.region}: ${i.credentials}`),Vt.createElement(E,{heading:l,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",render:({formik:t,nextIdx:i,wizard:s})=>{const l=r||a,o=!!t.values.vpcId;return Vt.createElement(Vt.Fragment,null,l&&Vt.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Vt.createElement(di,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),o&&Vt.createElement(w,{label:U.get("Firewalls"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Vt.createElement(ui,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Vt.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(si,{ref:a,app:e,formik:t,isNew:r,loadBalancer:n})}),Vt.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(Qr,{ref:a,app:e,formik:t})}),Vt.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(Hr,{ref:e})}))}})}};let mi=pi;mi.defaultProps={closeModal:C,dismissModal:C};xr(".AmazonLoadBalancer-AdvancedSettings .StandardFieldLayout .sm-label-right {\n width: 180px;\n}\n");class gi extends Vt.Component{render(){const{values:e}=this.props.formik,{maxValue:t}=ge;return Vt.createElement("div",{className:"form-group AmazonLoadBalancer-AdvancedSettings"},Vt.createElement(s,{name:"healthTimeout",label:"Timeout",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.healthTimeout"}),input:t=>Vt.createElement(p,{...t,min:0,max:e.healthInterval}),validate:t(e.healthInterval,"Timeout must be less than the health interval.")}),Vt.createElement(s,{name:"healthInterval",label:"Interval",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.healthInterval"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"healthyThreshold",label:"Healthy Threshold",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.healthyThreshold"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"unhealthyThreshold",label:"Unhealthy Threshold",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.unhealthyThreshold"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"idleTimeout",label:"Idle Timeout",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement("div",{className:"col-md-12"},Vt.createElement("p",null,"Additional configuration options (cross-zone load balancing, session stickiness, access logs) are available via the AWS console.")))}}class hi extends Vt.Component{constructor(){super(...arguments),this.healthCheckPathChanged=e=>{e&&0!==e.indexOf("/")&&this.props.formik.setFieldValue("healthCheckPath",`/${e}`)}}requiresHealthCheckPath(){const{values:e}=this.props.formik;return e.healthCheckProtocol&&0===e.healthCheckProtocol.indexOf("HTTP")}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},"Ping"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{style:{width:"35%"}},"Protocol"),Vt.createElement("th",{style:{width:"30%"}},"Port"),Vt.createElement("th",null,this.requiresHealthCheckPath()&&Vt.createElement("span",null,"Path")))),Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement(s,{name:"healthCheckProtocol",required:!0,input:e=>Vt.createElement(de,{...e,options:["HTTP","HTTPS","SSL","TCP"]})})),Vt.createElement("td",null,Vt.createElement(s,{name:"healthCheckPort",required:!0,input:e=>Vt.createElement(p,{...e,min:1,max:65534})})),Vt.createElement("td",null,this.requiresHealthCheckPath()&&Vt.createElement(s,{name:"healthCheckPath",input:e=>Vt.createElement(l,{...e}),required:!0,onChange:this.healthCheckPathChanged})))))))}}xr(".create-classic-load-balancer-wizard-listeners .Select-control {\n height: 30px;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-placeholder {\n line-height: 26px;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-value {\n line-height: 26px !important;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-value .Select-value-label {\n line-height: 26px;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-input {\n height: 26px;\n}\n");class fi extends Vt.Component{constructor(){super(...arguments),this.protocols=["HTTP","HTTPS","TCP","SSL"],this.secureProtocols=["HTTPS","SSL"],this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.state={certificates:[]},this.addListener=()=>{this.props.formik.values.listeners.push({internalProtocol:"HTTP",externalProtocol:"HTTP",externalPort:80,internalPort:80}),this.updateListeners()}}componentDidMount(){this.loadCertificates()}loadCertificates(){Yr.listCertificates().then((e=>{this.setState({certificates:e})}))}updateListeners(){const{values:e,setFieldValue:t}=this.props.formik;t("listeners",e.listeners)}showCertificateSelect(e){return"iam"===e.sslCertificateType&&this.state.certificates&&Object.keys(this.state.certificates).length>0}listenerExternalProtocolChanged(e,t){e.externalProtocol=t,this.secureProtocols.includes(t)&&(e.externalPort=443,this.certificateTypes.length>=1&&(e.sslCertificateType=this.certificateTypes[0])),"HTTP"===t&&(e.externalPort=80),this.updateListeners()}listenerInternalProtocolChanged(e,t){e.internalProtocol=t,this.updateListeners()}listenerExternalPortChanged(e,t){e.externalPort=Number.parseInt(t,10),this.updateListeners()}listenerInternalPortChanged(e,t){e.internalPort=Number.parseInt(t,10),this.updateListeners()}listenerCertificateTypeChanged(e,t){e.sslCertificateType=t,this.updateListeners()}handleListenerCertificateChanged(e,t){e.sslCertificateName=t,this.updateListeners()}removeListener(e){this.props.formik.values.listeners.splice(e,1),this.updateListeners()}renderCertificateSelector(e){if(this.secureProtocols.includes(e.externalProtocol)){if(this.showCertificateSelect(e)){const{values:t}=this.props.formik,{certificates:a}=this.state;return Vt.createElement(qr,{certificates:a,accountName:t.credentials,currentValue:e.sslCertificateName,app:this.props.app,onCertificateSelect:t=>this.handleListenerCertificateChanged(e,t)})}return Vt.createElement("input",{className:"input-sm",style:{width:"100%",marginLeft:"10px"},required:!0,onChange:t=>this.handleListenerCertificateChanged(e,t.target.value),value:e.sslCertificateName})}return null}render(){const{values:e}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal create-classic-load-balancer-wizard-listeners"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",null,"External Protocol"),Vt.createElement("th",null,"External Port"),Vt.createElement("th",null),Vt.createElement("th",null,"Internal Protocol"),Vt.createElement("th",null,"Internal Port"),Vt.createElement("th",null))),Vt.createElement("tbody",null,e.listeners.map(((e,t)=>Vt.createElement(Vt.Fragment,{key:t},Vt.createElement("tr",{key:t+"-main"},Vt.createElement("td",null,Vt.createElement("select",{className:"form-control input-sm",value:e.externalProtocol,onChange:t=>this.listenerExternalProtocolChanged(e,t.target.value)},this.protocols.map((e=>Vt.createElement("option",{key:e},e))))),Vt.createElement("td",null,Vt.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.externalPort,onChange:t=>this.listenerExternalPortChanged(e,t.target.value),required:!0})),Vt.createElement("td",{className:"small",style:{paddingTop:"10px"}},"→"),Vt.createElement("td",null,Vt.createElement("select",{className:"form-control input-sm",value:e.internalProtocol,onChange:t=>this.listenerInternalProtocolChanged(e,t.target.value)},this.protocols.map((e=>Vt.createElement("option",{key:e},e))))),Vt.createElement("td",null,Vt.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.internalPort,onChange:t=>this.listenerInternalPortChanged(e,t.target.value),required:!0})),Vt.createElement("td",null,Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(t)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"})))),this.secureProtocols.includes(e.externalProtocol)&&Vt.createElement("tr",{key:t+"-ssl"},Vt.createElement("td",{colSpan:5,style:{borderTopWidth:0}},Vt.createElement("div",{className:"horizontal space-between"},Vt.createElement("div",{className:"sm-label-right"},"Certificate"),this.certificateTypes.length>1&&Vt.createElement("select",{style:{width:"45px",marginLeft:"10px"},className:"form-control input-sm",value:e.sslCertificateType,onChange:t=>this.listenerCertificateTypeChanged(e,t.target.value)},this.certificateTypes.map((e=>Vt.createElement("option",{key:e},e)))),this.renderCertificateSelector(e)))))))),Vt.createElement("tfoot",null,Vt.createElement("tr",null,Vt.createElement("td",{colSpan:5},Vt.createElement("button",{className:"add-new col-md-12",onClick:this.addListener,type:"button"},Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),Vt.createElement("span",null," Add new port mapping")))))))))}}const vi=class extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.submit=e=>{const{app:t,forPipelineConfig:a,closeModal:n}=this.props,{isNew:r}=this.state,i=r?"Create":"Update",s=_t(e);if(a)this.formatListeners(s).then((()=>{n&&n(s)}));else{const e=new v({application:t,title:(r?"Creating":"Updating")+" your load balancer",modalInstance:v.modalInstanceEmulation((()=>this.props.dismissModal())),onTaskComplete:()=>this.onTaskComplete(s)});e.submit((()=>this.formatListeners(s).then((()=>(this.formatCommand(s),Te.upsertLoadBalancer(s,t,i)))))),this.setState({taskMonitor:e})}},this.validate=e=>({});const t=e.command?e.command:e.loadBalancer?$r.convertClassicLoadBalancerForEditing(e.loadBalancer):$r.constructNewClassicLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(vi,e,{dialogClassName:"wizard-modal modal-lg"})}certificateIdAsARN(e,t,a,n){if(t&&(0!==t.indexOf("arn:aws:iam::")||0!==t.indexOf("arn:aws:acm:"))){if("iam"===n)return`arn:aws:iam::${e}:server-certificate/${t}`;if("acm"===n)return`arn:aws:acm:${a}:${e}:certificate/${t}`}return t}formatListeners(e){return o.getAccountDetails(e.credentials).then((t=>{e.listeners.forEach((a=>{a.sslCertificateId=this.certificateIdAsARN(t.accountId,a.sslCertificateName,e.region,a.sslCertificateType||this.certificateTypes[0])}))}))}clearSecurityGroupsIfNotInVpc(e){e.vpcId||e.subnetType||(e.securityGroups=null)}addHealthCheckToCommand(e){let t=null;const a=e.healthCheckProtocol||"";t=a.startsWith("HTTP")?`${a}:${e.healthCheckPort}${e.healthCheckPath}`:`${a}:${e.healthCheckPort}`,e.healthCheck=t}setAvailabilityZones(e){const t={};t[e.region]=e.regionZones||[],e.availabilityZones=t}formatCommand(e){this.setAvailabilityZones(e),this.clearSecurityGroupsIfNotInVpc(e),this.addHealthCheckToCommand(e)}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.loadBalancerDetails")?h.$state.go("^.loadBalancerDetails",t):h.$state.go(".loadBalancerDetails",t)}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onTaskComplete(e){this.props.app.loadBalancers.refresh(),this.refreshUnsubscribe=this.props.app.loadBalancers.onNextRefresh(null,(()=>this.onApplicationRefresh(e)))}render(){const{app:e,dismissModal:t,forPipelineConfig:a,loadBalancer:n}=this.props,{isNew:r,loadBalancerCommand:i,taskMonitor:s}=this.state,l=r||a;let o=a?"Configure Classic Load Balancer":"Create New Classic Load Balancer";return r||(o=`Edit ${i.name}: ${i.region}: ${i.credentials}`),Vt.createElement(E,{heading:o,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",validate:this.validate,render:({formik:t,nextIdx:i,wizard:s})=>Vt.createElement(Vt.Fragment,null,l&&Vt.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Vt.createElement(di,{app:e,formik:t,isNew:r,forPipelineConfig:a,loadBalancer:n,ref:i})}),!!t.values.vpcId&&Vt.createElement(w,{label:U.get("Firewall"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Vt.createElement(ui,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Vt.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(fi,{ref:a,formik:t,app:e})}),Vt.createElement(w,{label:"Health Check",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(hi,{ref:e,formik:t})}),Vt.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(gi,{ref:e,formik:t})}))})}};let yi=vi;yi.defaultProps={closeModal:C,dismissModal:C};const bi=Vt.forwardRef(((e,t)=>Vt.createElement("div",{ref:t},Vt.createElement(s,{name:"deletionProtection",label:"Protection",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Vt.createElement(d,{...e,text:"Enable deletion protection"})}),Vt.createElement(s,{name:"loadBalancingCrossZone",label:"Cross-Zone Load Balancing",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.loadBalancingCrossZone"}),input:e=>Vt.createElement(d,{...e,text:"Distribute traffic across zones"})}),e.showDualstack&&Vt.createElement(s,{name:"dualstack",label:"Dualstack",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.nlbIpAddressType"}),input:e=>Vt.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})}))));function Ei({availableCertificates:e,certificates:t,formik:a,app:n,certificateTypes:r}){function i(){a.setFieldValue("listeners",a.values.listeners)}function s(e,t){e.name=t,i()}function l(e){return"iam"===e.type&&t&&Object.keys(t).length>0}const{values:o}=a;return Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Vt.createElement("div",{className:"wizard-pod-row-contents"},e.map(((e,a)=>Vt.createElement("div",{key:a,style:{width:"100%",display:"flex",flexDirection:"row"}},Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"45px"},value:e.type,onChange:t=>function(e,t){e.type=t,i()}(e,t.target.value)},r.map((e=>Vt.createElement("option",{key:e},e)))),l(e)&&Vt.createElement(qr,{certificates:t,accountName:o.credentials,currentValue:e.name,app:n,onCertificateSelect:t=>s(e,t)}),!l(e)&&Vt.createElement("input",{className:"form-control input-sm no-spel",style:{display:"inline-block"},type:"text",value:e.name,onChange:t=>s(e,t.target.value),required:!0}))))))}class wi extends Vt.Component{constructor(e){super(e),this.protocols=["TCP","UDP","TLS"],this.removedAuthActions=new Map,this.addListener=()=>{this.props.formik.values.listeners.push({certificates:[],protocol:"TCP",port:80,defaultActions:[{type:"forward",targetGroupName:""}],rules:[]}),this.updateListeners()},this.handleDefaultTargetChanged=(e,t)=>{e.defaultActions[0].targetGroupName=t,this.updateListeners()},this.state={certificates:[],certificateTypes:ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),oidcConfigs:void 0}}getAllTargetGroupsFromListeners(e){const t=Kt(e.map((e=>e.defaultActions))),a=Kt(e.map((e=>e.rules)));return t.push(...Kt(a.map((e=>e.actions)))),sa(t.map((e=>e.targetGroupName)))}validate(e){const t={},a=e.targetGroups.map((e=>e.name)),n=this.getAllTargetGroupsFromListeners(e.listeners),r=la(a,n);1===r.length?t.listeners=`Target group ${r[0]} is unused.`:r.length>1&&(t.listeners=`Target groups ${r.join(", ")} are unused.`);const{listeners:i}=e;return Zt(i,"port").length<i.length&&(t.listenerPorts="Multiple listeners cannot use the same port."),t}updateListeners(){this.props.formik.setFieldValue("listeners",this.props.formik.values.listeners)}componentDidMount(){this.loadCertificates()}addListenerCertificate(e){e.certificates=e.certificates||[],e.certificates.push({certificateArn:void 0,type:"iam",name:void 0})}loadCertificates(){Yr.listCertificates().then((e=>{this.setState({certificates:e})}))}listenerProtocolChanged(e,t){e.protocol=t,"TCP"===e.protocol?e.port=80:"UDP"===e.protocol?e.port=53:"TLS"===e.protocol&&(e.port=443,e.certificates&&0!==e.certificates.length||this.addListenerCertificate(e),this.reenableAuthActions(e)),this.updateListeners()}reenableAuthActions(e){const t=this.removedAuthActions.has(e)?this.removedAuthActions.get(e):[],a=t[-1];a&&(t[-1]=void 0,e.defaultActions.unshift({...a})),e.rules.forEach(((e,a)=>{const n=t[a];t[a]=void 0,n&&e.actions.unshift({...n})}))}listenerPortChanged(e,t){e.port=Number.parseInt(t,10),this.updateListeners()}removeListener(e){this.props.formik.values.listeners.splice(e,1),this.updateListeners()}render(){const{errors:e,values:t}=this.props.formik,{certificates:a,certificateTypes:n}=this.state;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},t.listeners.map(((e,r)=>Vt.createElement("div",{key:r,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Vt.createElement("div",{className:"wizard-pod-row-contents spread"},Vt.createElement("div",null,Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol"),Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"80px"},value:e.protocol,onChange:t=>this.listenerProtocolChanged(e,t.target.value)},this.protocols.map((e=>Vt.createElement("option",{key:e},e))))),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port"),Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",min:0,value:e.port||"",onChange:t=>this.listenerPortChanged(e,t.target.value),style:{width:"80px"},required:!0}))),Vt.createElement("div",null,Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(r)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))))),Vt.createElement("div",null,"TLS"===e.protocol&&Vt.createElement(Ei,{availableCertificates:e.certificates,formik:this.props.formik,app:this.props.app,certificateTypes:n,certificates:a})),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title",style:{height:"30px"}},"Rules"),Vt.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Vt.createElement("table",{className:"table table-condensed packed rules-table"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{style:{width:"10px",padding:"0"}}),Vt.createElement("th",{style:{width:"226px"}},"If"),Vt.createElement("th",{style:{width:"75px"}},"Then"),Vt.createElement("th",null,"Target"),Vt.createElement("th",{style:{width:"30px"}}))),Vt.createElement("tbody",null,Vt.createElement("tr",{className:"not-sortable"},Vt.createElement("td",null),Vt.createElement("td",null,"Default"),Vt.createElement("td",null,"forward to"),Vt.createElement("td",null,Vt.createElement("select",{className:"form-control input-sm",value:e.defaultActions[0].targetGroupName,onChange:t=>this.handleDefaultTargetChanged(e,t.target.value),required:!0},Vt.createElement("option",{value:""}),sa(t.targetGroups.map((e=>e.name))).map((e=>Vt.createElement("option",{key:e},e))))),Vt.createElement("td",null)))))))))),e.listenerPorts&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listenerPorts})),e.listeners&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listeners})),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}class Ci extends Vt.Component{constructor(e){super(e),this.protocols=["TCP","UDP"],this.healthProtocols=["TCP","HTTP","HTTPS"],this.targetTypes=["instance","ip"],this.destroy$=new Ta,this.addTargetGroup=()=>{const{setFieldValue:e,values:t}=this.props.formik,a=t.targetGroups.length;t.targetGroups.push({name:"targetgroup"+(a?`${a}`:""),protocol:"TCP",port:7001,targetType:"instance",healthCheckProtocol:"TCP",healthCheckPort:"traffic-port",healthCheckPath:"/healthcheck",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:10,attributes:{deregistrationDelay:300,preserveClientIp:!0}}),e("targetGroups",t.targetGroups)};const t=e.isNew?0:e.formik.initialValues.targetGroups.length;this.state={existingTargetGroupNames:{},oldTargetGroupCount:t}}validate(e){const t=sa(Kt(ea(ra(e.targetGroups,"name"),(e=>e.length>1))).map((e=>e.name))),a=new i(e),{arrayForEach:n}=a;return a.field("targetGroups").withValidators(n((a=>{a.field("name","Name").required().withValidators(ri(this.state.existingTargetGroupNames,e.credentials,e.region),ii(this.props.app.name.length),ge.valueUnique(t,"There is already a target group in this load balancer with the same name.")),a.field("port","Port").required().spelAware().withValidators((e=>he(e))),a.field("healthCheckInterval","Health Check Interval").required().spelAware().withValidators((e=>he(e))),a.field("healthyThreshold","Healthy Threshold").required().spelAware().withValidators((e=>he(e))),a.field("unhealthyThreshold","Unhealthy Threshold").required().spelAware().withValidators((e=>he(e))),a.field("healthCheckPort","Health Check Port").required().spelAware().withValidators((e=>"traffic-port"===e?null:he(e))),a.field("protocol","Protocol").required(),a.field("healthCheckProtocol","Health Check Protocol").required()}))),a.validateForm()}removeAppName(e){return e.replace(`${this.props.app.name}-`,"")}updateLoadBalancerNames(e){const{app:t,loadBalancer:a}=e,n={};Ia(t.getDataSource("loadBalancers").refresh(!0)).pipe($a(this.destroy$)).subscribe((()=>{t.getDataSource("loadBalancers").data.forEach((e=>{"classic"!==e.loadBalancerType&&(a&&e.name===a.name||e.targetGroups.forEach((t=>{n[e.account]=n[e.account]||{},n[e.account][e.region]=n[e.account][e.region]||[],n[e.account][e.region].push(this.removeAppName(t.name))})))})),this.setState({existingTargetGroupNames:n},(()=>this.props.formik.validateForm()))}))}targetGroupFieldChanged(e,t,a){const{setFieldValue:n,values:r}=this.props.formik,i=r.targetGroups[e];da(i,t,a),"healthyThreshold"===t&&da(i,"unhealthyThreshold",a),n("targetGroups",r.targetGroups)}removeTargetGroup(e){const{setFieldValue:t,values:a}=this.props.formik,{oldTargetGroupCount:n}=this.state;a.targetGroups.splice(e,1),e<n&&this.setState({oldTargetGroupCount:n-1}),t("targetGroups",a.targetGroups)}componentDidMount(){this.updateLoadBalancerNames(this.props)}componentWillUnmount(){this.destroy$.next(),this.destroy$.complete()}render(){const{app:e}=this.props,{errors:t,values:a}=this.props.formik,{oldTargetGroupCount:r}=this.state,i=this.protocols.map((e=>Vt.createElement("option",{key:e},e))),s=this.healthProtocols.map((e=>Vt.createElement("option",{key:e},e))),l=this.targetTypes.map((e=>Vt.createElement("option",{key:e},e)));return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},a.targetGroups.map(((a,o)=>{const c=t.targetGroups&&t.targetGroups[o]||{};return Vt.createElement("div",{key:o,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"group-name-prefix"},e.name,"-"),Vt.createElement("input",{className:"form-control input-sm target-group-name",type:"text",value:a.name,onChange:e=>this.targetGroupFieldChanged(o,"name",e.target.value),required:!0,disabled:o<r}),Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(o)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))),c.name&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:c.name})))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},Vt.createElement(n,{id:"aws.targetGroup.targetType"})," ",Vt.createElement("span",null,"Target Type ")),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("select",{className:"form-control input-sm",value:a.targetType,onChange:e=>this.targetGroupFieldChanged(o,"targetType",e.target.value),disabled:o<r},l))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),Vt.createElement(n,{id:"aws.targetGroup.protocol"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",value:a.protocol,onChange:e=>this.targetGroupFieldChanged(o,"protocol",e.target.value),disabled:o<r},i)),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(n,{id:"aws.targetGroup.port"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",value:a.port,onChange:e=>this.targetGroupFieldChanged(o,"port",e.target.value),type:"text",required:!0,disabled:o<r}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),Vt.createElement("select",{disabled:o<r,className:"form-control input-sm inline-number",value:a.healthCheckProtocol,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckProtocol",e.target.value)},s)),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(fe,{className:"form-control input-sm inline-number",error:c.healthCheckPort,name:"healthCheckPort",required:!0,value:a.healthCheckPort,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckPort",e.target.value)})),"TCP"!==a.healthCheckProtocol&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Path "),Vt.createElement(fe,{className:"form-control input-sm inline-text",error:c.healthCheckPath,name:"healthCheckPath",required:!0,value:a.healthCheckPath,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckPath",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Timeout "),Vt.createElement(ve,{error:c.healthCheckTimeout,required:!0,value:a.healthCheckTimeout,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckTimeout",e)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Interval "),Vt.createElement(ve,{error:c.healthCheckInterval,required:!0,value:a.healthCheckInterval,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckInterval",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},Vt.createElement(n,{id:"aws.targetGroup.nlbHealthcheckThreshold"})," ",Vt.createElement("span",null,"Healthcheck Threshold ")),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement(ve,{error:c.healthyThreshold,value:a.healthyThreshold,onChange:e=>this.targetGroupFieldChanged(o,"healthyThreshold",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Dereg. Delay"),Vt.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",value:a.attributes.deregistrationDelay,onChange:e=>this.targetGroupFieldChanged(o,"attributes.deregistrationDelay",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement(d,{name:"deregistrationDelayConnectionTermination",text:"Connection Termination",checked:a.attributes.deregistrationDelayConnectionTermination,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.deregistrationDelayConnectionTermination",e.target.checked)}}),Vt.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelayConnectionTermination"})),"instance"!==a.targetType&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement(d,{name:"preserveClientIp",text:"Preserve Client IP",checked:a.attributes.preserveClientIp,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.preserveClientIp",e.target.checked)}}),Vt.createElement(n,{id:"aws.targetGroup.attributes.preserveClientIp"})))))))})),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}}const Si=class extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.submit=e=>{const{app:t,forPipelineConfig:a,closeModal:n}=this.props,{isNew:r}=this.state,i=r?"Create":"Update",s=_t(e);if(s.ipAddressType=s.dualstack?"dualstack":"ipv4",delete s.dualstack,a)this.formatListeners(s).then((()=>{n&&n(s)}));else{const e=new v({application:t,title:(r?"Creating":"Updating")+" your load balancer",modalInstance:v.modalInstanceEmulation((()=>this.props.dismissModal())),onTaskComplete:()=>this.onTaskComplete(s)});e.submit((()=>this.formatListeners(s).then((()=>(this.formatCommand(s),Te.upsertLoadBalancer(s,t,i)))))),this.setState({taskMonitor:e})}},this.validate=()=>({});const t=e.loadBalancer?$r.convertNetworkLoadBalancerForEditing(e.loadBalancer):$r.constructNewNetworkLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(Si,e,{dialogClassName:"wizard-modal modal-lg"})}certificateIdAsARN(e,t,a,n){if(t&&(0!==t.indexOf("arn:aws:iam::")||0!==t.indexOf("arn:aws:acm:"))){if("iam"===n)return`arn:aws:iam::${e}:server-certificate/${t}`;if("acm"===n)return`arn:aws:acm:${a}:${e}:certificate/${t}`}return t}formatListeners(e){return o.getAccountDetails(e.credentials).then((t=>{e.listeners.forEach((a=>{"TCP"===a.protocol&&(delete a.sslPolicy,a.certificates=[]),a.certificates.forEach((a=>{a.certificateArn=this.certificateIdAsARN(t.accountId,a.name,e.region,a.type||this.certificateTypes[0])}))}))}))}setAvailabilityZones(e){const t={};t[e.region]=e.regionZones||[],e.availabilityZones=t}addAppName(e){return`${this.props.app.name}-${e}`}manageTargetGroupNames(e){(e.targetGroups||[]).forEach((e=>{e.name=this.addAppName(e.name)})),(e.listeners||[]).forEach((e=>{e.defaultActions.forEach((e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))})),(e.rules||[]).forEach((e=>{e.actions.forEach((e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))}))}))}))}manageRules(e){e.listeners.forEach((e=>{e.rules.forEach(((e,t)=>{e.priority=t+1,e.conditions=e.conditions.filter((e=>e.values[0].length>0))}))}))}formatCommand(e){this.setAvailabilityZones(e),this.manageTargetGroupNames(e),this.manageRules(e)}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.loadBalancerDetails")?h.$state.go("^.loadBalancerDetails",t):h.$state.go(".loadBalancerDetails",t)}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onTaskComplete(e){this.props.app.loadBalancers.refresh(),this.refreshUnsubscribe=this.props.app.loadBalancers.onNextRefresh(null,(()=>this.onApplicationRefresh(e)))}render(){const{app:e,dismissModal:t,forPipelineConfig:a,loadBalancer:n}=this.props,{isNew:r,loadBalancerCommand:i,taskMonitor:s}=this.state;let l=a?"Configure Network Load Balancer":"Create New Network Load Balancer";r||(l=`Edit ${i.name}: ${i.region}: ${i.credentials}`);const o=r||a;return Vt.createElement(E,{heading:l,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",validate:this.validate,render:({formik:t,nextIdx:i,wizard:s})=>Vt.createElement(Vt.Fragment,null,o&&Vt.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Vt.createElement(di,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),Vt.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(Ci,{ref:a,formik:t,app:e,isNew:r,loadBalancer:n})}),Vt.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(wi,{ref:e,formik:t})}),Vt.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(bi,{ref:e,showDualstack:!t.values.isInternal&&pa(t.values.targetGroups,{targetType:"instance"})})}))})}};let ki=Si;ki.defaultProps={closeModal:C,dismissModal:C};const Ni=[{type:"application",label:"Application",sublabel:"ALB",description:"Highly configurable, application-focused balancer. HTTP and HTTPS only.",component:mi},{type:"network",label:"Network",sublabel:"NLB",description:"Basic, high-performance balancer with fixed IP.",component:ki},{type:"classic",label:"Classic",sublabel:"Legacy",description:"Previous generation balancer (ELB).",component:yi}],Ti=class extends Vt.Component{constructor(e){super(e),this.choose=()=>{const{children:e,...t}=this.props;this.close(),this.state.selectedChoice.component.show(t).then((e=>{this.props.closeModal(e)})).catch((()=>{}))},this.close=e=>{this.props.dismissModal(e)},this.state={choices:Ni,selectedChoice:Ni[0]}}static show(e){return b.show(Ti,{...e,className:"create-pipeline-modal-overflow-visible modal-lg"},{bsSize:"lg"})}choiceSelected(e){this.setState({selectedChoice:e})}getIncompatibility(e,t){const{loadBalancer:a={}}=V.getProvider(t),{incompatibleLoadBalancerTypes:n=[]}=a;return n.find((t=>t.type===e.type))}isIncompatibleWithAllProviders(e){const{app:{attributes:t}}=this.props,{cloudProviders:a=[]}=t;return a.length>0&&a.every((t=>!!this.getIncompatibility(e,t)))}render(){const{app:{attributes:e}}=this.props,{cloudProviders:t=[]}=e,{choices:a,selectedChoice:n}=this.state,r=a.filter((e=>!this.isIncompatibleWithAllProviders(e))),i=t.map((e=>this.getIncompatibility(n,e))).filter((e=>e)),s=kn.createLoadBalancerWarnings&&kn.createLoadBalancerWarnings[n.type];return Vt.createElement(Vt.Fragment,null,Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Select Type of Load Balancer")),Vt.createElement(Ha.Body,null,Vt.createElement("div",{className:"modal-body"},Vt.createElement("div",{className:"card-choices"},r.map((e=>Vt.createElement("div",{key:e.type,className:"card "+(n===e?"active":""),onClick:()=>this.choiceSelected(e)},Vt.createElement("h3",{className:"load-balancer-label"},e.label),Vt.createElement("h3",null,"(",e.sublabel,")"),Vt.createElement("div",null,e.description))))),Vt.createElement(Vt.Fragment,null,i.length>0&&i.map((e=>Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"})," ",e.reason))))),!!s&&Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),Vt.createElement(Ce,{message:s,style:{display:"inline-block",marginLeft:"2px"}}))),Vt.createElement("div",{className:"load-balancer-description"}))),Vt.createElement(Ha.Footer,null,Vt.createElement(Wa,{onClick:this.choose},"Configure Load Balancer ",Vt.createElement("span",{className:"glyphicon glyphicon-chevron-right"}))))}};let Ii=Ti;Ii.defaultProps={closeModal:C,dismissModal:C};class Gi extends Vt.Component{constructor(e){super(e),this.editLoadBalancer=()=>{const{loadBalancer:e}=this.props,{application:t}=this.state;Ni.find((t=>t.type===e.loadBalancerType)).component.show({app:t,loadBalancer:e})},this.deleteLoadBalancer=()=>{const{app:e,loadBalancer:t,loadBalancerFromParams:a}=this.props;if(t.instances&&t.instances.length)return;const n={application:e,title:"Deleting "+a.name},r={cloudProvider:t.cloudProvider,loadBalancerName:t.name,loadBalancerType:t.loadBalancerType||"classic",regions:[t.region],credentials:t.account,vpcId:ia(t,"elb.vpcId",null)};S.confirm({header:`Really delete ${a.name} in ${a.region}: ${a.accountId}?`,buttonText:`Delete ${a.name}`,account:a.accountId,taskMonitorConfig:n,submitMethod:()=>Te.deleteLoadBalancer(r,e)})},this.entityTagUpdate=()=>{this.props.app.loadBalancers.refresh()};const{app:t,loadBalancer:a}=this.props;let n;const r=a.name.split("-")[0];r===t.name?n=t:k.getApplication(r).then((e=>{this.setState({application:e})})).catch((()=>{})),this.state={application:n}}render(){const{app:e,loadBalancer:t}=this.props,{application:r}=this.state,{loadBalancerType:i,instances:s,instanceCounts:l}=t,o=t.name.split("-")[0],c=!("classic"===i&&ma(l).filter((e=>e)).length)&&!s.length;return Vt.createElement("div",{style:{display:"inline-block"}},kn.adHocInfraWritesEnabled&&Vt.createElement(qa,{className:"dropdown",id:"load-balancer-actions-dropdown"},Vt.createElement(qa.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Vt.createElement("span",null,"Load Balancer Actions")),Vt.createElement(qa.Menu,{className:"dropdown-menu"},r&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.editLoadBalancer},"Edit Load Balancer"),!r&&Vt.createElement("li",{className:"disabled"},Vt.createElement("a",null,"Edit Load Balancer"," ",Vt.createElement(n,{content:`The application <b>${o}</b> must be configured before this load balancer can be edited.`}))),c&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.deleteLoadBalancer},"Delete Load Balancer"),!c&&Vt.createElement("li",{className:"disabled"},Vt.createElement("a",null,"Delete Load Balancer"," ",Vt.createElement(n,{content:"You must detach all instances before you can delete this load balancer."}))),a&&a.feature.entityTags&&Vt.createElement(N,{component:t,application:e,entityType:"loadBalancer",onUpdate:this.entityTagUpdate}))))}}const Ai="spinnaker.amazon.loadBalancer.details.loadBalancerActions.component";t(Ai,[]).component("loadBalancerActions",Ja(L(Gi,"loadBalancerActions"),["app","loadBalancer","loadBalancerFromParams"]));class xi{constructor(e,t,n,r,i,s,l){this.$scope=e,this.$state=t,this.$q=n,this.app=i,this.securityGroupReader=s,this.loadBalancerReader=l,this.state={loading:!0},this.firewallsLabel=U.get("Firewalls"),this.oidcConfigPath=a.oidcConfigPath,this.application=i,this.loadBalancerFromParams=r,this.app.ready().then((()=>this.extractLoadBalancer())).then((()=>{e.$$destroyed||i.getDataSource("loadBalancers").onRefresh(e,(()=>this.extractLoadBalancer()))}))}autoClose(){this.$scope.$$destroyed||(this.$state.params.allowModalToStayOpen=!0,this.$state.go("^",null,{location:"replace"}))}extractLoadBalancer(){const e=this.app.loadBalancers.data.find((e=>e.name===this.loadBalancerFromParams.name&&e.region===this.loadBalancerFromParams.region&&e.account===this.loadBalancerFromParams.accountId));if(e){return this.loadBalancerReader.getLoadBalancerDetails("aws",this.loadBalancerFromParams.accountId,this.loadBalancerFromParams.region,this.loadBalancerFromParams.name).then((t=>{this.loadBalancer=e,this.state.loading=!1;const a=[];if(t.length){this.loadBalancer.elb=t[0],this.loadBalancer.elb.vpcId=this.loadBalancer.elb.vpcId||this.loadBalancer.elb.vpcid,this.loadBalancer.account=this.loadBalancerFromParams.accountId;const e=t[0];if("application"===e.loadBalancerType||"network"===e.loadBalancerType){const e=t[0];e.listeners&&e.listeners.length&&(this.elbProtocol="http:",e.listeners.some((e=>"HTTPS"===e.protocol))&&(this.elbProtocol="https:"),this.listeners=[],e.listeners.forEach((e=>{e.defaultActions.sort(((e,t)=>e.order-t.order)),e.rules.forEach((e=>e.actions.sort(((e,t)=>e.order-t.order))))})),e.listeners.forEach((e=>{e.rules.map((t=>{let a=[e.protocol,(t.conditions.find((e=>"host-header"===e.field))||{values:[""]}).values[0],e.port].filter((e=>e)).join(":");const n=(t.conditions.find((e=>"path-pattern"===e.field))||{values:[]}).values[0];n&&(a=`${a}${n}`);const r=t.actions.map((e=>{const t={...e};return"forward"===t.type&&(t.targetGroup=this.loadBalancer.targetGroups.find((e=>e.name===t.targetGroupName))),t}));this.listeners.push({in:a,actions:r})}))}))),"dualstack"===e.ipAddressType&&(this.ipAddressTypeDescription="IPv4 and IPv6"),"ipv4"===e.ipAddressType&&(this.ipAddressTypeDescription="IPv4")}else{const e=t[0];e.listenerDescriptions&&(this.elbProtocol="http:",e.listenerDescriptions.some((e=>"HTTPS"===e.listener.protocol))&&(this.elbProtocol="https:"))}(this.loadBalancer.elb.securityGroups||[]).forEach((e=>{const t=this.securityGroupReader.getApplicationSecurityGroup(this.app,this.loadBalancerFromParams.accountId,this.loadBalancerFromParams.region,e);t&&a.push(t)})),this.securityGroups=Qt(a,"name"),this.loadBalancer.subnets&&(this.loadBalancer.subnetDetails=this.loadBalancer.subnets.reduce(((e,t)=>(g.getSubnetByIdAndProvider(t,this.loadBalancer.provider).then((t=>{e.push(t)})),e)),[]))}}),(()=>this.autoClose()))}return this.autoClose(),this.loadBalancer||this.autoClose(),this.$q.when(null)}getFirstSubnetPurpose(e=[]){return ga(e.map((e=>e.purpose)))||""}}xi.$inject=["$scope","$state","$q","loadBalancer","app","securityGroupReader","loadBalancerReader"];const Pi="spinnaker.amazon.loadBalancer.details.controller";t(Pi,[an,Ge,Ai,Ae,xe]).controller("awsLoadBalancerDetailsCtrl",xi);class Di{constructor(e,t,a,n,r){this.$scope=e,this.$q=t,this.$state=a,this.app=r,this.state={loading:!0},this.application=r,this.targetGroupFromParams=n,this.app.ready().then((()=>this.extractTargetGroup())).then((()=>{e.$$destroyed||r.getDataSource("loadBalancers").onRefresh(e,(()=>this.extractTargetGroup()))}))}autoClose(){this.$scope.$$destroyed||(this.$state.params.allowModalToStayOpen=!0,this.$state.go("^",null,{location:"replace"}))}extractTargetGroup(){const{loadBalancerName:e,region:t,accountId:a,name:n}=this.targetGroupFromParams,r=this.app.loadBalancers.data.find((n=>n.name===e&&n.region===t&&n.account===a));if(!r)return this.autoClose(),this.$q.when(null);const i=r.targetGroups.find((e=>e.name===n));return i?(this.targetGroup=i,this.loadBalancer=r,this.state.loading=!1,this.elbProtocol="http:",this.loadBalancer.listeners&&this.loadBalancer.listeners.some((e=>"HTTPS"===e.protocol))&&(this.elbProtocol="https:"),this.$q.when(null)):(this.autoClose(),this.$q.when(null))}}Di.$inject=["$scope","$q","$state","targetGroup","app"];const Bi="spinnaker.amazon.loadBalancer.details.targetGroupDetails.controller";t(Bi,[an,xe]).controller("awsTargetGroupDetailsCtrl",Di);const zi="spinnaker.amazon.loadBalancer.targetGroup.states";t(zi,[Pe]).config(["applicationStateProvider",e=>{const t={name:"targetGroupDetails",url:"/targetGroupDetails/:provider/:accountId/:region/:vpcId/:loadBalancerName/:name",params:{vpcId:{value:null,squash:!0}},views:{"detail@../insight":{component:Or,$type:"react"}},resolve:{accountId:["$stateParams",e=>e.accountId],targetGroup:["$stateParams",e=>({loadBalancerName:e.loadBalancerName,name:e.name,accountId:e.accountId,region:e.region,vpcId:e.vpcId})]},data:{pageTitleDetails:{title:"Target Group Details",nameParam:"name",accountParam:"accountId",regionParam:"region"}}};e.addInsightDetailState(t)}]);const Fi="spinnaker.amazon.loadBalancer";t(Fi,[Pi,Bi,Ai,zi]);const Mi="spinnaker.amazon.pipeline.stage.bake.executionDetails.controller";t(Mi,[an]).controller("awsBakeExecutionDetailsCtrl",["$scope","$stateParams","executionDetailsSectionService","$interpolate",function(e,t,n,r){e.configSections=["bakeConfig","taskStatus"];const i=()=>{e.detailsSection=t.details,e.provider=e.stage.context.cloudProviderType||"aws",e.roscoMode=a.feature.roscoMode||"function"==typeof a.feature.roscoSelector&&a.feature.roscoSelector(e.stage.context),e.bakeryDetailUrl=r(e.roscoMode&&a.roscoDetailUrl?a.roscoDetailUrl:a.bakeryDetailUrl),e.bakeFailedNoError="FAILURE"===ia(e.stage,"context.status.result")&&!e.stage.failureMessage},s=()=>n.synchronizeSection(e.configSections,i);s(),e.$on("$stateChangeSuccess",s)}]);const $i="spinnaker.amazon.pipeline.stage.bakeStage";t($i,[Mi]).config((function(){De.pipeline.registerStage({provides:"bake",cloudProvider:"aws",label:"Bake",description:"Bakes an image",templateUrl:"amazon/src/pipeline/stages/bake/bakeStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/bake/bakeExecutionDetails.html",executionLabelComponent:Be,extraLabelLines:e=>e.masterStage.context.allPreviouslyBaked||e.masterStage.context.somePreviouslyBaked?1:0,supportsCustomTimeout:!0,validators:[{type:"requiredField",fieldName:"package"},{type:"requiredField",fieldName:"regions"},{type:"upstreamVersionProvided",checkParentTriggers:!0,getMessage:e=>"Bake stages should always have a stage or trigger preceding them that provides version information: <ul>"+e.map((e=>`<li>${e}</li>`)).join("")+"</ul>Otherwise, Spinnaker will bake and deploy the most-recently built package."}],restartable:!0})})).controller("awsBakeStageCtrl",["$scope","$q","$uibModal",function(e,t,n){function r(){if(e.baseOsOptions.length&&e.baseOsOptions.every((({vmTypes:e})=>e))){const t=e.baseOsOptions.length&&new Set(e.baseOsOptions.reduce(((e,{vmTypes:t})=>e.concat(t)),[])),a=e.baseOsOptions.find((({id:t})=>t===e.stage.baseOs));e.viewState.showVmTypeSelector=t.size>1,e.vmTypes=a.vmTypes}else e.viewState.showVmTypeSelector=!0,e.vmTypes=["hvm","pv"]}e.stage.extendedAttributes=e.stage.extendedAttributes||{},e.stage.regions=e.stage.regions&&e.stage.regions.sort()||[],e.stage.user||(e.stage.user=ze.getAuthenticatedUser().name),e.viewState={loading:!0,roscoMode:a.feature.roscoMode||"function"==typeof a.feature.roscoSelector&&a.feature.roscoSelector(e.stage),minRootVolumeSize:kn.minRootVolumeSize,showVmTypeSelector:!0,bakeWarning:kn.bakeWarning,dockerBakeWarning:kn.dockerBakeWarning,showDockerPreview:kn.dockerBakeryDeprecated&&"docker"===e.stage.storeType,showMigrationFields:"Started"!==e.pipeline.migrationStatus,showStoreType:!kn.dockerBakeryDeprecated},this.addExtendedAttribute=function(){e.stage.extendedAttributes||(e.stage.extendedAttributes={}),n.open({templateUrl:Fe.addExtendedAttributes,controller:"bakeStageAddExtendedAttributeController",controllerAs:"addExtendedAttribute",resolve:{extendedAttribute:function(){return{key:"",value:""}}}}).result.then((function(t){e.stage.extendedAttributes[t.key]=t.value})).catch((()=>{}))},this.removeExtendedAttribute=function(t){delete e.stage.extendedAttributes[t]},this.showTemplateFileName=function(){return e.viewState.roscoMode||e.stage.templateFileName},this.showExtendedAttributes=function(){return e.viewState.roscoMode||e.stage.extendedAttributes&&Ht.size(e.stage.extendedAttributes)>0},this.showVarFileName=function(){return e.viewState.roscoMode||e.stage.varFileName},this.handleBaseOsChange=function(){r(),e.vmTypes&&e.vmTypes.length&&!e.vmTypes.includes(e.stage.vmType)&&(e.stage.vmType=e.vmTypes[0])},e.$watch("stage",(function(){Ht.forOwn(e.stage,(function(t,a){""===t&&delete e.stage[a]})),"ebs"===e.stage.storeType&&"aws"!==e.stage.cloudProviderType&&(e.stage.cloudProviderType="aws"),"function"==typeof a.feature.roscoSelector&&(e.viewState.roscoMode=a.feature.roscoSelector(e.stage))}),!0),t.all([Me.getRegions("aws"),Me.getBaseOsOptions("aws"),Me.getBaseLabelOptions(),["ebs","docker"]]).then((function([t,a,n,i]){e.regions=[...t].sort(),e.storeTypes=i,!e.stage.storeType&&e.storeTypes&&e.storeTypes.length&&(e.stage.storeType=e.storeTypes[0]),1===e.regions.length?e.stage.region=e.regions[0]:e.regions.includes(e.stage.region)||delete e.stage.region,!e.stage.regions.length&&e.application.defaultRegions.aws&&e.stage.regions.push(...Object.keys(e.application.defaultRegions.aws).sort()),e.baseOsOptions=a.baseImages,e.baseLabelOptions=n,!e.stage.baseOs&&e.baseOsOptions&&e.baseOsOptions.length?e.stage.baseOs=e.baseOsOptions[0].id:e.stage.baseOs&&!(e.baseOsOptions||[]).find((t=>t.id===e.stage.baseOs))&&e.baseOsOptions.push({id:e.stage.baseOs,detailedDescription:"Custom",vmTypes:["hvm","pv"]}),!e.stage.baseLabel&&e.baseLabelOptions&&e.baseLabelOptions.length&&(e.stage.baseLabel=e.baseLabelOptions[0]),r(),!e.stage.vmType&&e.vmTypes&&e.vmTypes.length&&(e.stage.vmType=e.vmTypes[0]),e.showAdvancedOptions=function(){const t=e.stage;return!!(t.templateFileName||t.extendedAttributes&&Ht.size(t.extendedAttributes)>0||t.varFileName||t.baseName||t.baseAmi||t.amiName||t.amiSuffix||t.rootVolumeSize)}(),e.viewState.loading=!1}))}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/bake/bakeStage.html",'<div ng-controller="awsBakeStageCtrl as bakeStageCtrl">\n <div ng-if="viewState.loading" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div ng-if="!viewState.loading && viewState.showDockerPreview">\n <div ng-if="viewState.dockerBakeWarning" class="alert alert-warning sp-margin-s-top horizontal middle">\n <i class="fa fa-exclamation-triangle"></i>\n <div class="sp-margin-s-left">\n <markdown message="viewState.dockerBakeWarning"></markdown>\n </div>\n </div>\n <div>\n <div class="alert alert-info horizontal middle">\n <i class="fa fa-info-circle"></i>\n <div class="sp-margin-s-left">\n <markdown\n message="\'To edit bake configuration or view advanced options, migrate to EBS store type.\'"\n ></markdown>\n </div>\n </div>\n <stage-config-field label="Store Type" ng-if="!viewState.roscoMode && viewState.showMigrationFields">\n <label class="radio-inline" ng-repeat="storeType in storeTypes">\n <input type="radio" ng-model="stage.storeType" ng-value="storeType" />\n {{storeType | uppercase}}\n </label>\n </stage-config-field>\n <stage-config-field label="Regions">\n <span class="sp-margin-xs-right" ng-repeat="region in stage.regions">{{region}}</span>\n </stage-config-field>\n <stage-config-field label="Skip Region Detection">{{!!stage.skipRegionDetection}}</stage-config-field>\n <stage-config-field label="Repo Path">{{stage.package}}</stage-config-field>\n <stage-config-field label="Base OS">{{stage.baseOs}}</stage-config-field>\n <stage-config-field label="VM Type">{{stage.vmType}}</stage-config-field>\n <stage-config-field label="Store Type">{{stage.storeType}}</stage-config-field>\n <stage-config-field label="Base Label">{{stage.baseLabel}}</stage-config-field>\n </div>\n </div>\n <div ng-if="!viewState.loading && !viewState.showDockerPreview">\n <div\n ng-if="pipeline.migrationStatus === \'Started\' && viewState.bakeWarning"\n class="alert alert-warning sp-margin-s-top horizontal middle"\n >\n <i class="fa fa-exclamation-triangle"></i>\n <div class="sp-margin-s-left">\n <markdown message="viewState.bakeWarning"></markdown>\n </div>\n </div>\n <stage-config-field label="Regions">\n <checklist items="regions" model="stage.regions" inline="true" include-select-all-button="true"></checklist>\n </stage-config-field>\n <stage-config-field label="Skip Region Detection" help-key="pipeline.config.bake.skipRegionDetection">\n <div class="checkbox" style="margin-bottom: 0">\n <label>\n <input type="checkbox" ng-model="stage.skipRegionDetection" />\n Only bake explicitly selected regions\n </label>\n </div>\n </stage-config-field>\n <stage-config-field\n label="{{stage.storeType === \'docker\' ? \'Repo Path\' : \'Package\'}}"\n help-key="pipeline.config.bake.package"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.package" />\n </stage-config-field>\n <stage-config-field label="Base OS">\n <bake-stage-choose-os\n model="stage.baseOs"\n base-os-options="baseOsOptions"\n on-change="bakeStageCtrl.handleBaseOsChange()"\n ></bake-stage-choose-os>\n </stage-config-field>\n <stage-config-field label="VM Type" ng-if="viewState.showVmTypeSelector && viewState.showMigrationFields">\n <label class="radio-inline" ng-repeat="vmType in vmTypes">\n <input type="radio" ng-model="stage.vmType" ng-value="vmType" />\n {{vmType | uppercase}}\n </label>\n </stage-config-field>\n <stage-config-field\n label="Store Type"\n ng-if="!viewState.roscoMode && viewState.showMigrationFields && viewState.showStoreType"\n >\n <label class="radio-inline" ng-repeat="storeType in storeTypes">\n <input type="radio" ng-model="stage.storeType" ng-value="storeType" />\n {{storeType | uppercase}}\n </label>\n </stage-config-field>\n <stage-config-field label="Base Label">\n <label class="radio-inline" ng-repeat="baseLabel in baseLabelOptions">\n <input type="radio" ng-model="stage.baseLabel" ng-value="baseLabel" />\n {{baseLabel}}\n </label>\n </stage-config-field>\n \x3c!-- Even if the roscoMode flag is false, we should show the control if rebake is set. --\x3e\n <stage-config-field label="Rebake" ng-if="viewState.roscoMode || stage.rebake">\n <div class="checkbox" style="margin-bottom: 0">\n <label>\n <input type="checkbox" ng-model="stage.rebake" />\n Rebake image without regard to the status of any existing bake\n </label>\n </div>\n </stage-config-field>\n <div class="form-group">\n <div class="col-md-9 col-md-offset-1">\n <div class="checkbox">\n <label>\n <input type="checkbox" ng-model="showAdvancedOptions" />\n <strong>Show Advanced Options</strong>\n </label>\n </div>\n </div>\n </div>\n <div ng-class="{collapse: showAdvancedOptions !== true, \'collapse.in\': !showAdvancedOptions === true}">\n <stage-config-field\n label="Template File Name"\n help-key="pipeline.config.bake.templateFileName"\n ng-if="bakeStageCtrl.showTemplateFileName() && viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.templateFileName" />\n </stage-config-field>\n <stage-config-field\n label="Extended Attributes"\n help-key="pipeline.config.bake.extendedAttributes"\n ng-if="bakeStageCtrl.showExtendedAttributes()"\n >\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 40%">Key</th>\n <th style="width: 60%">Value</th>\n <th class="text-right">Actions</th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="(key,value) in stage.extendedAttributes">\n <td>\n <strong class="small">{{key}}</strong>\n </td>\n <td>\n <input\n type="text"\n ng-model="stage.extendedAttributes[key]"\n value="{{value}}"\n class="form-control input-sm"\n />\n </td>\n <td class="text-right">\n <a class="small" href ng-click="bakeStageCtrl.removeExtendedAttribute(key)">Remove</a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="7">\n <button class="btn btn-block btn-sm add-new" ng-click="bakeStageCtrl.addExtendedAttribute()">\n <span class="glyphicon glyphicon-plus-sign"></span> Add Extended Attribute\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </stage-config-field>\n <stage-config-field\n label="Var File Name"\n help-key="pipeline.config.bake.varFileName"\n ng-if="bakeStageCtrl.showVarFileName() && viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.varFileName" />\n </stage-config-field>\n <stage-config-field label="Root Volume Size" ng-if="viewState.minRootVolumeSize && viewState.showMigrationFields">\n <input\n type="number"\n class="form-control input-sm"\n style="width: 80px; display: inline-block"\n ng-min="viewState.minRootVolumeSize"\n ng-model="stage.rootVolumeSize"\n />\n GB <span class="small">(minimum: {{viewState.minRootVolumeSize}})</span>\n </stage-config-field>\n <stage-config-field label="Base Name" ng-if="stage.storeType !== \'docker\' && viewState.showMigrationFields">\n <input type="text" class="form-control input-sm" ng-model="stage.baseName" />\n </stage-config-field>\n <stage-config-field\n label="Base AMI"\n help-key="pipeline.config.bake.baseAmi"\n ng-if="stage.storeType !== \'docker\' && viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.baseAmi" />\n </stage-config-field>\n <stage-config-field\n label="{{stage.storeType === \'docker\' ? \'Docker Image Name\' : \'AMI Name\'}}"\n help-key="pipeline.config.bake.amiName"\n ng-if="viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.amiName" />\n </stage-config-field>\n <stage-config-field\n label="{{stage.storeType === \'docker\' ? \'Docker Image Prefix\' : \'AMI Suffix\'}}"\n help-key="pipeline.config.bake.amiSuffix"\n ng-if="viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.amiSuffix" />\n </stage-config-field>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/bake/bakeExecutionDetails.html",'<div ng-controller="awsBakeExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'bakeConfig\'">\n <div class="row">\n <div class="col-md-6">\n <dl class="dl-narrow dl-horizontal">\n <dt if-multiple-providers>Provider</dt>\n <dd if-multiple-providers>Amazon</dd>\n <dt>Image</dt>\n <dd>{{stage.context.ami}}</dd>\n <dt>Region</dt>\n <dd>{{stage.context.region}}</dd>\n <dt>Package</dt>\n <dd>{{stage.context.package}}</dd>\n </dl>\n </div>\n <div class="col-md-6">\n <dl class="dl-narrow dl-horizontal">\n <dt>Base OS</dt>\n <dd>{{stage.context.baseOs}}</dd>\n <dt>VM Type</dt>\n <dd>{{stage.context.vmType | uppercase}}</dd>\n <dt ng-if="!roscoMode">Store Type</dt>\n <dd ng-if="!roscoMode">{{stage.context.storeType | uppercase}}</dd>\n <dt ng-if="!roscoMode">Label</dt>\n <dd ng-if="!roscoMode">{{stage.context.baseLabel}}</dd>\n <dt ng-if="roscoMode || execution.trigger.rebake || stage.context.rebake">Rebake</dt>\n <dd ng-if="roscoMode || execution.trigger.rebake || stage.context.rebake">\n {{execution.trigger.rebake || stage.context.rebake || false}}\n </dd>\n <dt ng-if="stage.context.templateFileName">Template</dt>\n <dd ng-if="stage.context.templateFileName">{{stage.context.templateFileName}}</dd>\n <dt ng-if="stage.context.varFileName">Var File</dt>\n <dd ng-if="stage.context.varFileName">{{stage.context.varFileName}}</dd>\n </dl>\n </div>\n </div>\n <stage-failure-message\n stage="stage"\n message="stage.failureMessage"\n ng-if="stage.failureMessage"\n ></stage-failure-message>\n\n <div class="row" ng-if="stage.context.region && stage.context.status.resourceId">\n <div class="col-md-12">\n <div class="alert alert-{{stage.isFailed ? \'danger\' : \'info\'}}">\n <div ng-if="stage.context.previouslyBaked">No changes detected; reused existing bake</div>\n <div ng-if="stage.context.imageName">\n <strong>Image:</strong>\n <div select-on-dbl-click>{{stage.context.imageName}}</div>\n <div>({{stage.context.ami}})</div>\n </div>\n <span ng-if="bakeFailedNoError">Bake failed. </span>\n <a target="_blank" href="{{ bakeryDetailUrl(stage) }}">View Bakery Details</a>\n <span ng-if="bakeFailedNoError"> for more info.</span>\n </div>\n </div>\n </div>\n </div>\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]);const Li="spinnaker.amazon.pipeline.stage.cloneServerGroupStage";t(Li,[]).config((function(){De.pipeline.registerStage({provides:"cloneServerGroup",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStepLabel.html",accountExtractor:e=>[e.context.credentials],validators:[{type:"requiredField",fieldName:"targetCluster",fieldLabel:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"region"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsCloneServerGroupStageCtrl",["$scope",function(e){const t=e.stage;e.viewState={accountsLoaded:!1},o.listAccounts("aws").then((t=>{e.accounts=t,e.viewState.accountsLoaded=!0})),this.cloneTargets=$e.TARGET_LIST,t.target=t.target||this.cloneTargets[0].val,t.application=e.application.name,t.cloudProvider="aws",t.cloudProviderType="aws",t.viewState={mode:"editPipeline"},t.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(t.interestingHealthProviderNames=["Amazon"]),!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),t.isNew&&(t.useAmiBlockDeviceMappings=Ht.get(e,"application.attributes.providerSettings.aws.useAmiBlockDeviceMappings",!1),t.copySourceCustomBlockDeviceMappings=!1),this.targetClusterUpdated=()=>{if(t.targetCluster){const a=Le.monikerClusterNameFilter(t.targetCluster),n=Ht.first(Le.getMonikers([e.application],a));if(n)t.stack=n.stack,t.freeFormDetails=n.detail;else{const e=re.parseClusterName(t.targetCluster);t.stack=e.stack,t.freeFormDetails=e.freeFormDetails}}else t.stack="",t.freeFormDetails=""},e.$watch("stage.targetCluster",this.targetClusterUpdated),this.removeCapacity=()=>{delete t.capacity},Ht.has(t,"useSourceCapacity")||(t.useSourceCapacity=!0),this.toggleSuspendedProcess=e=>{t.suspendedProcesses=t.suspendedProcesses||[];const a=t.suspendedProcesses.indexOf(e);-1===a?t.suspendedProcesses.push(e):t.suspendedProcesses.splice(a,1)},this.processIsSuspended=e=>t.suspendedProcesses&&t.suspendedProcesses.includes(e),this.getBlockDeviceMappingsSource=()=>t.copySourceCustomBlockDeviceMappings?"source":t.useAmiBlockDeviceMappings?"ami":"default",this.selectBlockDeviceMappingsSource=e=>{"source"===e?(t.copySourceCustomBlockDeviceMappings=!0,t.useAmiBlockDeviceMappings=!1):"ami"===e?(t.copySourceCustomBlockDeviceMappings=!1,t.useAmiBlockDeviceMappings=!0):(t.copySourceCustomBlockDeviceMappings=!1,t.useAmiBlockDeviceMappings=!1)},this.onRedBlackFieldChange=(e,a)=>{Ht.set(t,e,a)}}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStage.html",'<div ng-controller="awsCloneServerGroupStageCtrl as cloneServerGroupStageCtrl">\n <div ng-if="!pipeline.strategy">\n <div ng-if="viewState.loading" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div ng-if="!viewState.loading">\n <account-region-cluster-selector\n application="application"\n component="stage"\n accounts="accounts"\n single-region="true"\n cluster-field="targetCluster"\n >\n </account-region-cluster-selector>\n </div>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="cloneServerGroupStageCtrl.cloneTargets"></target-select>\n </stage-config-field>\n <div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Capacity</div>\n <div class="col-md-9 radio">\n <label>\n <input\n type="radio"\n ng-model="stage.useSourceCapacity"\n ng-value="true"\n ng-click="cloneServerGroupStageCtrl.removeCapacity()"\n id="useSourceCapacityTrue"\n />\n Copy the capacity from the current server group\n <help-field key="serverGroupCapacity.useSourceCapacityTrue"></help-field>\n </label>\n </div>\n <div class="col-md-9 col-md-offset-3 radio">\n <label>\n <input type="radio" ng-model="stage.useSourceCapacity" ng-value="false" id="useSourceCapacityFalse" />\n Let me specify the capacity\n <help-field key="serverGroupCapacity.useSourceCapacityFalse"></help-field>\n </label>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-2 col-md-offset-3">Min</div>\n <div class="col-md-2">Max</div>\n <div class="col-md-2">Desired</div>\n </div>\n <div class="form-group">\n <div class="col-md-2 col-md-offset-3">\n <input\n type="number"\n ng-disabled="stage.useSourceCapacity"\n class="form-control input-sm"\n ng-model="stage.capacity.min"\n min="0"\n max="{{stage.capacity.max}}"\n required\n />\n </div>\n <div class="col-md-2">\n <input\n type="number"\n ng-disabled="stage.useSourceCapacity"\n class="form-control input-sm"\n ng-model="stage.capacity.max"\n min="{{stage.capacity.min}}"\n required\n />\n </div>\n <div class="col-md-2">\n <input\n type="number"\n ng-disabled="stage.useSourceCapacity"\n class="form-control input-sm"\n ng-model="stage.capacity.desired"\n min="{{stage.capacity.min}}"\n max="{{stage.capacity.max}}"\n required\n />\n </div>\n </div>\n </div>\n <stage-config-field label="Traffic" help-key="aws.serverGroup.traffic">\n <div class="checkbox">\n <label>\n <input\n type="checkbox"\n ng-click="cloneServerGroupStageCtrl.toggleSuspendedProcess(\'AddToLoadBalancer\')"\n ng-checked="!cloneServerGroupStageCtrl.processIsSuspended(\'AddToLoadBalancer\')"\n />\n Send client requests to new instances\n </label>\n </div>\n </stage-config-field>\n <stage-config-field label="AMI Block Device Mappings">\n <div class="radio">\n <div>\n <label>\n <input\n type="radio"\n ng-click="cloneServerGroupStageCtrl.selectBlockDeviceMappingsSource(\'source\')"\n ng-checked="cloneServerGroupStageCtrl.getBlockDeviceMappingsSource() === \'source\'"\n name="blockDeviceMappingsSource"\n />\n Copy from current server group\n <help-field key="aws.blockDeviceMappings.useSource"></help-field>\n </label>\n </div>\n <div>\n <label>\n <input\n type="radio"\n ng-click="cloneServerGroupStageCtrl.selectBlockDeviceMappingsSource(\'ami\')"\n ng-checked="cloneServerGroupStageCtrl.getBlockDeviceMappingsSource() === \'ami\'"\n name="blockDeviceMappingsSource"\n />\n Prefer AMI block device mappings\n <help-field key="aws.blockDeviceMappings.useAMI"></help-field>\n </label>\n </div>\n <div>\n <label>\n <input\n type="radio"\n ng-click="cloneServerGroupStageCtrl.selectBlockDeviceMappingsSource(\'default\')"\n ng-checked="cloneServerGroupStageCtrl.getBlockDeviceMappingsSource() === \'default\'"\n name="blockDeviceMappingsSource"\n />\n Defaults for selected instance type\n <help-field key="aws.blockDeviceMappings.useDefaults"></help-field>\n </label>\n </div>\n </div>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n <deployment-strategy-selector\n field-columns="6"\n command="stage"\n on-field-change="cloneServerGroupStageCtrl.onRedBlackFieldChange"\n ></deployment-strategy-selector>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStepLabel.html",'<span class="task-label"> Clone Server Group: {{step.context.source.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const Ri=[{label:"Newest Function Version",value:"$LATEST",description:"Delete the most recently deployed function version when this stage starts."},{label:"Previous Function Version",value:"$PREVIOUS",description:"Delete the second-most recently deployed function version when this stage starts."},{label:"Older Than N",value:"$MOVING",description:"Delete all version but the N most recent versions."},{label:"Provide Version Number",value:"$PROVIDED",description:"Provide a specific version number to delete."},{label:"All Function Versions",value:"$ALL",description:"Delete all function versions and function infrastructure. This will completely delete the Lambda function."}];class Oi extends Vt.Component{constructor(e){super(e);const{value:t}=this.props,a=Ri.filter((e=>e.value===t))[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Vt.createElement("div",null,Vt.createElement("b",null," ",this.state.label," "),Vt.createElement("br",null),Vt.createElement("small",null," ",this.state.description," "))}}function Vi(e){const{values:t}=e.formik,{functions:a}=e.application,{result:r,status:i}=F((()=>o.listAccounts("aws")),[],[]),l=t.account&&t.region?a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).map((e=>e.functionName)):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement(s,{label:"Account",name:"account",onChange:(t,a)=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue(t,a)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Vt.createElement(s,{label:"Region",name:"region",onChange:(t,a)=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue(t,a)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===i,stringOptions:r.filter((e=>e.name===t.account)).flatMap((e=>e.regions)).map((e=>e.name))})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:l})}),Vt.createElement(s,{label:"Target Version",name:"version",input:t=>Vt.createElement(c,{...t,clearable:!1,options:Ri,optionRenderer:t=>Vt.createElement(Oi,{config:e,value:t.value,showingDetails:!0})})}),"$PROVIDED"===t.version?Vt.createElement(s,{label:"Version Number",name:"versionNumber",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).filter((e=>e.functionName===t.functionName)).flatMap((e=>Object.values(e.revisions).sort((function(e,t){return t-e})))).filter((e=>"$LATEST"!==e))})}):null,"$MOVING"===t.version?Vt.createElement(s,{name:"retentionNumber",help:Vt.createElement(n,{content:"The number of Lambda versions to retain"}),label:"Prior Versions to Retain",input:e=>Vt.createElement(p,{...e,min:1,max:100})}):null)}function Ui(e){const{stage:t,name:a,current:n}=e;return Vt.createElement(Re,{name:a,current:n},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," ",Vt.createElement("b",null," Status: ")," ","done"===t.outputs.deleteTask?"COMPLETE":t.outputs.deleteTask," "),Vt.createElement("p",null," ",Vt.createElement("b",null," Deleted Version: ")," ",t.outputs["deleteTask:deleteVersion"]?t.outputs["deleteTask:deleteVersion"]:"N/A"," ")))}function qi(e){const t=new i(e);return t.field("account","Account Name").required(),t.field("region","Region").required(),t.field("functionName","Lambda Function Name").required(),t.field("version","Lambda Function Version").required(),t.validateForm()}(Ui||(Ui={})).title="Delete Lambda Stage";const Hi={key:"Aws.LambdaDeleteStage",label:"AWS Lambda Delete",description:"Delete an AWS Lambda Function",component:function(e){return Vt.createElement("div",{className:"DeleteLambdaStageConfig"},Vt.createElement(Ue,{...e,validate:qi,onChange:e.updateStage,render:e=>Vt.createElement(Vi,{...e})}))},executionDetailsSections:[Ui,Ve],validateFn:qi},Wi="spinnaker.amazon.pipeline.stage.Aws.LambdaDeleteStage";t(Wi,[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Hi)}));const ji="spinnaker.amazon.cloudformation.changetset.info.component";t(ji,[]).component("cloudFormationChangeSetInfo",Ja(L((e=>{const{stage:t,stageconfig:a}=e,[n,r]=Ut(t.changeSetName?t.changeSetName:"ChangeSet-${execution['id']}"),[i,s]=Ut(t.executeChangeSet),[o,u]=Ut(t.actionOnReplacement);return Vt.createElement("div",null,Vt.createElement("hr",null),Vt.createElement("h4",null,"ChangeSet Configuration"),Vt.createElement(qe,{label:"ChangeSet Name"},Vt.createElement(l,{className:"form-control",type:"text",value:n,onChange:e=>{return t=e.target.value,r(t),void a.updateStageField({changeSetName:t});var t}})),Vt.createElement(qe,{label:"Execute ChangeSet"},Vt.createElement(d,{checked:i,onChange:e=>{return t=e.target.checked,s(t),void a.updateStageField({executeChangeSet:t});var t}})),i&&Vt.createElement(qe,{label:"If ChangeSet contains a replacement","help-key":"aws.cloudformation.changeSet.options"},Vt.createElement(c,{clearable:!1,value:o,options:[{value:"ask",label:"ask"},{value:"skip",label:"skip it"},{value:"execute",label:"execute it"},{value:"fail",label:"fail stage"}],onChange:e=>{return t=e.target.value,u(t),void a.updateStageField({actionOnReplacement:t});var t}})))}),"cloudFormationChangeSetInfo"),["stage","stageconfig"]));class Zi{constructor(e){this.$scope=e,this.$onInit=()=>{"string"==typeof this.command.templateBody?this.rawTemplateBody=this.command.templateBody:this.rawTemplateBody=He(this.command.templateBody)},this.handleChange=(e,t)=>{this.command.templateBody=t||e,this.templateBody=t||e,this.rawTemplateBody=e,this.$scope.$applyAsync()}}}Zi.$inject=["$scope"];const _i={bindings:{command:"<",templateBody:"<"},controller:Zi,controllerAs:"ctrl",template:'\n <yaml-editor\n value="ctrl.rawTemplateBody"\n on-change="ctrl.handleChange"\n ></yaml-editor>'},Ki="spinnaker.amazon.cloudformation.entry.component";t(Ki,[]).component("cloudFormationTemplateEntry",_i);class Yi extends Ot.Component{constructor(e){super(e)}render(){const{stage:e,current:t,name:a}=this.props;return Ot.createElement(Re,{name:a,current:t},Ot.createElement(We,{item:e}),Ot.createElement(Oe,{stage:e,message:e.failureMessage}))}}Yi.title="Task Status";class Xi{constructor(e){this.$scope=e,this.state={loaded:!1},this.textSource="text",this.artifactSource="artifact",this.sources=[this.textSource,this.artifactSource],this.showClusterSelect=!1,this.onStackArtifactEdited=e=>{this.$scope.$applyAsync((()=>{this.$scope.stage.stackArtifactId=null,this.$scope.stage.stackArtifact=e}))},this.onStackArtifactSelected=e=>{this.onChangeStackArtifactId(e.id)},this.onChangeStackArtifactId=e=>{this.$scope.$applyAsync((()=>{this.$scope.stage.stackArtifactId=e,this.$scope.stage.stackArtifact=null}))},this.onStackArtifactAccountSelected=e=>{this.$scope.$applyAsync((()=>{this.$scope.stage.stackArtifactAccount=e}))},this.updatePipeline=e=>{this.$scope.$applyAsync((()=>{ha(this.$scope.pipeline,e)}))};const t={accounts:o.getAllAccountDetailsForProvider("aws"),artifactAccounts:o.getArtifactAccounts()};Xa.all(t).then((e=>{const{accounts:t,artifactAccounts:a}=e;this.accounts=t,this.state.loaded=!0,this.cloudFormationStackArtifactDelegate.setAccounts(a),this.cloudFormationStackArtifactController.updateAccounts(this.cloudFormationStackArtifactDelegate.getSelectedExpectedArtifact())})),this.cloudFormationStackArtifactDelegate=new je(e,"stack"),this.cloudFormationStackArtifactController=new Ze(this.cloudFormationStackArtifactDelegate)}canShowAccountSelect(){return this.$scope.stage.source===this.artifactSource&&!this.$scope.showCreateArtifactForm&&this.cloudFormationStackArtifactController.accountsForArtifact.length>1}toggleChangeSet(){this.$scope.stage.isChangeSet=!this.$scope.stage.isChangeSet}}Xi.$inject=["$scope"];const Ji=e=>{const{execution:t,stage:a,application:n}=e,[r,i]=Ut(!1),[s,l]=Ut(""),[o,c]=Ut(!1),d=e=>{i(!0),l(e),c(!1),Xn.evaluateCloudFormationChangeSetExecutionService.evaluateExecution(n,t,a,e)},u=e=>a.judgmentStatus===e||r&&s===e;return Vt.createElement("div",null,Vt.createElement("div",null,Vt.createElement("p",null,"This ChangeSet contains a replacement, which means there will be ",Vt.createElement("b",null,"potential data loss")," when executed."),Vt.createElement("p",null,"How do you want to proceed?"),Vt.createElement("div",{className:"action-buttons"},Vt.createElement("button",{className:"btn btn-danger",onClick:()=>{d("execute")},disabled:r},u("Execute")&&Vt.createElement(ae,{mode:"circular"}),a.context.stopButtonLabel||"Execute"),Vt.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("skip")}},u("Skip")&&Vt.createElement(ae,{mode:"circular"}),a.context.skipButtonLabel||"Skip"),Vt.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("fail")}},u("Fail")&&Vt.createElement(ae,{mode:"circular"}),a.context.FailButtonLabel||"Fail"))),o&&Vt.createElement("div",{className:"error-message"},"There was an error recording your decision. Please try again."))};class Qi extends Ot.Component{constructor(e){super(e)}render(){const{application:e,execution:t,stage:a,current:n,name:r}=this.props,i=a.context.changeSetContainsReplacement,s=i&&a.isRunning&&"ask"===a.context.actionOnReplacement,l=a.context.isChangeSet;return Ot.createElement(Re,{name:r,current:n},s?Ot.createElement(Ji,{key:a.refId,application:e,execution:t,stage:a}):Ot.createElement("div",null,l?Ot.createElement("div",null,Ot.createElement("dl",{className:"no-margin"},Ot.createElement("dt",null,"ChangeSet Name"),Ot.createElement("dd",null,a.context.changeSetName),Ot.createElement("dt",null,"Replacement"),Ot.createElement("dd",null,String(i)),a.context.changeSetExecutionChoice&&Ot.createElement("div",null,Ot.createElement("dt",null,"Judgment"),Ot.createElement("dd",null,a.context.changeSetExecutionChoice),Ot.createElement("dt",null,"Judged By"),Ot.createElement("dd",null,a.context.lastModifiedBy)))):Ot.createElement("div",null,"No changeSets found")))}}Qi.title="Change Set Execution";class es extends Ot.Component{render(){if(!this.props.executionMarker)return Ot.createElement(_e,{...this.props});const{stage:e}=this.props;if(e.isRunning&&e.stages[0].context.changeSetContainsReplacement&&"ask"===e.stages[0].context.actionOnReplacement){const t=Ot.createElement("div",null,Ot.createElement("div",null,Ot.createElement("b",null,e.name)),Ot.createElement(Ji,{stage:e.masterStage,application:this.props.application,execution:this.props.execution}));return Ot.createElement(ne,{template:t},this.props.children)}const t=Ot.createElement(ja,{id:e.id},e.name);return Ot.createElement(Za,{placement:"top",overlay:t},Ot.createElement("span",null,this.props.children))}}class ts extends Ot.Component{constructor(e){super(e)}render(){return this.props.stage.isRunning&&this.props.stage.stages[0].context.changeSetContainsReplacement&&"ask"===this.props.stage.stages[0].context.actionOnReplacement?(this.props.stage.requiresAttention=!0,Ot.createElement("span",{className:"fa fa-child"})):null}}const as="spinnaker.amazon.pipeline.stages.deployCloudFormationStage";t(as,[]).config((()=>{De.pipeline.registerStage({label:"Deploy (CloudFormation Stack)",description:"Deploy a CloudFormation Stack",key:"deployCloudFormation",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/deployCloudFormation/deployCloudFormationStackConfig.html",controller:"DeployCloudFormationStackConfigController",controllerAs:"ctrl",useCustomTooltip:!0,executionDetailsSections:[Yi,Qi],executionLabelComponent:es,producesArtifacts:!0,supportsCustomTimeout:!0,validators:[],markerIcon:ts,accountExtractor:e=>e.account?[e.account]:[],configAccountExtractor:e=>e.account?[e.account]:[],artifactExtractor:Ke.accumulateArtifacts(["stackArtifactId","requiredArtifactIds"]),artifactRemover:Ye.removeArtifactFromFields(["stackArtifactId","requiredArtifactIds"])})})).controller("DeployCloudFormationStackConfigController",Xi),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/deployCloudFormation/deployCloudFormationStackConfig.html",'<div ng-if="ctrl.state.loaded" class="clearfix">\n <div class="container-fluid form-horizontal">\n <h4>Basic Settings</h4>\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector\n application="application"\n component="stage"\n accounts="ctrl.accounts"\n show-cluster-select="ctrl.showClusterSelect"\n >\n </account-region-cluster-selector>\n </div>\n <h4>Template Configuration</h4>\n <ng-form name="amazonCloudFormationTemplateSource">\n <stage-config-field label="Stack name">\n <label class="sm-label-right">\n <input type="text" class="form-control input-sm" required ng-model="stage.stackName" />\n </label>\n <br />\n <label>\n <input type="checkbox" ng-checked="stage.isChangeSet" ng-click="ctrl.toggleChangeSet()" />\n <strong>Create CloudFormation ChangeSet</strong>\n </label>\n </stage-config-field>\n\n <stage-config-field label="IAM role ARN">\n <label class="sm-label-right">\n <input type="text" class="form-control input-sm" ng-model="stage.roleARN" />\n </label>\n </stage-config-field>\n <stage-config-field label="Source" help-key="aws.cloudformation.source">\n <label class="sm-label-right">\n <input type="radio" ng-model="ctrl.$scope.stage.source" value="{{ctrl.textSource}}" />\n {{ ctrl.textSource | robotToHuman }}\n <span ng-if="stage.source === ctrl.textSource"> </span> </label\n ><br />\n <label class="sm-label-right">\n <input type="radio" ng-model="ctrl.$scope.stage.source" value="{{ctrl.artifactSource}}" />\n {{ ctrl.artifactSource | robotToHuman }}\n </label>\n </stage-config-field>\n </ng-form>\n <cloud-formation-template-entry\n ng-if="stage.source === ctrl.textSource"\n templateBody="stage.templateBody"\n command="stage"\n >\n </cloud-formation-template-entry>\n <stage-artifact-selector-delegate\n ng-if="ctrl.$scope.stage.source === ctrl.artifactSource"\n artifact="stage.stackArtifact"\n excluded-artifact-type-patterns="[]"\n expected-artifact-id="stage.stackArtifactId"\n field-columns="8"\n help-key="\'aws.cloudformation.expectedArtifact\'"\n label="\'Expected Artifact\'"\n on-artifact-edited="ctrl.onStackArtifactEdited"\n on-expected-artifact-selected="ctrl.onStackArtifactSelected"\n pipeline="pipeline"\n stage="stage"\n >\n </stage-artifact-selector-delegate>\n <div ng-if="stage.isChangeSet">\n <cloud-formation-change-set-info stage="stage" stageconfig="stageConfigCtrl"> </cloud-formation-change-set-info>\n </div>\n <hr />\n <stage-config-field label="Parameters" field-columns="6">\n <map-editor model="ctrl.$scope.stage.parameters" add-button-label="Add parameter"></map-editor>\n </stage-config-field>\n <hr />\n <stage-config-field label="Tags" field-columns="6">\n <map-editor model="ctrl.$scope.stage.tags" add-button-label="Add tag"></map-editor>\n </stage-config-field>\n <hr />\n <stage-config-field label="Capabilities" field-columns="6">\n <ui-select multiple ng-model="stage.capabilities" class="form-control input-sm">\n <ui-select-match>{{$item}}</ui-select-match>\n <ui-select-choices repeat="capability in [\'CAPABILITY_IAM\', \'CAPABILITY_NAMED_IAM\', \'CAPABILITY_AUTO_EXPAND\']">\n <span>{{ capability }}</span>\n </ui-select-choices>\n </ui-select>\n </stage-config-field>\n </div>\n</div>\n')}]);class ns{constructor(e){this.executionService=e}evaluateExecution(e,t,a,n){const r=e=>{const t=e.stages.find((e=>e.id===a.id));return t&&"RUNNING"!==t.status};return this.executionService.patchExecution(t.id,a.id,{changeSetExecutionChoice:n}).then((()=>this.executionService.waitUntilExecutionMatches(t.id,r))).then((t=>this.executionService.updateExecution(e,t)))}}ns.$inject=["executionService"];const rs="spinnaker.amazon.deployCloudFormation.service";function is(e,t){return Object.entries(t).forEach((([t,a])=>{var n;e[t]||fa(n=a)&&(Yt(n)||""===n)||(e[t]=a)})),e}function ss(e){const{values:t}=e.formik,a=()=>{const a=re.getClusterName(e.application.name,t.stackName,t.detailName),n=t.functionUid;e.formik.setFieldValue("functionName",`${a}-${n}`)},{result:r,status:i}=F((()=>o.listAccounts("aws")),[],[]);return Vt.createElement("div",null,Vt.createElement(s,{label:"Account",name:"account",input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("enableLambdaAtEdge",!1),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.filter((e=>e.name===t.account)).flatMap((e=>e.regions)).map((e=>e.name))})}),Vt.createElement(s,{name:"functionUid",label:"Function Name",onChange:t=>{e.formik.setFieldValue("functionUid",t),a()},help:Vt.createElement(n,{id:"aws.function.name"}),input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"stackName",label:"Stack",help:Vt.createElement(n,{content:Ln}),onChange:t=>{e.formik.setFieldValue("stackName",t),a()},input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"detailName",label:"Detail",help:Vt.createElement(n,{content:Rn}),onChange:t=>{e.formik.setFieldValue("detailName",t),a()},input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"aliasNames",label:"Alias Name",help:Vt.createElement(n,{content:"AWS Lambda aliases are like a pointer to a specific function version. Users can access the function version using the alias Amazon Resource Name (ARN). Input the alias name and select `Create option ALIAS-INPUT` to add the alias."}),input:a=>Vt.createElement(Je,{...a,multi:!0,clearable:!1,placeholder:"Input Alias Name...",onChange:t=>{var a,n;a=t,n="aliases",e.formik.setFieldValue(n,a.map((e=>e.value)))},value:t.aliases?t.aliases.map((e=>({value:e,label:e}))):[]})}),Vt.createElement(s,{name:"runtime",label:"Runtime",help:Vt.createElement(n,{id:"aws.function.runtime"}),input:e=>Vt.createElement(c,{...e,stringOptions:$n,clearable:!0})}),Vt.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Vt.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Vt.createElement(l,{...e,placeholder:"S3 bucket name"})}),Vt.createElement(s,{name:"s3key",label:"S3 Key",help:Vt.createElement(n,{id:"aws.function.s3key"}),input:e=>Vt.createElement(l,{...e,placeholder:"object.zip"})}),Vt.createElement(s,{name:"handler",label:"Handler",help:Vt.createElement(n,{id:"aws.function.handler"}),input:e=>Vt.createElement(l,{...e,placeholder:"filename.method"})}),Vt.createElement(s,{name:"publish",label:"Publish",help:Vt.createElement(n,{id:"aws.function.publish"}),input:e=>Vt.createElement(d,{...e})}))}t(rs,[Xe]).service("evaluateCloudFormationChangeSetExecutionService",ns);function ls(e){const{values:t}=e.formik,a=t=>{e.formik.setFieldValue("securityGroupIds",null),e.formik.setFieldValue("subnetIds",null),e.formik.setFieldValue("vpcId",t.target.value)},{result:n,status:r}=F((()=>m.listNetworksByProvider("aws")),[],[]),{result:i}=F((()=>g.listSubnetsByProvider("aws")),[],[]),{result:l}=F((()=>h.securityGroupReader.getAllSecurityGroups()),void 0,[]),o=t.account&&t.region&&"PENDING"!==r?n.filter((e=>!1===e.deprecated)).filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).map((e=>e.id)):[],d=Zt(i.filter((e=>e.vpcId===t.vpcId)),"id"),u=t.account&&t.region&&t.vpcId?l[t.account].aws[t.region].filter((e=>e.vpcId===t.vpcId)).map((e=>({value:e.id,label:e.name}))):[];return Vt.createElement("div",null,Vt.createElement(s,{name:"vpcId",label:"VPC Id",input:e=>Vt.createElement(c,{...e,onChange:a,isLoading:"PENDING"===r,stringOptions:o,clearable:!0})}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Subnets ")),0===d.length?Vt.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC "):Vt.createElement("div",{className:"col-md-6"},Vt.createElement(f,{multi:!0,options:d.map((e=>{return{value:(t=e).id,label:t.id};var t})),value:t.subnetIds,onChange:t=>{const a=t.map((e=>e.value));e.formik.setFieldValue("subnetIds",a)}}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Security Groups ")),0===u.length?Vt.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC "):Vt.createElement("div",{className:"col-md-6"},Vt.createElement(f,{multi:!0,options:u,value:t.securityGroupIds,onChange:t=>{const a=t.map((e=>e.value));e.formik.setFieldValue("securityGroupIds",a)}}))))}function os(){return Vt.createElement(s,{name:"role",label:"Role ARN",input:e=>Vt.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"})})}function cs(e){const{values:t}=e.formik;return Vt.createElement("div",null,Vt.createElement(s,{name:"triggerArns",label:"Event ARNs",help:Vt.createElement(n,{content:"The resource ARNs for Lambda event trigger sources. Triggers created here will only be applied to the higher level function, and will NOT be applied to function aliases. Input the entire ARN and select `Create option TRIGGER-ARN-INPUT` to add the ARN."}),input:a=>Vt.createElement(Je,{...a,multi:!0,placeholder:"Input ARN...",onChange:t=>{var a,n;a=t,n="triggerArns",e.formik.setFieldValue(n,a.map((e=>e.value)))},value:t.triggerArns?t.triggerArns.map((e=>({value:e,label:e}))):[]})}),Vt.createElement(s,{name:"batchsize",label:"Event Batch Size",input:e=>Vt.createElement(p,{...e,min:1,max:1e3})}))}const ds="Validate AWS Lambda function configuration against Lambda@Edge requirements. This will not enable Lambda@Edge on this function. ";function us(e){const{values:t}=e.formik;return"us-east-1"!==t.region?Vt.createElement("div",{className:"horizontal center"},"Lambda@Edge is only available in region us-east-1."):Vt.createElement("div",null,Vt.createElement(s,{name:"enableLambdaAtEdge",label:"Enable Lambda@Edge Validation",help:Vt.createElement(n,{content:ds}),input:e=>Vt.createElement(d,{...e})}))}function ps(e){const{values:t,errors:a}=e.formik,r=Na({well:!0,"alert-danger":!!a.functionName,"alert-info":!a.functionName});return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("div",{className:r},Vt.createElement("strong",null,"Your function will be named: "),Vt.createElement(n,{id:"aws.function.name"}),Vt.createElement("span",null,t.functionName?t.functionName:e.application.name),Vt.createElement(s,{name:"functionName",input:()=>null})),Vt.createElement("h4",null,"Basic Settings"),Vt.createElement(ss,{...e}),Vt.createElement("h4",null," Execution Role "),Vt.createElement(os,null),Vt.createElement("h4",null," Environment "),!0!==t.enableLambdaAtEdge?Vt.createElement(Vt.Fragment,null,Vt.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Vt.createElement(s,{name:"encryptionKMSKeyArn",label:"Key ARN",help:Vt.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Vt.createElement(l,{...e})})):Vt.createElement("div",{className:"horizontal center"},"Environment variables not available with Lambda@Edge functions."),Vt.createElement("h4",null," Tags "),Vt.createElement(s,{name:"tags",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}),Vt.createElement("h4",null," Settings "),Vt.createElement(s,{name:"description",label:"Description",input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"layers",label:"Layer ARNs",help:Vt.createElement(n,{content:"The resource ARNs for Lambda layer. Input the entire ARN and select `Create option TRIGGER-ARN-INPUT` to add the ARN."}),input:a=>Vt.createElement(Je,{...a,multi:!0,placeholder:"Layer ARN...",onChange:t=>{var a,n;a=t,n="layers",e.formik.setFieldValue(n,a.map((e=>e.value)))},value:t.layers?t.layers.map((e=>({value:e,label:e}))):[]})}),Vt.createElement(s,{name:"reservedConcurrentExecutions",label:"Reserved Concurrency",help:Vt.createElement(n,{content:"The total number of current executions of your Lambda function that can be instantiated at any time."}),input:e=>Vt.createElement(p,{...e,min:0,max:3e3})}),Vt.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Vt.createElement(p,{...e,min:128,max:!0===t.enableLambdaAtEdge?128:3008})}),Vt.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Vt.createElement(p,{...e,min:1,max:!0===t.enableLambdaAtEdge?5:900})}),Vt.createElement(us,{...e}),Vt.createElement("h4",null," Network "),!0!==t.enableLambdaAtEdge?Vt.createElement(ls,{...e}):Vt.createElement("div",{className:"horizontal center"},"VPC configuration not available with Lambda@Edge functions."),Vt.createElement("h4",null," Event Triggers "),Vt.createElement(cs,{...e}),Vt.createElement("h4",null," Debugging and Error Handling "),"Dead Letter Config",Vt.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Vt.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Vt.createElement(l,{...e})}),"X-Ray Tracing",Vt.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Vt.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Vt.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}function ms(e){const t=new i(e);return t.field("runtime","Runtime").required(),t.field("s3key","S3 Object Key").required(),t.field("handler","Handler").required(),t.field("functionUid","Function Name").required(),t.field("stackName","Stack Name").optional().withValidators(Fn),t.field("detailName","Detail Name").optional().withValidators(Fn),t.field("s3bucket","S3 Bucket Name").required().withValidators(Dn),t.field("role","Role ARN").required().withValidators(Pn),t.field("triggerArns","Trigger ARNs").optional().withValidators(((e,t)=>e.map((e=>Bn(e,e))).every((e=>void 0===e))?void 0:"Invalid ARN. Event ARN must match regular expression: /^arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./")),t.validateForm()}function gs(e){const{stage:t,current:a,name:n}=e;return Vt.createElement(Re,{name:n,current:a},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," ",Vt.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ",Vt.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}(gs||(gs={})).title="Lambda Deployment Stage";const hs={key:"Aws.LambdaDeploymentStage",label:"AWS Lambda Deployment",description:"Create a Single AWS Lambda Function",component:function(e){const t={role:"",runtime:"",s3key:"",s3bucket:"",handler:"",functionName:"",publish:!1,tags:{},memorySize:128,description:"",credentials:"",cloudProvider:"aws",region:"",envVariables:{},tracingConfig:{mode:"PassThrough"},kmskeyArn:"",vpcId:"",subnetIds:[],securityGroupIds:[],timeout:3,deadLetterConfig:{targetArn:""},operation:"",targetGroups:""};return Vt.createElement("div",{className:"LambdaDeploymentConfig"},Vt.createElement(Ue,{...e,stage:is(e.stage,t),validate:ms,onChange:e.updateStage,render:e=>Vt.createElement(ps,{...e})}))},executionDetailsSections:[gs,Ve],validateFn:ms},fs="spinnaker.amazon.pipeline.stage.Aws.LambdaDeploymentStage";t(fs,[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(hs)}));const vs="spinnaker.amazon.pipeline.stage.aws.destroyAsgStage";t(vs,[]).config((function(){De.pipeline.registerStage({provides:"destroyServerGroup",alias:"destroyAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/destroyAsg/destroyAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/destroyAsg/destroyAsgStepLabel.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"targetImpedance",message:"This pipeline will attempt to destroy a server group without deploying a new version into the same cluster."},{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsDestroyAsgStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),e.regions=["us-east-1","us-west-1","eu-west-1","us-west-2"],e.targets=$e.TARGET_LIST,t.regions=t.regions||[],t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),t.target||(t.target=e.targets[0].val)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/destroyAsg/destroyAsgStage.html",'<div ng-controller="awsDestroyAsgStageCtrl as destroyAsgStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/destroyAsg/destroyAsgStepLabel.html",'<span class="task-label"> Destroy Server Group: {{step.context.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const ys="spinnaker.amazon.pipeline.stage.disableAsgStage";t(ys,[]).config((function(){De.pipeline.registerStage({provides:"disableServerGroup",alias:"disableAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/disableAsg/disableAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/disableAsg/disableAsgStepLabel.html",validators:[{type:"targetImpedance",message:"This pipeline will attempt to disable a server group without deploying a new version into the same cluster."},{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsDisableAsgStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),e.targets=$e.TARGET_LIST,t.regions=t.regions||[],t.cloudProvider="aws",t.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(t.interestingHealthProviderNames=["Amazon"]),!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),t.target||(t.target=e.targets[0].val)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/disableAsg/disableAsgStage.html",'<div ng-controller="awsDisableAsgStageCtrl as disableAsgStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/disableAsg/disableAsgStepLabel.html",'<span class="task-label"> Disable Server Group: {{step.context.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const bs="spinnaker.amazon.pipeline.stage.disableClusterStage";t(bs,[]).config((function(){De.pipeline.registerStage({provides:"disableCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/disableCluster/disableClusterStage.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"remainingEnabledServerGroups",fieldLabel:"Keep [X] enabled Server Groups"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsDisableClusterStageCtrl",["$scope",function(e){const t=this,a=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),t.reset=()=>{t.accountUpdated(),t.resetSelectedCluster()},a.regions=a.regions||[],a.cloudProvider="aws",a.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(a.interestingHealthProviderNames=["Amazon"]),!a.credentials&&e.application.defaultCredentials.aws&&(a.credentials=e.application.defaultCredentials.aws),!a.regions.length&&e.application.defaultRegions.aws&&a.regions.push(e.application.defaultRegions.aws),void 0===a.remainingEnabledServerGroups&&(a.remainingEnabledServerGroups=1),t.pluralize=function(e,t){return 1===t?e:e+"s"},void 0===a.preferLargerOverNewer&&(a.preferLargerOverNewer="false"),a.preferLargerOverNewer=a.preferLargerOverNewer.toString()}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/disableCluster/disableClusterStage.html",'<div ng-controller="awsDisableClusterStageCtrl as disableClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Disable Options">\n <div class="form-inline">\n Keep the\n <input\n type="number"\n min="0"\n required\n ng-model="stage.remainingEnabledServerGroups"\n class="form-control input-sm"\n style="width: 50px"\n />\n <select class="form-control input-sm" ng-model="stage.preferLargerOverNewer" style="width: 100px">\n <option value="true">largest</option>\n <option value="false">newest</option>\n </select>\n {{disableClusterStageCtrl.pluralize(\'server group\', stage.remainingEnabledServerGroups)}} enabled.\n </div>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]);const Es="spinnaker.amazon.pipeline.stage.enableAsgStage";t(Es,[]).config((function(){De.pipeline.registerStage({provides:"enableServerGroup",alias:"enableAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/enableAsg/enableAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/enableAsg/enableAsgStepLabel.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsEnableAsgStageCtrl",["$scope",function(e){const t=this,a=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),t.reset=()=>{t.accountUpdated(),t.resetSelectedCluster()},e.targets=$e.TARGET_LIST,a.regions=a.regions||[],a.cloudProvider="aws",a.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(a.interestingHealthProviderNames=["Amazon"]),!a.credentials&&e.application.defaultCredentials.aws&&(a.credentials=e.application.defaultCredentials.aws),!a.regions.length&&e.application.defaultRegions.aws&&a.regions.push(e.application.defaultRegions.aws),a.target||(a.target=e.targets[0].val),e.$watch("stage.credentials",e.accountUpdated)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/enableAsg/enableAsgStage.html",'<div ng-controller="awsEnableAsgStageCtrl as enableAsgStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/enableAsg/enableAsgStepLabel.html",'<span class="task-label"> Enable Server Group: {{step.context.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const ws="spinnaker.amazon.pipeline.stage.findAmiStage";e.module(ws,[]).config((function(){De.pipeline.registerStage({provides:"findImage",alias:"findAmi",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/findAmi/findAmiStage.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"selectionStrategy",fieldLabel:"Server Group Selection"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials"}]})})).controller("awsFindAmiStageCtrl",["$scope",function(t){const a=t.stage;t.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(e){t.accounts=e,t.state.accounts=!0})),t.selectionStrategies=[{label:"Largest",val:"LARGEST",description:"When multiple server groups exist, prefer the server group with the most instances"},{label:"Newest",val:"NEWEST",description:"When multiple server groups exist, prefer the newest"},{label:"Oldest",val:"OLDEST",description:"When multiple server groups exist, prefer the oldest"},{label:"Fail",val:"FAIL",description:"When multiple server groups exist, fail"}],a.regions=a.regions||[],a.cloudProvider="aws",a.selectionStrategy=a.selectionStrategy||t.selectionStrategies[0].val,e.isUndefined(a.onlyEnabled)&&(a.onlyEnabled=!0),!a.credentials&&t.application.defaultCredentials.aws&&(a.credentials=t.application.defaultCredentials.aws),!a.regions.length&&t.application.defaultRegions.aws&&a.regions.push(t.application.defaultRegions.aws),t.$watch("stage.credentials",t.accountUpdated)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/findAmi/findAmiStage.html",'<div ng-controller="awsFindAmiStageCtrl as findAmiCtrl" class="form-horizontal">\n <account-region-cluster-selector\n application="application"\n component="stage"\n accounts="accounts"\n show-all-regions="true"\n >\n </account-region-cluster-selector>\n <stage-config-field label="Server Group Selection">\n <ui-select ng-model="stage.selectionStrategy" class="form-control input-sm">\n <ui-select-match placeholder="None">{{$select.selected.label}}</ui-select-match>\n <ui-select-choices repeat="strategy.val as strategy in selectionStrategies | filter: $select.search">\n <strong ng-bind-html="strategy.label | highlight: $select.search"></strong>\n <div ng-bind-html="strategy.description"></div>\n </ui-select-choices>\n </ui-select>\n </stage-config-field>\n <stage-config-field label="Server Group Filters">\n <label class="checkbox-inline">\n <input type="checkbox" ng-model="stage.onlyEnabled" />\n Only consider enabled Server Groups\n </label>\n </stage-config-field>\n</div>\n')}]);const Cs="spinnaker.amazon.pipeline.stage.findImageFromTagsStage";function Ss(e){const{values:t}=e.formik,a=Qe(et.BITBUCKET_FILE,et.CUSTOM_OBJECT,et.EMBEDDED_BASE64,et.REMOTE_BASE64,et.GCS_OBJECT,et.GITHUB_FILE,et.GITLAB_FILE,et.S3_OBJECT,et.HTTP_FILE),n=(e,t)=>e[t]?e[t]:{account:"",id:""};return Vt.createElement("div",null,Vt.createElement(s,{name:"timeout",label:"Timeout",input:e=>Vt.createElement(p,{...e,min:0,max:900})}),Vt.createElement(s,{name:"executionCount",label:"Execution Count",input:e=>Vt.createElement(p,{...e,min:0,max:100})}),Vt.createElement(tt,{artifact:n(t,"payloadArtifact").artifact,excludedArtifactTypePatterns:a,expectedArtifactId:n(t,"payloadArtifact").id,label:"Payload Artifact",onArtifactEdited:t=>{((t,a)=>{e.formik.setFieldValue(`${a}.id`,null),e.formik.setFieldValue(`${a}.artifact`,t),e.formik.setFieldValue(`${a}.account`,t.artifactAccount)})(t,"payloadArtifact")},helpKey:"",onExpectedArtifactSelected:t=>{return a=t.id,n="payloadrtifact",e.formik.setFieldValue(`${n}.id`,a),void e.formik.setFieldValue(`${n}.artifact`,null);var a,n},pipeline:e.pipeline,stage:t}))}function ks(e){const{values:t}=e.formik,{functions:a}=e.application,{result:n,status:r}=F((()=>o.listAccounts("aws")),[],[]),i=t.account&&t.region?a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).map((e=>e.functionName)):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("h4",null," Basic Settings "),Vt.createElement(s,{label:"Account",name:"account",onChange:t=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("account",t)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===r,stringOptions:n.map((e=>e.name))})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===r,stringOptions:n.filter((e=>e.name===t.account)).flatMap((e=>e.regions)).map((e=>e.name))})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:i})}),Vt.createElement(s,{label:"Alias",name:"aliasName",input:e=>Vt.createElement(l,{...e})}),Vt.createElement("h4",null," Invoke Settings "),Vt.createElement(Ss,{...e}))}function Ns(e){const{stage:t}=e;return Vt.createElement(Re,{name:e.name,current:e.current},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," Function Name: ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ","Deployed Alias:"," ",t.outputs["deployment:aliasDeployed"]?t.outputs["deployment:aliasDeployed"]:"N/A"," "),Vt.createElement("p",null," ","Deployed Major Version:"," ",t.outputs["deployment:majorVersionDeployed"]?t.outputs["deployment:majorVersionDeployed"]:"N/A"," ")))}function Ts(e){const t=new i(e);return t.field("triggerArns","Trigger ARNs").optional().withValidators(((e,t)=>e.map((e=>Bn(e,e))).every((e=>void 0===e))?void 0:"Invalid ARN. Event ARN must match regular expression: /^arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./")),t.validateForm()}t(Cs,[]).config((function(){De.pipeline.registerStage({provides:"findImageFromTags",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsExecutionDetails.html",executionConfigSections:["findImageConfig","taskStatus"],validators:[{type:"requiredField",fieldName:"packageName"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"tags"}]})})).controller("awsFindImageFromTagsStageCtrl",["$scope",function(e){e.stage.tags=e.stage.tags||{},e.stage.regions=e.stage.regions||[],e.stage.cloudProvider=e.stage.cloudProvider||"aws",Me.getRegions("aws").then((function(t){e.regions=t}))}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsStage.html",'<div ng-controller="awsFindImageFromTagsStageCtrl as findImageFromTagsCtrl" class="form-horizontal">\n <stage-config-field label="Package">\n <input type="text" class="form-control input-sm" ng-model="stage.packageName" />\n </stage-config-field>\n <stage-config-field label="Regions">\n <checklist items="regions" model="stage.regions" inline="true" include-select-all-button="true"></checklist>\n </stage-config-field>\n <stage-config-field label="Tags">\n <map-editor model="stage.tags" allow-empty="true"></map-editor>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsExecutionDetails.html",'<div ng-controller="BaseExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'findImageConfig\'">\n <div class="row">\n <div class="col-md-12">\n <dl class="dl-narrow dl-horizontal">\n <dt if-multiple-providers>Provider</dt>\n <dd if-multiple-providers>Amazon</dd>\n <dt>Package</dt>\n <dd>{{stage.context.packageName}}</dd>\n <dt>Regions</dt>\n <dd>{{stage.context.regions.join(\', \')}}</dd>\n <dt>Tags</dt>\n <dd>\n <span ng-repeat="(key, val) in stage.context.tags"> {{key}}:{{val}}{{$last ? \'\' : \', \'}} </span>\n </dd>\n </dl>\n </div>\n </div>\n <stage-failure-message stage="stage" message="stage.failureMessage"></stage-failure-message>\n\n <div class="row" ng-if="stage.context.amiDetails">\n <div class="col-md-12">\n <div class="well alert alert-info">\n <h4>Results</h4>\n <dl ng-repeat="image in stage.context.amiDetails" class="dl-narrow dl-horizontal">\n <dt>Region</dt>\n <dd>{{image.region}}</dd>\n <dt>Image ID</dt>\n <dd>{{image.imageId}}</dd>\n <dt>Name</dt>\n <dd>{{image.imageName}}</dd>\n </dl>\n </div>\n </div>\n </div>\n </div>\n\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]),(Ns||(Ns={})).title="Invoke Lambda Stage";const Is={key:"Aws.LambdaInvokeStage",label:"AWS Lambda Invoke",description:"Invoke a Lambda function",component:function(e){return Vt.createElement("div",{className:"InvokeLambdaStageConfig"},Vt.createElement(Ue,{...e,validate:Ts,onChange:e.updateStage,render:e=>Vt.createElement(ks,{...e})}))},executionDetailsSections:[Ns,Ve],validateFn:Ts},Gs="spinnaker.amazon.pipeline.stage.Aws.LambdaInvokeStage";t(Gs,[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Is)}));const As="spinnaker.amazon.pipeline.stage.modifyScalingProcessStage";t(As,[]).config((function(){De.pipeline.registerStage({label:"Modify Scaling Process",description:"Suspend/Resume Scaling Processes",key:"modifyAwsScalingProcess",alias:"modifyScalingProcess",controller:"ModifyScalingProcessStageCtrl",templateUrl:"amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessExecutionDetails.html",executionConfigSections:["modifyScalingProcessesConfig","taskStatus"],validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"action"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"processes"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}],cloudProvider:"aws",strategy:!0})})).controller("ModifyScalingProcessStageCtrl",["$scope","stage",function(e,t){e.stage=t,e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),e.targets=$e.TARGET_LIST,e.actions=[{label:"Suspend",val:"suspend"},{label:"Resume",val:"resume"}],e.processes=["Launch","Terminate","AddToLoadBalancer","AlarmNotification","AZRebalance","HealthCheck","ReplaceUnhealthy","ScheduledActions"],t.processes=t.processes||[],t.regions=t.regions||[],t.action=t.action||e.actions[0].val,t.target=t.target||e.targets[0].val,t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),e.toggleProcess=function(e){t.processes||(t.processes=[]);const a=t.processes.indexOf(e);a>-1?t.processes.splice(a,1):t.processes.push(e)},e.$watch("stage.credentials",e.accountUpdated)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessStage.html",'<div class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n <stage-config-field label="Action">\n <select\n class="form-control input-sm"\n required\n ng-model="stage.action"\n ng-options="a.val as a.label for a in actions"\n >\n <option>Select an action...</option>\n </select>\n </stage-config-field>\n <stage-config-field label="Processes" field-columns="8">\n <div class="checkbox" style="padding-left: 0">\n <checklist model="stage.processes" items="processes"></checklist>\n </div>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessExecutionDetails.html",'<div ng-controller="BaseExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'modifyScalingProcessesConfig\'">\n <div class="row">\n <div class="col-md-9">\n <dl class="dl-narrow dl-horizontal">\n <dt>Account</dt>\n <dd><account-tag account="stage.context.credentials"></account-tag></dd>\n <dt>Region</dt>\n <dd>{{stage.context.region}}</dd>\n <dt>ASG Name</dt>\n <dd>{{stage.context.asgName}}</dd>\n <dt>Action</dt>\n <dd>{{stage.context.action}}</dd>\n <dt>Processes</dt>\n <dd>{{stage.context.processes.join(\', \')}}</dd>\n </dl>\n </div>\n </div>\n <stage-failure-message stage="stage" message="stage.failureMessage"></stage-failure-message>\n\n <div class="row" ng-if="stage.context.execution.logs">\n <div class="col-md-12">\n <div class="well alert alert-info">\n <a target="_blank" href="{{stage.context.execution.logs}}"> View Execution Logs </a>\n </div>\n </div>\n </div>\n </div>\n\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]);const xs="spinnaker.amazon.pipeline.stage.aws.resizeAsgStage";t(xs,[]).config((function(){De.pipeline.registerStage({provides:"resizeServerGroup",alias:"resizeAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/resizeAsg/resizeAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/resizeAsg/resizeAsgStepLabel.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"targetImpedance",message:"This pipeline will attempt to resize a server group without deploying a new version into the same cluster."},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"action"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsResizeAsgStageCtrl",["$scope",function(e){const t=e.stage;e.viewState={accountsLoaded:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.viewState.accountsLoaded=!0})),e.resizeTargets=$e.TARGET_LIST,e.scaleActions=[{label:"Scale Up",val:"scale_up"},{label:"Scale Down",val:"scale_down"},{label:"Scale to Cluster Size",val:"scale_to_cluster"},{label:"Scale to Exact Size",val:"scale_exact"}],e.resizeTypes=[{label:"Percentage",val:"pct"},{label:"Incremental",val:"incr"}],t.capacity=t.capacity||{},t.regions=t.regions||[],t.target=t.target||e.resizeTargets[0].val,t.action=t.action||e.scaleActions[0].val,t.resizeType=t.resizeType||e.resizeTypes[0].val,void 0===t.targetHealthyDeployPercentage&&(t.targetHealthyDeployPercentage=100),t.action||"exact"!==t.resizeType||(t.action="scale_exact"),t.cloudProvider="aws",t.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(t.interestingHealthProviderNames=["Amazon"]),!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),this.updateResizeType=function(){"scale_exact"===t.action?(t.resizeType="exact",delete t.scalePct,delete t.scaleNum):(t.capacity={},"pct"===t.resizeType?delete t.scaleNum:(t.resizeType="incr",delete t.scalePct,t.scaleNum=t.scaleNum||0))}}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/resizeAsg/resizeAsgStage.html",'<div ng-controller="awsResizeAsgStageCtrl as resizeAsgStageCtrl">\n <div ng-if="!pipeline.strategy">\n <div ng-if="!viewState.accountsLoaded" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div ng-if="viewState.accountsLoaded">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="resizeTargets"></target-select>\n </stage-config-field>\n <stage-config-field label="Action" help-key="pipeline.config.resizeAsg.action">\n <select\n class="form-control input-sm"\n required\n ng-model="stage.action"\n ng-change="resizeAsgStageCtrl.updateResizeType()"\n ng-options="a.val as a.label for a in scaleActions"\n >\n <option>Select an action...</option>\n </select>\n </stage-config-field>\n <div ng-if="stage.action !== \'scale_exact\'">\n <stage-config-field label="{{stage.action === \'scale_to_cluster\' ? \'Additional Capacity\' : \'Type\'}}">\n <select\n class="form-control input-sm"\n required\n ng-model="stage.resizeType"\n ng-change="resizeAsgStageCtrl.updateResizeType()"\n ng-options="t.val as t.label for t in resizeTypes"\n >\n <option>Select an action...</option>\n </select>\n </stage-config-field>\n <div ng-if="stage.resizeType === \'pct\'">\n <stage-config-field label="Resize Percentage">\n <input type="number" min="0" ng-model="stage.scalePct" class="form-control input-sm" style="width: 80px" />\n <div>\n <em class="subinput-note"\n >This is the percentage by which the target server group\'s capacity will be increased</em\n >\n </div>\n </stage-config-field>\n </div>\n <div ng-if="stage.resizeType === \'incr\'">\n <stage-config-field label="Resize-by Amount">\n <input type="number" min="0" ng-model="stage.scaleNum" class="form-control input-sm" style="width: 80px" />\n <div>\n <em class="subinput-note"\n >This is the exact amount by which the target server group\'s capacity will be increased</em\n >\n </div>\n </stage-config-field>\n </div>\n <div ng-if="stage.action === \'scale_up\' || stage.action === \'scale_to_cluster\'">\n <stage-config-field>\n <target-healthy-percentage-selector command="stage"></target-healthy-percentage-selector>\n </stage-config-field>\n </div>\n </div>\n <div ng-if="stage.action === \'scale_exact\'">\n <stage-config-field class="small">\n <div class="row">\n <div class="col-md-3">Min</div>\n <div class="col-md-3">Max</div>\n <div class="col-md-3">Desired</div>\n </div>\n </stage-config-field>\n <stage-config-field label="Match Capacity">\n <div class="row">\n <div class="col-md-3">\n <input type="number" ng-model="stage.capacity.min" class="form-control input-sm" />\n </div>\n <div class="col-md-3">\n <input type="number" ng-model="stage.capacity.max" class="form-control input-sm" />\n </div>\n <div class="col-md-3">\n <input type="number" ng-model="stage.capacity.desired" class="form-control input-sm" />\n </div>\n </div>\n </stage-config-field>\n <stage-config-field>\n <em class="subinput-note">This is the exact amount to which the target server group will be scaled</em>\n </stage-config-field>\n </div>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/resizeAsg/resizeAsgStepLabel.html",'<span class="task-label" ng-if="!step.context.useNameAsLabel">\n Resize Server Group: {{step.context.serverGroupName}} ({{step.context.region}})\n</span>\n<span class="task-label" ng-if="step.context.useNameAsLabel"> {{step.name}} </span>\n')}]);const Ps="spinnaker.amazon.pipeline.stage.rollbackClusterStage";function Ds(e){const{values:t}=e.formik;return Vt.createElement("div",null,Vt.createElement(s,{name:"triggerArns",label:"Event ARNs",help:Vt.createElement(n,{content:"The resource ARNs for Lambda event trigger sources. Input the entire ARN and select `Create option TRIGGER-ARN-INPUT` to add the ARN."}),input:a=>Vt.createElement(Je,{...a,multi:!0,placeholder:"Input ARN...",onChange:t=>{var a,n;a=t,n="triggerArns",e.formik.setFieldValue(n,a.map((e=>e.value)))},value:t.triggerArns?t.triggerArns.map((e=>({value:e,label:e}))):[]}),required:!1}),Vt.createElement(s,{name:"batchsize",label:"Event Batch Size",input:e=>Vt.createElement(p,{...e,min:1,max:10}),required:!1}))}function Bs(e){const{values:t}=e.formik,a=Qe(et.BITBUCKET_FILE,et.CUSTOM_OBJECT,et.EMBEDDED_BASE64,et.GCS_OBJECT,et.GITHUB_FILE,et.GITLAB_FILE,et.S3_OBJECT,et.HTTP_FILE),n=(t,a)=>{e.formik.setFieldValue(`${a}.id`,null),e.formik.setFieldValue(`${a}.artifact`,t),e.formik.setFieldValue(`${a}.account`,t.artifactAccount)},r=(t,a)=>{e.formik.setFieldValue(`${a}.id`,t),e.formik.setFieldValue(`${a}.artifact`,null)},i=(e,t)=>e[t]?e[t]:{account:"",id:""};return Vt.createElement("div",null,Vt.createElement(s,{name:"destroyOnFail",label:"On Fail",input:e=>Vt.createElement(d,{text:"Destroy latest lambda version on fail.",...e})}),Vt.createElement(s,{name:"timeout",label:"Timeout",input:e=>Vt.createElement(p,{...e,min:0,max:900})}),Vt.createElement(tt,{artifact:i(t,"payloadArtifact").artifact,excludedArtifactTypePatterns:a,expectedArtifactId:i(t,"payloadArtifact").id,label:"Payload Artifact",onArtifactEdited:e=>{n(e,"payloadArtifact")},helpKey:"",onExpectedArtifactSelected:e=>r(e.id,"payloadrtifact"),pipeline:e.pipeline,stage:t}),Vt.createElement(tt,{artifact:i(t,"outputArtifact").artifact,excludedArtifactTypePatterns:a,expectedArtifactId:i(t,"outputArtifact").id,label:"Output Artifact",onArtifactEdited:e=>{n(e,"outputArtifact")},helpKey:"",onExpectedArtifactSelected:e=>r(e.id,"outputArtifact"),pipeline:e.pipeline,stage:t}))}t(Ps,[]).config((function(){De.pipeline.registerStage({provides:"rollbackCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/rollbackCluster/rollbackClusterStage.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsRollbackClusterStageCtrl",["$scope",function(e){const t=this,n=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),t.reset=()=>{t.accountUpdated(),t.resetSelectedCluster()},n.regions=n.regions||[],n.cloudProvider="aws",n.targetHealthyRollbackPercentage=n.targetHealthyRollbackPercentage||100,n.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(n.interestingHealthProviderNames=["Amazon"]),!n.credentials&&e.application.defaultCredentials.aws&&(n.credentials=e.application.defaultCredentials.aws),!n.regions.length&&e.application.defaultRegions.aws&&n.regions.push(e.application.defaultRegions.aws),e.viewState.dynamicRollbackTimeout=a.feature.dynamicRollbackTimeout}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/rollbackCluster/rollbackClusterStage.html",'<div ng-controller="awsRollbackClusterStageCtrl as rollbackClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n\n <div class="row">\n <div class="col-sm-10 col-sm-offset-2" ng-if="stage.regions.length > 1">\n Wait\n <input\n type="number"\n min="0"\n ng-model="stage.waitTimeBetweenRegions"\n class="form-control input-sm inline-number"\n />\n seconds between regional rollbacks.\n </div>\n <div class="col-sm-10 col-sm-offset-2">\n Consider rollback successful when\n <input\n type="number"\n min="0"\n max="100"\n ng-model="stage.targetHealthyRollbackPercentage"\n class="form-control input-sm inline-number"\n />\n percent of instances are healthy.\n </div>\n <div class="col-sm-10 col-sm-offset-2" ng-if="viewState.dynamicRollbackTimeout">\n Rollback Timeout is\n <input\n type="number"\n min="0"\n max="100"\n ng-model="stage.rollbackTimeout"\n class="form-control input-sm inline-number"\n />\n minutes.\n </div>\n </div>\n</div>\n')}]);const zs=[{label:"Lambda Invocation",value:"$LAMBDA"}];function Fs(e){const{values:t}=e.formik;return Vt.createElement("div",null,Vt.createElement(s,{label:"Health Check Type",name:"healthCheckType",input:e=>Vt.createElement(c,{...e,clearable:!1,options:zs})}),t.healthCheckType?function(e,t){return"$LAMBDA"===e?Vt.createElement(Bs,{...t}):null}(t.healthCheckType,e):null)}const Ms=[{label:"Simple",value:"$SIMPLE",description:"Route 100% of traffic to specified version"},{label:"Weighted Deployment",value:"$WEIGHTED",description:"Split the traffic weight between two function versions."},{label:"Blue/Green",value:"$BLUEGREEN",description:"Disable all previous versions once the latest version passes health checks."}];class $s extends Vt.Component{constructor(e){super(e);const{value:t}=this.props,a=Ms.filter((e=>e.value===t))[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Vt.createElement("div",null,Vt.createElement("b",null," ",this.state.label," "),Vt.createElement("br",null),Vt.createElement("small",null," ",this.state.description," "))}}const Ls=[{label:"Newest Function Version",value:"$LATEST",description:"Selects the most recently deployed function when this stage starts."},{label:"Previous Function Version",value:"$PREVIOUS",description:"Selects the second-most recently deployed function when this stage starts."},{label:"Oldest Function Verion",value:"$OLDEST",description:"Selects the least recently deployed function when this stage starts."},{label:"Provide Version Number",value:"$PROVIDED",description:"Provide a specific version number to destroy."}];class Rs extends Vt.Component{constructor(e){super(e);const{value:t}=this.props,a=Ls.filter((e=>e.value===t))[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Vt.createElement("div",null,Vt.createElement("b",null," ",this.state.label," ")," ",Vt.createElement("br",null),Vt.createElement("small",null," ",this.state.description," "))}}function Os(e){const{values:t}=e.formik,{functions:a}=e.application;return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement(s,{label:"Target Version",name:"versionNameA",onChange:t=>{e.formik.setFieldValue("trafficPercentA",100),e.formik.setFieldValue("versionNameA",t)},input:e=>Vt.createElement(c,{...e,clearable:!1,options:Ls,optionRenderer:e=>Vt.createElement(Rs,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameA?Vt.createElement(s,{label:"Version Number",name:"versionNumberA",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).filter((e=>e.functionName===t.functionName)).flatMap((e=>Object.values(e.revisions).sort((function(e,t){return t-e})))).filter((e=>"$LATEST"!==e))})}):null,Vt.createElement(s,{name:"trafficPercentA",label:"Traffic %",input:e=>Vt.createElement(p,{...e,min:0,max:100,value:100,disabled:!0})}))}function Vs(e){const{values:t}=e.formik,{functions:a}=e.application;return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement(s,{label:"Target Version",name:"versionNameA",input:e=>Vt.createElement(c,{...e,clearable:!1,options:Ls,optionRenderer:e=>Vt.createElement(Rs,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameA?Vt.createElement(s,{label:"Version Number",name:"versionNumberA",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).filter((e=>e.functionName===t.functionName)).flatMap((e=>Object.values(e.revisions).sort((function(e,t){return t-e})))).filter((e=>"$LATEST"!==e))})}):null,Vt.createElement(s,{name:"trafficPercentA",label:"Traffic %",input:e=>Vt.createElement(p,{...e,min:0,max:100})}),Vt.createElement(s,{label:"Version Name",name:"versionNameB",input:e=>Vt.createElement(c,{...e,clearable:!1,options:Ls,optionRenderer:e=>Vt.createElement(Rs,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameB?Vt.createElement(s,{label:"Version Number",name:"versionNumberB",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).filter((e=>e.functionName===t.functionName)).flatMap((e=>Object.values(e.revisions).sort((function(e,t){return t-e})))).filter((e=>"$LATEST"!==e))})}):null,Vt.createElement(s,{name:"trafficPercentB",label:"Traffic %",input:e=>Vt.createElement(p,{...e,min:0,max:100,disabled:!0,value:t.trafficPercentA||0===t.trafficPercentA?100-t.trafficPercentA:null})}))}function Us(e){const{values:t}=e.formik;return Vt.createElement("div",{className:"form-horizontal"},t.deploymentStrategy?function(e,t){switch(e){case"$SIMPLE":return Vt.createElement(Os,{...t});case"$WEIGHTED":return Vt.createElement(Vs,{...t});case"$BLUEGREEN":return Vt.createElement(Fs,{...t});default:return null}}(t.deploymentStrategy,e):null)}function qs(e){const{values:t}=e.formik,{functions:a}=e.application,{result:r,status:i}=F((()=>o.listAccounts("aws")),[],[]),d=t.account&&t.region?a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).map((e=>e.functionName)):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("h4",null," Basic Settings "),Vt.createElement(s,{label:"Account",name:"account",onChange:t=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("account",t)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===i,stringOptions:r.filter((e=>e.name===t.account)).flatMap((e=>e.regions)).map((e=>e.name))})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:d})}),Vt.createElement(s,{label:"Alias",name:"aliasName",input:e=>Vt.createElement(l,{...e})}),Vt.createElement("h4",null," Alias Settings "),Vt.createElement(Ds,{...e}),Vt.createElement(s,{name:"provisionedConcurrentExecutions",label:"Provisioned Concurrency",help:Vt.createElement(n,{content:"To enable your function to scale without fluctuations in latency, use provisioned concurrency. Provisioned concurrency runs continually and has separate pricing for concurrency and execution duration. Concurrency cannot be provisioned with a weighted deployment strategy."}),input:e=>"$WEIGHTED"===t.deploymentStrategy?Vt.createElement(p,{...e,min:0,max:0}):Vt.createElement(p,{...e,min:0,max:3e3}),required:!1}),Vt.createElement("h4",null," Deployment Strategy "),Vt.createElement(s,{label:"Strategy",name:"deploymentStrategy",help:Vt.createElement(n,{content:""}),input:t=>Vt.createElement(c,{...t,clearable:!1,options:Ms,optionRenderer:t=>Vt.createElement($s,{config:e,value:t.value,showingDetails:!0})})}),t.deploymentStrategy?Vt.createElement(Us,{...e}):null)}function Hs(e){const{stage:t}=e;return Vt.createElement(Re,{name:e.name,current:e.current},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," Function Name: ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ","Deployed Alias:"," ",t.outputs["deployment:aliasDeployed"]?t.outputs["deployment:aliasDeployed"]:"N/A"," "),Vt.createElement("p",null," ","Deployed Major Version:"," ",t.outputs["deployment:majorVersionDeployed"]?t.outputs["deployment:majorVersionDeployed"]:"N/A"," ")))}function Ws(e){const t=new i(e);return t.field("triggerArns","Trigger ARNs").optional().withValidators(((e,t)=>e.map((e=>Bn(e,e))).every((e=>void 0===e))?void 0:"Invalid ARN. Event ARN must match regular expression: /^arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./")),t.validateForm()}(Hs||(Hs={})).title="Route Lambda Traffic Stage";const js={key:"Aws.LambdaTrafficRoutingStage",label:"AWS Lambda Route",description:"Route traffic across various versions of your Lambda function",component:function(e){return Vt.createElement("div",{className:"RouteLambdaStageConfig"},Vt.createElement(Ue,{...e,validate:Ws,onChange:e.updateStage,render:e=>Vt.createElement(qs,{...e})}))},executionDetailsSections:[Hs,Ve],validateFn:Ws},Zs="spinnaker.amazon.pipeline.stage.Aws.LambdaTrafficRoutingStage";t(Zs,[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(js)}));const _s="spinnaker.amazon.pipeline.stage.scaleDownClusterStage";t(_s,[]).config((function(){De.pipeline.registerStage({provides:"scaleDownCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/scaleDownCluster/scaleDownClusterStage.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"remainingFullSizeServerGroups",fieldLabel:"Keep [X] full size Server Groups"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}],strategy:!0})})).controller("awsScaleDownClusterStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),t.regions=t.regions||[],t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),void 0===t.remainingFullSizeServerGroups&&(t.remainingFullSizeServerGroups=1),void 0===t.allowScaleDownActive&&(t.allowScaleDownActive=!1),this.pluralize=function(e,t){return 1===t?e:e+"s"},void 0===t.preferLargerOverNewer&&(t.preferLargerOverNewer="false"),t.preferLargerOverNewer=t.preferLargerOverNewer.toString()}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/scaleDownCluster/scaleDownClusterStage.html",'<div ng-controller="awsScaleDownClusterStageCtrl as scaleDownClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Scale Down Options">\n <div class="form-inline">\n <p>\n Keep the\n <input\n type="number"\n min="0"\n required\n ng-model="stage.remainingFullSizeServerGroups"\n class="form-control input-sm"\n style="width: 50px"\n />\n <select class="form-control input-sm" ng-model="stage.preferLargerOverNewer" style="width: 100px">\n <option value="true">largest</option>\n <option value="false">newest</option>\n </select>\n {{scaleDownClusterStageCtrl.pluralize(\'server group\', stage.remainingFullSizeServerGroups)}} at current size.\n </p>\n <p>The remaining server groups will be scaled down to zero instances.</p>\n </div>\n </stage-config-field>\n <div class="form-group">\n <div class="col-md-offset-3 col-md-6 checkbox">\n <label>\n <input type="checkbox" ng-model="stage.allowScaleDownActive" />\n Allow scale down of active server groups\n </label>\n </div>\n </div>\n</div>\n')}]);const Ks="spinnaker.amazon.pipeline.stage.aws.shrinkClusterStage";t(Ks,[]).config((function(){De.pipeline.registerStage({provides:"shrinkCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/shrinkCluster/shrinkClusterStage.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"shrinkToSize",fieldLabel:"shrink to [X] Server Groups"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})})).controller("awsShrinkClusterStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then((function(t){e.accounts=t,e.state.accounts=!0})),t.regions=t.regions||[],t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),void 0===t.shrinkToSize&&(t.shrinkToSize=1),void 0===t.allowDeleteActive&&(t.allowDeleteActive=!1),this.pluralize=function(e,t){return 1===t?e:e+"s"},void 0===t.retainLargerOverNewer&&(t.retainLargerOverNewer="false"),t.retainLargerOverNewer=t.retainLargerOverNewer.toString()}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/shrinkCluster/shrinkClusterStage.html",'<div ng-controller="awsShrinkClusterStageCtrl as shrinkClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Shrink Options">\n <div class="form-inline">\n Shrink to\n <input\n type="number"\n min="0"\n required\n ng-model="stage.shrinkToSize"\n class="form-control input-sm"\n style="width: 50px"\n />\n {{shrinkClusterStageCtrl.pluralize(\'server group\', stage.shrinkToSize)}}, keeping the\n <select class="form-control input-sm" ng-model="stage.retainLargerOverNewer" style="width: 100px">\n <option value="true">largest</option>\n <option value="false">newest</option>\n </select>\n </div>\n </stage-config-field>\n <div class="form-group">\n <div class="col-md-offset-3 col-md-6 checkbox">\n <label>\n <input type="checkbox" ng-model="stage.allowDeleteActive" />\n Allow deletion of active server groups\n </label>\n </div>\n </div>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]);const Ys="spinnaker.amazon.pipeline.stage.tagImageStage";function Xs(e){const{values:t}=e.formik,{functions:a}=e.application,{result:r,status:i}=F((()=>o.listAccounts("aws")),[],[]),u=t.account&&t.region?a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).map((e=>e.functionName)):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("h4",null," Basic Settings "),Vt.createElement(s,{label:"Account",name:"account",onChange:t=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("account",t)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===i,stringOptions:r.filter((e=>e.name===t.account)).flatMap((e=>e.regions)).map((e=>e.name))})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:u})}),Vt.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Vt.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Vt.createElement(l,{...e,placeholder:"S3 bucket name"})}),Vt.createElement(s,{name:"s3key",label:"S3 Key",help:Vt.createElement(n,{id:"aws.function.s3key"}),input:e=>Vt.createElement(l,{...e,placeholder:"object.zip"})}),Vt.createElement(s,{name:"publish",label:"Publish",help:Vt.createElement(n,{id:"aws.function.publish"}),input:e=>Vt.createElement(d,{...e})}))}t(Ys,[]).config((function(){De.pipeline.registerStage({provides:"upsertImageTags",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/tagImage/tagImageStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/tagImage/tagImageExecutionDetails.html",executionConfigSections:["tagImageConfig","taskStatus"]})})).controller("awsTagImageStageCtrl",["$scope",e=>{e.stage.tags=e.stage.tags||{},e.stage.cloudProvider=e.stage.cloudProvider||"aws";e.$watch("stage.requisiteStageRefIds",(()=>{const t=at.getAllUpstreamDependencies(e.pipeline,e.stage).filter((e=>$e.IMAGE_PRODUCING_STAGES.includes(e.type)));e.consideredStages=new Map(t.map((e=>[e.refId,e.name])))}))}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/tagImage/tagImageStage.html",'<div ng-controller="awsTagImageStageCtrl as tagImageStageCtrl" class="form-horizontal">\n <stage-config-field label="Tags">\n <map-editor model="stage.tags" allow-empty="true"></map-editor>\n </stage-config-field>\n <stage-config-field label="Stages (optional)" help-key="aws.tagImage.consideredStages" help-key-expand="true">\n <div class="checkbox">\n <checklist model="stage.consideredStages" items="consideredStages"></checklist>\n </div>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/tagImage/tagImageExecutionDetails.html",'<div ng-controller="BaseExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'tagImageConfig\'">\n <div class="row" ng-if="stage.context.targets">\n <div class="col-md-12">\n <dl class="dl-narrow dl-horizontal">\n <dt if-multiple-providers>Provider</dt>\n <dd if-multiple-providers>Amazon</dd>\n <dt>Images</dt>\n <dd ng-repeat="target in stage.context.targets">\n {{target.imageName}}<br />\n <em>{{target.regions.join(\', \')}}</em>\n </dd>\n </dl>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <dl class="dl-narrow dl-horizontal">\n <dt>Tags</dt>\n <dd ng-repeat="(key, val) in stage.context.tags" ng-if="val !== null">{{key}} = {{val}}</dd>\n <dt ng-if="stage.context.consideredStages">Stages</dt>\n <dd ng-repeat="consideredStage in stage.context.consideredStages">\n <stage-name stages="execution.stages" ref-id="consideredStage"></stage-name>\n </dd>\n </dl>\n </div>\n </div>\n\n <stage-failure-message stage="stage" message="stage.failureMessage"></stage-failure-message>\n </div>\n\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]);function Js(e){const t=new i(e);return t.field("account","Account Name").required(),t.field("region","Region").required(),t.field("functionName","Lambda Function Name").required(),t.field("s3key","S3 Object Key").required(),t.field("s3bucket","S3 Bucket Name").required().withValidators(Dn),t.validateForm()}function Qs(e){const{stage:t,current:a,name:n}=e;return Vt.createElement(Re,{name:n,current:a},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," ",Vt.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ",Vt.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}xr(""),(Qs||(Qs={})).title="Lambda Update Code Stage";const el={key:"Aws.LambdaUpdateCodeStage",label:"AWS Lambda Update Code",description:"Update code for a single AWS Lambda Function",component:function(e){return Vt.createElement("div",{className:"LambdaUpdateCodeConfig"},Vt.createElement(Ue,{...e,validate:Js,onChange:e.updateStage,render:e=>Vt.createElement(Xs,{...e})}))},executionDetailsSections:[Qs,Ve],validateFn:Js},tl="spinnaker.amazon.pipeline.stage.Aws.LambdaUpdateCodeStage";t(tl,[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(el)}));const al="spinnaker.amazon.react";t(al,[]).run(["$injector",function(e){Xn.initialize(e)}]);const nl="spinnaker.amazon.search.searchResultFormatter";t(nl,[]).factory("awsSearchResultFormatter",(function(){return{securityGroups:function(e){return Wn.getVpcName(e.vpcId).then((function(t){const a=t?e.region+" - "+t.toLowerCase():e.region;return e.name+" ("+a+")"}))}}}));const rl="spinnaker.amazon.securityGroup.baseConfig.controller";t(rl,[an,Ge]).controller("awsConfigSecurityGroupMixin",["$scope","$state","$uibModalInstance","application","securityGroup","securityGroupReader","cacheInitializer",function(e,t,a,n,r,i,s){let l;const c=this;e.self=e,e.application=n,e.customComponentIsvalid=!0,e.state={submitting:!1,regionError:void 0,refreshingSecurityGroups:!1,removedRules:[],infiniteScroll:{numToAdd:20,currentItems:20}},e.allVpcs=[],e.wizard=nt,e.hideClassic=!1,c.addMoreItems=function(){e.state.infiniteScroll.currentItems+=e.state.infiniteScroll.numToAdd};const d=()=>e.securityGroup.accountName||e.securityGroup.credentials;function u(){if(e.$$destroyed)return;a.close();const n={name:e.securityGroup.name,accountId:d(),region:e.securityGroup.regions[0],vpcId:e.securityGroup.vpcId,provider:"aws"};t.includes("**.firewallDetails")?t.go("^.firewallDetails",n):t.go(".firewallDetails",n)}function p(){e.availableSecurityGroups=[],e.existingSecurityGroupNames=[]}function m(){e.state.refreshTime=Ne.get("securityGroups").getStats().ageMax}e.taskMonitor=new v({application:n,title:`Creating your ${U.get("firewall")}`,modalInstance:a,onTaskComplete:function(){n.securityGroups.refresh(),n.securityGroups.onNextRefresh(e,u)}}),e.securityGroup=r,c.initializeAccounts=()=>o.listAllAccounts("aws").then((function(t){e.accounts=t.filter((e=>!1!==e.authorized)),e.allAccounts=t,c.accountUpdated()})),c.upsert=function(){e.taskMonitor.submit((function(){return rt.upsertSecurityGroup(e.securityGroup,n,"Create")}))},c.accountUpdated=function(){const t=e.securityGroup;t.account=t.accountId=t.accountName=t.credentials,o.getRegionsForAccount(d()).then((t=>{e.regions=t.map((e=>e.name)),p(),c.regionUpdated(),e.state.isNew&&c.updateName()}))},c.regionUpdated=function(){const t=d(),a=e.securityGroup.regions||[];Wn.listVpcs().then((function(n){const r=Ht.groupBy(n.filter((e=>e.account===t)),"label");e.allVpcs=n;const i=[];Ht.forOwn(r,(function(e,n){a.every((a=>e.some((e=>e.region===a&&e.account===t))))&&i.push({ids:e.filter((e=>a.includes(e.region))).map((e=>e.id)),label:n,deprecated:e[0].deprecated})})),e.activeVpcs=i.filter((function(e){return!e.deprecated})),e.deprecatedVpcs=i.filter((function(e){return e.deprecated})),e.vpcs=i,e.state.regionError=e.state.isClone&&(e.securityGroup.regions||[]).includes(e.state.originRegion),c.updateVpcId(i)}))},this.updateVpcId=t=>{const a=kn.classicLaunchLockout;if(!r.id&&a){if(Number(Ht.get(n,"attributes.createTs",0))>=a&&(e.hideClassic=!0,!r.vpcId&&t.length)){let a;if(kn.defaults.vpc){const e=t.find((e=>e.label===kn.defaults.vpc));e&&(a=e.ids[0])}r.vpcId=a||(e.activeVpcs.length?e.activeVpcs[0].ids[0]:t[0].ids[0])}}const i=e.allVpcs.find((t=>t.id===e.securityGroup.vpcId)),s=(t||[]).find((e=>i&&i.label===e.label)),l=(t||[]).find((e=>kn.defaults.vpc===e.label))||(e.activeVpcs||[])[0];e.securityGroup.vpcId=s&&s.ids[0]||l&&l.ids[0],this.vpcUpdated()},this.vpcUpdated=function(){const t=d(),a=e.securityGroup.regions;t&&a.length?function(){const t=e.securityGroup.vpcId||null,a=d(),n=e.securityGroup.regions||[];let r=[],i=[];n.forEach((function(n){let s=null;if(t){const r=Ht.find(e.allVpcs,{id:t});s=Ht.find(e.allVpcs,{account:a,region:n,name:r.name}).id}const o=Ht.get(l,[a,"aws",n].join("."),[]).filter((e=>e.vpcId===s)).map((e=>e.name));r=Ht.uniq(r.concat(o)),i=i.length?Ht.intersection(i,o):r})),e.availableSecurityGroups=i,e.existingSecurityGroupNames=r,e.state.securityGroupsLoaded=!0,function(){const t=e.state.removedRules,a=e.securityGroup;e.securityGroup.securityGroupIngress=(a.securityGroupIngress||[]).filter((n=>!(!n.accountName||!n.vpcId||n.accountName===a.accountName&&n.vpcId===a.vpcId)||(!(n.name&&!e.availableSecurityGroups.includes(n.name)&&!t.includes(n.name))||(t.push(n.name),!1)))),t.length&&nt.markDirty("Ingress")}()}():p(),e.coordinatesChanged.next()},c.mixinUpsert=function(t){e.taskMonitor.submit((function(){return rt.upsertSecurityGroup(e.securityGroup,n,t)}))},c.refreshSecurityGroups=function(){return e.state.refreshingSecurityGroups=!0,s.refreshCache("securityGroups").then((function(){return c.initializeSecurityGroups().then((function(){c.vpcUpdated(),e.state.refreshingSecurityGroups=!1,m()}))}))},l={},e.allSecurityGroupsUpdated=new Ta,e.coordinatesChanged=new Ta,c.initializeSecurityGroups=function(){return i.getAllSecurityGroups().then((function(t){m(),l=t;const a=e.securityGroup.credentials||e.securityGroup.accountName,n=e.securityGroup.regions[0],r=e.securityGroup.vpcId||null;let i;i=a&&n?Ht.filter(t[a].aws[n],{vpcId:r}):t,e.availableSecurityGroups=Ht.map(i,"name");const s=kn.securityGroupExclusions;e.allSecurityGroups=s?it(t,(e=>!s.includes(e))):t,e.allSecurityGroupsUpdated.next(),e.state.regionError=e.state.isClone&&(e.securityGroup.regions||[]).includes(e.state.originRegion)}))},c.cancel=function(){a.dismiss()};const g=/^[\x20-\x7F]+$/,h=/^[a-zA-Z0-9\s._\-:/()#,@[\]+=&;{}!$*]+$/;c.getCurrentNamePattern=function(){return e.securityGroup.vpcId?h:g},c.updateName=function(){const{securityGroup:t}=e,a=n.isStandalone?n.name.split("-")[0]:n.name,r=re.getClusterName(a,t.stack,t.detail);t.name=r,e.namePreview=r},c.namePattern={test:function(e){return c.getCurrentNamePattern().test(e)}},c.addRule=function(e){e.push({type:"tcp",startPort:7001,endPort:7001})},c.removeRule=function(e,t){e.splice(t,1)},c.updateRuleType=function(e,t,a){const n=t[a];"icmp"!==e&&"icmpv6"!==e||(n.startPort=0,n.endPort=0)},c.dismissRemovedRules=function(){e.state.removedRules=[],nt.markClean("Ingress"),nt.markComplete("Ingress")}}]);const il="spinnaker.amazon.securityGroup.clone.controller";e.module(il,[rl]).controller("awsCloneSecurityGroupController",["$scope","$uibModalInstance","$controller","securityGroup","application",function(t,a,n,r,i){const s=this;s.firewallLabel=U.get("Firewall"),t.pages={location:"amazon/src/securityGroup/configure/createSecurityGroupProperties.html",ingress:"amazon/src/securityGroup/configure/createSecurityGroupIngress.html"},r.credentials=r.accountName,t.namePreview=r.name,e.extend(this,n("awsConfigSecurityGroupMixin",{$scope:t,$uibModalInstance:a,application:i,securityGroup:r})),t.state.isNew=!0,t.allowDuplicateNames=!0,t.state.isClone=!0,t.state.originRegion=r.regions&&r.regions[0],o.listAccounts("aws").then((function(e){t.accounts=e,s.accountUpdated()})),r.securityGroupIngress=Ht.chain(r.inboundRules).filter((function(e){return e.securityGroup})).map((function(e){return e.portRanges.map((function(t){return{name:e.securityGroup.name,type:e.protocol,startPort:t.startPort,endPort:t.endPort}}))})).flatten().value(),r.ipIngress=Ht.chain(r.inboundRules).filter((function(e){return e.range})).map((function(e){return e.portRanges.map((function(t){return{cidr:e.range.ip+e.range.cidr,type:e.protocol,startPort:t.startPort,endPort:t.endPort}}))})).flatten().value(),s.upsert=function(){const{credentials:e}=t.securityGroup;Object.assign(t.securityGroup,{account:e,accountName:e,accountId:e}),s.mixinUpsert("Clone")},s.initializeSecurityGroups().then(s.initializeAccounts)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupProperties.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="form-group">\n <div\n class="col-md-12 well"\n ng-class="{\'alert-danger\': form.securityGroupName.$error.validateUnique, \'alert-info\': !form.securityGroupName.$error.validateUnique}"\n >\n <strong>Your <firewall-label label="firewall"></firewall-label> will be named:</strong>\n <span ng-bind="namePreview"></span>\n <help-field key="aws.securityGroup.name"></help-field>\n <input\n type="hidden"\n class="form-control input-sm"\n ng-model="securityGroup.name"\n ng-model-options="{allowInvalid: true}"\n validate-unique="{{allowDuplicateNames ? \'\' : \'existingSecurityGroupNames\'}}"\n validate-ignore-case="true"\n name="securityGroupName"\n ng-pattern="ctrl.namePattern"\n trigger-validation="securityGroup.subnet"\n required\n />\n <validation-error\n ng-if="form.securityGroupName.$error.validateUnique && securityGroup.credentials"\n message="A {{ctrl.translate(\'firewall\')}} named \'{{namePreview}}\' already exists in one or more of the selected regions. Use a unique stack and detail to create a new {{ctrl.translate(\'firewall\')}}."\n ></validation-error>\n <validation-error\n ng-if="form.securityGroupName.$error.pattern"\n message="Name must match {{ctrl.getCurrentNamePattern().toString()}}"\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Account</div>\n <div class="col-md-8">\n <account-select-field\n component="securityGroup"\n field="credentials"\n accounts="accounts"\n provider="\'aws\'"\n on-change="ctrl.accountUpdated()"\n ></account-select-field>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Regions</div>\n <div class="col-md-8">\n <input type="hidden" ng-model="securityGroup.regions[0]" required />\n <checklist\n ng-if="securityGroup.credentials"\n items="regions"\n model="securityGroup.regions"\n inline="true"\n on-change="ctrl.regionUpdated()"\n ></checklist>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <validation-error\n ng-if="state.regionError"\n message="A security group cannot be cloned into a region it already exists in. Please deselect \'{{state.originRegion}}\' to clear this error."\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Stack</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.stack"\n ng-change="ctrl.updateName()"\n />\n </div>\n <div class="col-md-2 sm-label-right">Detail</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.detail"\n ng-change="ctrl.updateName()"\n />\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Description (required)</div>\n <div class="col-md-8">\n <textarea required cols="2" class="form-control input-sm no-spel" ng-model="securityGroup.description">\n </textarea>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">VPC <help-field key="aws.securityGroup.vpc"></help-field></div>\n <div class="col-md-8">\n <select\n class="form-control input-sm"\n ng-model="securityGroup.vpcId"\n ng-change="ctrl.vpcUpdated()"\n ng-if="securityGroup.regions.length"\n >\n <option value="" ng-if="!hideClassic">None (EC2 Classic)</option>\n <option\n ng-repeat="vpc in activeVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n <option ng-if="activeVpcs.length && deprecatedVpcs.length" disabled>---------------</option>\n <option\n ng-repeat="vpc in deprecatedVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n </select>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <p class="form-control-static" ng-if="securityGroup.credentials && !securityGroup.regions.length">\n (Select at least one region)\n </p>\n </div>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupIngress.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="row">\n <div class="col-md-12" ng-if="state.removedRules.length">\n <div class="alert alert-danger">\n <p>\n <i class="fa fa-exclamation-triangle"></i> The following\n <firewall-label label="firewalls"></firewall-label> could not be found in the selected account/region/VPC\n and were removed:\n </p>\n <ul>\n <li ng-repeat="securityGroup in state.removedRules">{{securityGroup}}</li>\n </ul>\n <p class="text-right">\n <a class="btn btn-sm btn-primary dirty-flag-dismiss" href ng-click="ctrl.dismissRemovedRules()">Okay</a>\n </p>\n </div>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <p class="info">\n <span class="glyphicon glyphicon-info-sign"></span> IP range rules can only be edited through the AWS Console.\n </p>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-12">\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 50%"><firewall-label label="Firewall"></firewall-label></th>\n <th style="width: 15%">Protocol</th>\n <th style="width: 15%">Start Port</th>\n <th style="width: 15%">End Port</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="rule in securityGroup.securityGroupIngress">\n <td>\n <ingress-rule-group-selector\n rule="rule"\n ng-if="state.securityGroupsLoaded"\n security-group="securityGroup"\n vpcs="allVpcs"\n accounts="allAccounts"\n all-security-groups="allSecurityGroups"\n coordinates-changed="coordinatesChanged"\n all-security-groups-updated="allSecurityGroupsUpdated"\n ></ingress-rule-group-selector>\n </td>\n <td>\n <select\n class="form-control input-sm"\n ng-model="rule.type"\n ng-options="protocol as protocol.toUpperCase() for protocol in [\'tcp\', \'udp\', \'icmp\', \'icmpv6\']"\n ng-change="ctrl.updateRuleType(rule.type, securityGroup.securityGroupIngress, $index)"\n required\n ></select>\n </td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.startPort" required /></td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.endPort" required /></td>\n <td>\n <a class="sm-label" ng-click="ctrl.removeRule(securityGroup.securityGroupIngress, $index)">\n <span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addRule(securityGroup.securityGroupIngress)">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new\n <firewall-label label="Firewall"></firewall-label> Rule\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n <div class="form-group small" style="margin-top: 20px">\n <div class="col-md-12">\n <p>\n <span ng-if="state.refreshingSecurityGroups"><span class="fa fa-sync-alt fa-spin"></span></span>\n <firewall-label label="Firewalls"></firewall-label>\n <span ng-if="!state.refreshingSecurityGroups">last refreshed {{ state.refreshTime | timestamp }}</span>\n <span ng-if="state.refreshingSecurityGroups"> refreshing...</span>\n </p>\n <p>\n If you\'re not finding a <firewall-label label="firewall"></firewall-label> that was recently added,\n <a href ng-click="ctrl.refreshSecurityGroups()">click here</a> to refresh the list.\n </p>\n </div>\n </div>\n <security-group-details-custom security-group-details="securityGroup" ctrl="ctrl" scope="self" />\n </div>\n</div>\n')}]);const sl="spinnaker.amazon.securityGroup.create.controller";e.module(sl,[an,st]).controller("awsCreateSecurityGroupCtrl",["$scope","$uibModalInstance","$state","$controller","cacheInitializer","application","securityGroup",function(t,a,n,r,i,s,l){t.pages={location:"amazon/src/securityGroup/configure/createSecurityGroupProperties.html",ingress:"amazon/src/securityGroup/configure/createSecurityGroupIngress.html"};const o=this;o.translate=e=>U.get(e),e.extend(this,r("awsConfigSecurityGroupMixin",{$scope:t,$uibModalInstance:a,application:s,securityGroup:l})),t.state.isNew=!0,o.upsert=()=>o.mixinUpsert("Create"),o.initializeSecurityGroups().then(o.initializeAccounts)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupProperties.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="form-group">\n <div\n class="col-md-12 well"\n ng-class="{\'alert-danger\': form.securityGroupName.$error.validateUnique, \'alert-info\': !form.securityGroupName.$error.validateUnique}"\n >\n <strong>Your <firewall-label label="firewall"></firewall-label> will be named:</strong>\n <span ng-bind="namePreview"></span>\n <help-field key="aws.securityGroup.name"></help-field>\n <input\n type="hidden"\n class="form-control input-sm"\n ng-model="securityGroup.name"\n ng-model-options="{allowInvalid: true}"\n validate-unique="{{allowDuplicateNames ? \'\' : \'existingSecurityGroupNames\'}}"\n validate-ignore-case="true"\n name="securityGroupName"\n ng-pattern="ctrl.namePattern"\n trigger-validation="securityGroup.subnet"\n required\n />\n <validation-error\n ng-if="form.securityGroupName.$error.validateUnique && securityGroup.credentials"\n message="A {{ctrl.translate(\'firewall\')}} named \'{{namePreview}}\' already exists in one or more of the selected regions. Use a unique stack and detail to create a new {{ctrl.translate(\'firewall\')}}."\n ></validation-error>\n <validation-error\n ng-if="form.securityGroupName.$error.pattern"\n message="Name must match {{ctrl.getCurrentNamePattern().toString()}}"\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Account</div>\n <div class="col-md-8">\n <account-select-field\n component="securityGroup"\n field="credentials"\n accounts="accounts"\n provider="\'aws\'"\n on-change="ctrl.accountUpdated()"\n ></account-select-field>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Regions</div>\n <div class="col-md-8">\n <input type="hidden" ng-model="securityGroup.regions[0]" required />\n <checklist\n ng-if="securityGroup.credentials"\n items="regions"\n model="securityGroup.regions"\n inline="true"\n on-change="ctrl.regionUpdated()"\n ></checklist>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <validation-error\n ng-if="state.regionError"\n message="A security group cannot be cloned into a region it already exists in. Please deselect \'{{state.originRegion}}\' to clear this error."\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Stack</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.stack"\n ng-change="ctrl.updateName()"\n />\n </div>\n <div class="col-md-2 sm-label-right">Detail</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.detail"\n ng-change="ctrl.updateName()"\n />\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Description (required)</div>\n <div class="col-md-8">\n <textarea required cols="2" class="form-control input-sm no-spel" ng-model="securityGroup.description">\n </textarea>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">VPC <help-field key="aws.securityGroup.vpc"></help-field></div>\n <div class="col-md-8">\n <select\n class="form-control input-sm"\n ng-model="securityGroup.vpcId"\n ng-change="ctrl.vpcUpdated()"\n ng-if="securityGroup.regions.length"\n >\n <option value="" ng-if="!hideClassic">None (EC2 Classic)</option>\n <option\n ng-repeat="vpc in activeVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n <option ng-if="activeVpcs.length && deprecatedVpcs.length" disabled>---------------</option>\n <option\n ng-repeat="vpc in deprecatedVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n </select>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <p class="form-control-static" ng-if="securityGroup.credentials && !securityGroup.regions.length">\n (Select at least one region)\n </p>\n </div>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupIngress.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="row">\n <div class="col-md-12" ng-if="state.removedRules.length">\n <div class="alert alert-danger">\n <p>\n <i class="fa fa-exclamation-triangle"></i> The following\n <firewall-label label="firewalls"></firewall-label> could not be found in the selected account/region/VPC\n and were removed:\n </p>\n <ul>\n <li ng-repeat="securityGroup in state.removedRules">{{securityGroup}}</li>\n </ul>\n <p class="text-right">\n <a class="btn btn-sm btn-primary dirty-flag-dismiss" href ng-click="ctrl.dismissRemovedRules()">Okay</a>\n </p>\n </div>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <p class="info">\n <span class="glyphicon glyphicon-info-sign"></span> IP range rules can only be edited through the AWS Console.\n </p>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-12">\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 50%"><firewall-label label="Firewall"></firewall-label></th>\n <th style="width: 15%">Protocol</th>\n <th style="width: 15%">Start Port</th>\n <th style="width: 15%">End Port</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="rule in securityGroup.securityGroupIngress">\n <td>\n <ingress-rule-group-selector\n rule="rule"\n ng-if="state.securityGroupsLoaded"\n security-group="securityGroup"\n vpcs="allVpcs"\n accounts="allAccounts"\n all-security-groups="allSecurityGroups"\n coordinates-changed="coordinatesChanged"\n all-security-groups-updated="allSecurityGroupsUpdated"\n ></ingress-rule-group-selector>\n </td>\n <td>\n <select\n class="form-control input-sm"\n ng-model="rule.type"\n ng-options="protocol as protocol.toUpperCase() for protocol in [\'tcp\', \'udp\', \'icmp\', \'icmpv6\']"\n ng-change="ctrl.updateRuleType(rule.type, securityGroup.securityGroupIngress, $index)"\n required\n ></select>\n </td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.startPort" required /></td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.endPort" required /></td>\n <td>\n <a class="sm-label" ng-click="ctrl.removeRule(securityGroup.securityGroupIngress, $index)">\n <span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addRule(securityGroup.securityGroupIngress)">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new\n <firewall-label label="Firewall"></firewall-label> Rule\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n <div class="form-group small" style="margin-top: 20px">\n <div class="col-md-12">\n <p>\n <span ng-if="state.refreshingSecurityGroups"><span class="fa fa-sync-alt fa-spin"></span></span>\n <firewall-label label="Firewalls"></firewall-label>\n <span ng-if="!state.refreshingSecurityGroups">last refreshed {{ state.refreshTime | timestamp }}</span>\n <span ng-if="state.refreshingSecurityGroups"> refreshing...</span>\n </p>\n <p>\n If you\'re not finding a <firewall-label label="firewall"></firewall-label> that was recently added,\n <a href ng-click="ctrl.refreshSecurityGroups()">click here</a> to refresh the list.\n </p>\n </div>\n </div>\n <security-group-details-custom security-group-details="securityGroup" ctrl="ctrl" scope="self" />\n </div>\n</div>\n')}]);const ll="spinnaker.amazon.securityGroup.edit.controller";e.module(ll,[an]).controller("awsEditSecurityGroupCtrl",["$scope","$uibModalInstance","$state","application","securityGroup","$controller",function(t,a,n,r,i,s){t.self=t,t.pages={ingress:"amazon/src/securityGroup/configure/createSecurityGroupIngress.html"},t.securityGroup=i,t.state={refreshingSecurityGroups:!1},t.securityGroup.regions=[t.securityGroup.region],t.securityGroup.credentials=t.securityGroup.accountName,e.extend(this,s("awsConfigSecurityGroupMixin",{$scope:t,$uibModalInstance:a,application:r,securityGroup:i})),t.state.isNew=!1,t.taskMonitor=new v({application:r,title:`Updating your ${U.get("firewall")}`,modalInstance:a,onTaskComplete:()=>r.securityGroups.refresh()}),i.securityGroupIngress=Ht.chain(i.inboundRules).filter((e=>e.securityGroup)).map((e=>e.portRanges.map((t=>{const a=e.securityGroup.vpcId===i.vpcId?null:e.securityGroup.vpcId;return{accountName:e.securityGroup.accountName||e.securityGroup.accountId,accountId:e.securityGroup.accountId,vpcId:a,id:e.securityGroup.id,name:e.securityGroup.inferredName?null:e.securityGroup.name,type:e.protocol,startPort:t.startPort,endPort:t.endPort,existing:!0}})))).flatten().value(),i.ipIngress=Ht.chain(i.inboundRules).filter((function(e){return e.range})).map((function(e){return e.portRanges.map((function(t){return{cidr:e.range.ip+e.range.cidr,type:e.protocol,startPort:t.startPort,endPort:t.endPort}}))})).flatten().value(),this.upsert=function(){const e=t.securityGroup,a={credentials:e.accountName,name:e.name,description:e.description,vpcId:e.vpcId,region:e.region,securityGroupIngress:e.securityGroupIngress,ipIngress:e.ipIngress};t.taskMonitor.submit((function(){return rt.upsertSecurityGroup(a,r,"Update")}))},this.cancel=function(){a.dismiss()},this.initializeSecurityGroups().then(this.initializeAccounts)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupIngress.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="row">\n <div class="col-md-12" ng-if="state.removedRules.length">\n <div class="alert alert-danger">\n <p>\n <i class="fa fa-exclamation-triangle"></i> The following\n <firewall-label label="firewalls"></firewall-label> could not be found in the selected account/region/VPC\n and were removed:\n </p>\n <ul>\n <li ng-repeat="securityGroup in state.removedRules">{{securityGroup}}</li>\n </ul>\n <p class="text-right">\n <a class="btn btn-sm btn-primary dirty-flag-dismiss" href ng-click="ctrl.dismissRemovedRules()">Okay</a>\n </p>\n </div>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <p class="info">\n <span class="glyphicon glyphicon-info-sign"></span> IP range rules can only be edited through the AWS Console.\n </p>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-12">\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 50%"><firewall-label label="Firewall"></firewall-label></th>\n <th style="width: 15%">Protocol</th>\n <th style="width: 15%">Start Port</th>\n <th style="width: 15%">End Port</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="rule in securityGroup.securityGroupIngress">\n <td>\n <ingress-rule-group-selector\n rule="rule"\n ng-if="state.securityGroupsLoaded"\n security-group="securityGroup"\n vpcs="allVpcs"\n accounts="allAccounts"\n all-security-groups="allSecurityGroups"\n coordinates-changed="coordinatesChanged"\n all-security-groups-updated="allSecurityGroupsUpdated"\n ></ingress-rule-group-selector>\n </td>\n <td>\n <select\n class="form-control input-sm"\n ng-model="rule.type"\n ng-options="protocol as protocol.toUpperCase() for protocol in [\'tcp\', \'udp\', \'icmp\', \'icmpv6\']"\n ng-change="ctrl.updateRuleType(rule.type, securityGroup.securityGroupIngress, $index)"\n required\n ></select>\n </td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.startPort" required /></td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.endPort" required /></td>\n <td>\n <a class="sm-label" ng-click="ctrl.removeRule(securityGroup.securityGroupIngress, $index)">\n <span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addRule(securityGroup.securityGroupIngress)">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new\n <firewall-label label="Firewall"></firewall-label> Rule\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n <div class="form-group small" style="margin-top: 20px">\n <div class="col-md-12">\n <p>\n <span ng-if="state.refreshingSecurityGroups"><span class="fa fa-sync-alt fa-spin"></span></span>\n <firewall-label label="Firewalls"></firewall-label>\n <span ng-if="!state.refreshingSecurityGroups">last refreshed {{ state.refreshTime | timestamp }}</span>\n <span ng-if="state.refreshingSecurityGroups"> refreshing...</span>\n </p>\n <p>\n If you\'re not finding a <firewall-label label="firewall"></firewall-label> that was recently added,\n <a href ng-click="ctrl.refreshSecurityGroups()">click here</a> to refresh the list.\n </p>\n </div>\n </div>\n <security-group-details-custom security-group-details="securityGroup" ctrl="ctrl" scope="self" />\n </div>\n</div>\n')}]);const ol={bindings:{rule:"=",securityGroup:"=",accounts:"=",vpcs:"=",allSecurityGroups:"=",coordinatesChanged:"=",allSecurityGroupsUpdated:"="},templateUrl:"amazon/src/securityGroup/configure/ingressRuleGroupSelector.component.html",controller:class{constructor(){this.infiniteScroll={currentItems:20}}addMoreItems(){this.infiniteScroll.currentItems+=20}resetCurrentItems(){this.infiniteScroll.currentItems=20}addRegionalVpc(e){const t=e.account;this.regionalVpcs[t]||(this.regionalVpcs[t]=[]),this.regionalVpcs[t].push({name:e.name,region:e.region,account:t,id:e.id,label:e.label,deprecated:e.deprecated,cloudProvider:e.cloudProvider})}enableCrossAccount(){var e;this.rule.crossAccountEnabled=!0,this.crossAccountAccounts=this.accounts;const t=null==(e=kn)?void 0:e.crossAccountIngressExclusions[this.securityGroup.credentials];t&&Array.isArray(t)&&(this.crossAccountAccounts=this.accounts.filter((e=>!t.includes(e.name)))),this.rule.accountName=this.securityGroup.credentials,this.rule.vpcId=this.securityGroup.vpcId}disableCrossAccount(){this.rule.crossAccountEnabled=!1,this.rule.accountName=void 0,this.rule.vpcId=void 0}$onInit(){this.setAvailableSecurityGroups(),this.coordinatesChangedListener=this.coordinatesChanged.subscribe((()=>this.setAvailableSecurityGroups())),this.securityGroupsUpdatedListener=this.allSecurityGroupsUpdated.subscribe((()=>this.setAvailableSecurityGroups()))}$onDestroy(){this.coordinatesChangedListener.unsubscribe(),this.securityGroupsUpdatedListener.unsubscribe()}setAvailableSecurityGroups(){const e=this.rule.accountName||this.securityGroup.credentials,t=this.securityGroup.regions,a=this.rule.vpcId||this.securityGroup.vpcId||null;let n=[],r=[];t.length>1&&this.disableCrossAccount(),t.forEach((t=>{var i,s,l,o;let c=null;if(a){const n=this.vpcs.find((e=>e.id===a)),r=this.vpcs.find((a=>a.account===e&&a.region===t&&a.name===n.name));c=r?r.id:void 0}const d=(null!=(o=null==(l=null==(s=null==(i=this.allSecurityGroups)?void 0:i[e])?void 0:s.aws)?void 0:l[t])?o:[]).filter((e=>e.vpcId===c)).map((e=>e.name));n=sa(n.concat(d)),r=r.length?va(r,d):n})),1===t.length&&this.configureAvailableVpcs(),this.availableSecurityGroups=r,r.includes(this.rule.name)||this.rule.existing||(this.rule.name=null)}configureAvailableVpcs(){const e=this.securityGroup.regions[0],t=this.vpcs.filter((t=>t.region===e));this.regionalVpcs={},t.forEach((e=>this.addRegionalVpc(e))),this.reconcileRuleVpc(t)}reconcileRuleVpc(e){if(this.rule.vpcId&&!this.rule.existing){if(!this.securityGroup.vpcId)return this.rule.vpcId=null,void(this.rule.name=null);const t=e.find((e=>e.id===this.rule.vpcId)),a=e.find((e=>e.account===this.rule.accountName&&e.name===t.name));a?this.rule.vpcId=a.id:(this.rule.vpcId=null,this.rule.name=null)}}}},cl="spinnaker.amazon.securityGroup.configure.ingressRuleGroupSelector";t(cl,[]).component("ingressRuleGroupSelector",ol),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/ingressRuleGroupSelector.component.html",'<span class="form-control-static" ng-if="$ctrl.rule.existing">\n <account-tag\n account="$ctrl.rule.accountName"\n ng-if="$ctrl.rule.accountName !== $ctrl.securityGroup.accountName"\n ></account-tag>\n {{ $ctrl.rule.name || $ctrl.rule.id }}\n</span>\n\n<div ng-if="$ctrl.rule.crossAccountEnabled && $ctrl.securityGroup.regions.length === 1" class="cross-account-select">\n <div class="row">\n <div class="col-md-3"><span class="small">Account</span></div>\n <div class="col-md-9">\n <account-select-field\n component="$ctrl.rule"\n field="accountName"\n accounts="$ctrl.crossAccountAccounts"\n provider="\'aws\'"\n on-change="$ctrl.setAvailableSecurityGroups()"\n ></account-select-field>\n </div>\n </div>\n <div class="row" ng-if="$ctrl.securityGroup.vpcId">\n <div class="col-md-3"><span class="small">VPC</span></div>\n <div class="col-md-9">\n <select class="form-control input-sm" ng-model="$ctrl.rule.vpcId" ng-change="$ctrl.setAvailableSecurityGroups()">\n <option\n ng-repeat="vpc in $ctrl.regionalVpcs[$ctrl.rule.accountName]"\n value="{{ vpc.id }}"\n ng-selected="$ctrl.rule.vpcId === vpc.id"\n >\n {{ vpc.label }}\n </option>\n </select>\n </div>\n </div>\n</div>\n\n<div class="row">\n <div class="col-md-3">\n <span class="small" ng-if="$ctrl.rule.crossAccountEnabled">Group</span>\n </div>\n <div class="col-md-{{ $ctrl.rule.crossAccountEnabled ? 9 : 12 }}">\n <ui-select\n ng-if="!$ctrl.rule.existing"\n ng-model="$ctrl.rule.name"\n uis-open-close="$ctrl.resetCurrentItems()"\n class="form-control input-sm"\n required\n style="width: 100%"\n >\n <ui-select-match>{{ $select.selected }}</ui-select-match>\n <ui-select-choices\n repeat="securityGroup as securityGroup in $ctrl.availableSecurityGroups | filter: $select.search | limitTo: $ctrl.infiniteScroll.currentItems"\n infinite-scroll="$ctrl.addMoreItems()"\n infinite-scroll-distance="4"\n >\n <span ng-bind-html="securityGroup | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n</div>\n\n<a\n href\n class="small"\n ng-if="!$ctrl.rule.existing && $ctrl.securityGroup.regions.length === 1 && !$ctrl.rule.crossAccountEnabled"\n ng-click="$ctrl.enableCrossAccount($index)"\n>\n Select from a different account <span ng-if="$ctrl.securityGroup.vpcId">or VPC</span>\n</a>\n\n<div ng-if="$ctrl.crossAccountAccounts && $ctrl.crossAccountAccounts.length !== $ctrl.accounts.length">\n <help-field key="aws.securityGroup.cross.account.ingress.help" expand="true"></help-field>\n</div>\n<span ng-if="$ctrl.securityGroup.regions.length > 1" class="small">\n Cross-account rules disabled when 2+ regions selected\n</span>\n')}]);var dl=Object.defineProperty,ul=Object.getOwnPropertyDescriptor;let pl=class extends Vt.Component{render(){return null}};pl=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?ul(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&dl(t,a,i),i})([ie("aws.securityGroup.details.custom")],pl);const ml="spinnaker.amazon.securityGroups.details.custom.component";t(ml,[]).component("securityGroupDetailsCustom",Ja(L(pl,"securityGroupDetailsCustom"),["securityGroupDetails","ctrl","scope"]));const gl="spinnaker.amazon.securityGroup.details.controller";e.module(gl,[an,Ge,il,xe]).controller("awsSecurityGroupDetailsCtrl",["$scope","$state","resolvedSecurityGroup","app","securityGroupReader","$uibModal",function(t,a,n,r,i,s){this.application=r;const l=r,o=n;function c(){return i.getSecurityGroupDetails(l,o.accountId,o.provider,o.region,o.vpcId,o.name).then((function(e){return Wn.getVpcName(e.vpcId).then((t=>(e.vpcName=t,e)))})).then((function(a){if(t.state.loading=!1,!a||Ht.isEmpty(a))u();else{const n=i.getApplicationSecurityGroup(l,o.accountId,o.region,o.name);e.extend(o,n,a),t.securityGroup=o,t.ipRules=function(e){const t=Ht.groupBy(e.ipRangeRules,(e=>e.range.ip+e.range.cidr));return Object.keys(t).map((e=>({address:e,rules:d(t,e)}))).filter((e=>e.rules.length))}(o),t.securityGroupRules=function(e){const t=Ht.groupBy(e.securityGroupRules,(e=>e.securityGroup.id));return Object.keys(t).map((e=>({securityGroup:t[e][0].securityGroup,rules:d(t,e)}))).filter((e=>e.rules.length))}(o)}}),u)}function d(e,t){const a=[];return e[t].forEach((e=>{(e.portRanges||[]).forEach((t=>{("-1"===e.protocol||void 0!==t.startPort&&void 0!==t.endPort)&&a.push({startPort:t.startPort,endPort:t.endPort,protocol:e.protocol,description:e.description})}))})),a}function u(){t.$$destroyed||(r.isStandalone?(t.group=o.name,t.state.notFound=!0,t.state.loading=!1,q.removeLastItem("securityGroups")):a.go("^",{allowModalToStayOpen:!0},{location:"replace"}))}this.firewallLabel=U.get("Firewall"),t.detailsTemplateUrl=V.getValue("aws","securityGroup.detailsTemplateUrl"),t.isDisabled=!kn.adHocInfraWritesEnabled,t.state={loading:!0,standalone:r.isStandalone},c().then((()=>{t.$$destroyed||r.isStandalone||r.securityGroups.onRefresh(t,c)})),this.editInboundRules=function(){lt(t.securityGroup,l).then((a=>new Promise((e=>setTimeout(e,500))).then((()=>{a&&s.open({templateUrl:"amazon/src/securityGroup/configure/editSecurityGroup.html",controller:"awsEditSecurityGroupCtrl as ctrl",size:"lg",resolve:{securityGroup:function(){return e.copy(t.securityGroup)},application:function(){return l}}})}))))},this.cloneSecurityGroup=function(){s.open({templateUrl:"amazon/src/securityGroup/clone/cloneSecurityGroup.html",controller:"awsCloneSecurityGroupController as ctrl",size:"lg",resolve:{securityGroup:function(){const a=e.copy(t.securityGroup);return a.region&&(a.regions=[a.region]),a},application:function(){return l}}})},this.deleteSecurityGroup=function(){let e=!1;const a={removeDependencies:!0},n={application:l,title:"Deleting "+o.name,onTaskRetry:()=>{e=!0}},r=()=>{const t={cloudProvider:o.provider,vpcId:o.vpcId};return e&&Object.assign(t,a),rt.deleteSecurityGroup(o,l,t)};lt(t.securityGroup,l).then((e=>{e&&S.confirm({header:"Really delete "+o.name+"?",buttonText:"Delete "+o.name,account:o.accountId,taskMonitorConfig:n,submitMethod:r,retryBody:`<div><p>Retry deleting the ${U.get("firewall")} and revoke any dependent ingress rules?</p><p>Any instance or load balancer associations will have to removed manually.</p></div>`})}))},r.isStandalone&&(r.securityGroups={refresh:c})}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/editSecurityGroup.html",'<ng-form role="form" name="form" novalidate>\n <v2-modal-wizard\n heading="Edit {{securityGroup.name}}: {{securityGroup.region}}: {{securityGroup.accountName}}"\n task-monitor="taskMonitor"\n dismiss="$dismiss()"\n >\n <v2-wizard-page key="Ingress" label="Ingress" done="true">\n <ng-include src="pages.ingress"></ng-include>\n </v2-wizard-page>\n </v2-modal-wizard>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <submit-button\n is-disabled="form.$invalid || !wizard.isComplete() || state.submitting || !customComponentIsvalid"\n submitting="state.submitting"\n on-click="ctrl.upsert()"\n is-new="state.isNew"\n ></submit-button>\n </div>\n</ng-form>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/clone/cloneSecurityGroup.html",'<ng-form role="form" name="form" novalidate>\n <v2-modal-wizard heading="Clone {{ctrl.firewallLabel}}" task-monitor="taskMonitor" dismiss="$dismiss()">\n <v2-wizard-page key="Location" label="Location">\n <ng-include src="pages.location"></ng-include>\n </v2-wizard-page>\n <v2-wizard-page key="Ingress" label="Ingress" done="true" mark-clean-on-view="false">\n <ng-include src="pages.ingress"></ng-include>\n </v2-wizard-page>\n </v2-modal-wizard>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <submit-button\n is-disabled="form.$invalid || !wizard.isComplete() || state.submitting || state.removedRules.length > 0 || !customComponentIsvalid || state.regionError"\n submitting="state.submitting"\n on-click="ctrl.upsert()"\n is-new="isNew"\n ></submit-button>\n </div>\n</ng-form>\n')}]);var hl=Object.defineProperty,fl=Object.getOwnPropertyDescriptor;let vl=class extends Vt.Component{render(){const e=this.props.ipRules||[],t=`IP Range Rules (${e.length})`;return Vt.createElement(x,{heading:t},e.map((e=>Vt.createElement(W,{className:"horizontal-when-filters-collapsed"},Vt.createElement(B,{label:"IP Range",value:e.address}),Vt.createElement(B,{label:"Port Ranges",value:e.rules.map((t=>"-1"===t.protocol?Vt.createElement("span",null,"All ports and protocols",e.rules.length>1?Vt.createElement("div",null,Vt.createElement("em",null,"Additional port ranges are specified, but redundant:")):null):Vt.createElement("div",null,Vt.createElement("span",null,t.protocol,":",t.startPort," → ",t.endPort))))})))))}};vl=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?fl(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&hl(t,a,i),i})([ie("aws.securityGroup.ip.rules")],vl);const yl="spinnaker.amazon.securityGroups.details.securityGroups.component";t(yl,[]).component("ipRangeRules",Ja(L(vl,"ipRangeRules"),["ipRules"]));class bl{resolveIndexedSecurityGroup(e,t,a){return bl.resolveIndexedSecurityGroup(e,t,a)}static resolveIndexedSecurityGroup(e,t,a){return e[t.account][t.region][a]}}const El="spinnaker.amazon.securityGroup.reader";t(El,[]).service("awsSecurityGroupReader",bl);const wl="spinnaker.amazon.securityGroup.transformer";t(wl,[]).factory("awsSecurityGroupTransformer",(function(){return{normalizeSecurityGroup:function(e){return Wn.listVpcs().then(function(e){return function(t){const a=t.filter((function(t){return t.id===e.vpcId}));e.vpcName=a.length?a[0].name:""}}(e))},compress:function(e){const t=ra(e,"vpcId");return Object.keys(t).forEach((e=>{t[e]=t[e].map((e=>[e.name,e.id]))})),t},decompress:function(e){const t=[];return Object.keys(e).forEach((a=>{e[a].forEach((e=>{t.push({name:e[0],id:e[1],vpcId:a})}))})),t},supportsCompression:!0}}));const Cl="spinnaker.amazon.securityGroup";t(Cl,[El,il,cl,rl,sl,ll,gl,wl,yl,ml]);class Sl extends Vt.Component{constructor(e){super(e),this.state={templateSelectionText:{copied:["account, region, subnet, cluster name (stack, details)","load balancers",U.get("firewalls"),"instance type","all fields on the Advanced Settings page"],notCopied:["the following suspended scaling processes: Launch, Terminate, AddToLoadBalancer"],additionalCopyText:"If a server group exists in this cluster at the time of deployment, its scaling policies will be copied over to the new server group."}},e.command.viewState.disableStrategySelection||this.state.templateSelectionText.notCopied.push("the deployment strategy (if any) used to deploy the most recent server group")}render(){const{app:e,command:t,onDismiss:a,onTemplateSelected:n}=this.props,{templateSelectionText:r}=this.state;return Vt.createElement(ot,{cloudProvider:"aws",application:e,command:t,onDismiss:a,onTemplateSelected:n,templateSelectionText:r})}}class kl extends Vt.Component{constructor(){super(...arguments),this.state={errorMessage:null,selectionMode:"packageImages",searchString:"",searchResults:null,isSearching:!1,packageImages:null,isLoadingPackageImages:!0},this.awsImageReader=new nr,this.props$=new Ta,this.searchInput$=new Ta,this.destroy$=new Ta,this.sortImagesBy$=new Aa("ts"),this.buildImageMenu=e=>{const{ImageMenuHeading:t,ImageLabel:a}=this,{options:n}=e;return Vt.createElement("div",{className:"Select-menu-outer"},Vt.createElement("div",{className:"Select-menu",role:"listbox"},n.length>0&&Vt.createElement(t,null),n.map((t=>Vt.createElement(a,{key:t.imageName,option:t,params:e})))))},this.ImageMenuHeading=()=>{const e=this.sortImagesBy$.value;return Vt.createElement("div",{className:"sp-padding-s-xaxis sp-padding-xs-yaxis small",style:{borderBottom:"1px solid var(--color-silver)",position:"sticky",top:0,backgroundColor:"var(--color-white)"}},Vt.createElement("b",null,"Sort by: "),Vt.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("ts")},"ts"===e?Vt.createElement("b",null,"timestamp (newest first)"):"timestamp (newest first)"),Vt.createElement("span",null," | "),Vt.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("name")},"name"===e?Vt.createElement("b",null,"name (A-Z)"):"name (A-Z)"))},this.ImageLabel=e=>{const{credentials:t,region:a}=this.props,{option:n,params:r}=e,i=n.amis[a]&&n.amis[a][0]?n.amis[a][0]:` - not found in ${t}/${a}`;return Vt.createElement("div",{key:n.imageName,onClick:()=>r.selectValue(n),onMouseOver:()=>r.focusOption(n),className:"Select-option "+(r.focusedOption&&r.focusedOption.imageName===n.imageName?"is-focused":""),role:"option"},Vt.createElement("div",null,n.imageName),Vt.createElement("div",{className:"small"},Vt.createElement("b",null,"Created: "),n.attributes.creationDate,Vt.createElement("b",{className:"sp-padding-s-left"},"AMI: "),i))}}static makeFakeImage(e,t,a){if(!e&&!t)return null;return{imageName:e,amis:{[a]:[t]},attributes:{virtualizationType:"*",architecture:"*",creationDate:(new Date).toISOString()}}}loadImagesFromApplicationName(e){const t=e.name.replace(/_/g,"[_\\-]")+"*";return this.awsImageReader.findImages({q:t})}buildQueryForSimilarImages(e){let t=!1,a=e.split("_")[0];const n=a.split("-");n.length>3&&(a=n.slice(0,-3).join("-"),t=!0);return!a||a.length<3?null:a+(t?"-*":"*")}loadImageById(e,t,a){return e?this.awsImageReader.getImage(e,t,a).catch((()=>null)):Xa.when(null)}searchForImages(e){return e&&e.length>=3?this.awsImageReader.findImages({q:e}):Xa.when([])}fetchPackageImages(e,t,a,n){const r=e&&e.amis&&e.amis[t]&&e.amis[t][0];return this.loadImageById(r,t,a).then((e=>e?this.searchForImages(this.buildQueryForSimilarImages(e.imageName)).then((t=>t.find((t=>t.imageName===e.imageName))?t:t.concat(e))):this.loadImagesFromApplicationName(n)))}selectImage(e){this.props.value!==e&&this.props.onChange(e)}findMatchingImage(e,t){return e.find((e=>t&&t.imageName===e.imageName))}componentDidMount(){const e=this.props$.pipe(Da((e=>e.region)),Ba()),{value:t,region:a,credentials:n,application:r}=this.props;this.setState({isLoadingPackageImages:!0});const i=this.fetchPackageImages(t,a,n,r),s=Ia(i).pipe(Oa((e=>(console.error(e),this.setState({errorMessage:"Unable to load package images"}),xa([])))),La((()=>this.setState({isLoadingPackageImages:!1})))),l=Ga([s,e,this.sortImagesBy$]).pipe(Da((([e,t,a])=>{const n=e.filter((e=>!!e.amis[t]));return this.sortImages(n,a)}))),o=this.searchInput$.pipe(La((e=>this.setState({searchString:e}))),Ba(),Va(250)).pipe(La((()=>this.setState({isSearching:!0}))),Fa((e=>this.searchForImages(e))),Oa((e=>(console.error(e),this.setState({errorMessage:"Unable to search for images"}),xa([])))),La((()=>this.setState({isSearching:!1}))));Ga([o,e,this.sortImagesBy$]).pipe(Da((([e,t,a])=>{const{searchString:n}=this.state;if(0===e.length&&/ami-[0-9a-f]{8,17}/.exec(n)){return[kl.makeFakeImage(n,n,t)].filter((e=>!!e))}const r=e.filter((e=>!!e.amis[t]));return this.sortImages(r,a)}))).pipe($a(this.destroy$)).subscribe((e=>this.setState({searchResults:e}))),l.pipe($a(this.destroy$)).subscribe((e=>{this.setState({packageImages:e}),this.selectImage(this.findMatchingImage(e,this.props.value))})),e.pipe(Fa((e=>{const t=this.props.value;if("packageImages"===this.state.selectionMode)return l.pipe(Da((e=>this.findMatchingImage(e,t))));{const a=!!(t&&t.amis&&t.amis[e]);return xa(a?t:void 0)}})),$a(this.destroy$)).subscribe((e=>this.selectImage(e)))}setSortImagesBy(e){this.sortImagesBy$.next(e)}sortImages(e,t){return e.slice().sort(((e,a)=>"ts"===t?a.attributes.creationDate.localeCompare(e.attributes.creationDate):e.imageName.localeCompare(a.imageName)))}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}render(){const{value:e,credentials:t,region:a,onChange:r}=this.props,{isLoadingPackageImages:i,isSearching:s,selectionMode:l,packageImages:o,searchResults:c,searchString:d}=this.state,u=!!o,p=e=>{const n=e.amis||{},r=n[a]&&n[a][0],i=r?`(${r})`:` - not found in ${t}/${a}`;return Vt.createElement(Vt.Fragment,null,Vt.createElement("span",null,e.imageName),Vt.createElement("span",null,i))},m={clearable:!1,required:!0,valueKey:"imageName",optionRenderer:p,valueRenderer:p,onSelectResetsInput:!1,onBlurResetsInput:!1,onCloseResetsInput:!1,value:e},g=this.state.errorMessage?Vt.createElement(pe,{message:this.state.errorMessage,type:"error"}):null,h=`No results found in ${t}/${a}`;if("searchAllImages"===l){const e=!d||d.length<3?"Please enter at least 3 characters":s?"Searching...":h;return Vt.createElement("div",{className:"col-md-9"},Vt.createElement(f,{...m,menuRenderer:this.buildImageMenu,isLoading:s,placeholder:"Search for an image...",filterOptions:!1,noResultsText:e,options:c,onInputChange:e=>(this.searchInput$.next(e),e),onChange:r}),g)}return u?Vt.createElement("div",{className:"col-md-9"},Vt.createElement(f,{...m,menuRenderer:this.buildImageMenu,isLoading:i,placeholder:"Pick an image",noResultsText:h,options:o,onChange:r}),g,Vt.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Vt.createElement(n,{id:"aws.serverGroup.allImages"})):Vt.createElement("div",{className:"col-md-9"},Vt.createElement(f,{...m,isLoading:i,disabled:!0,options:[e].filter((e=>!!e))}),g,Vt.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Vt.createElement(n,{id:"aws.serverGroup.allImages"}))}}const Nl=e=>e&&e.includes("${");class Tl extends Vt.Component{constructor(e){super(e),this.imageChanged=e=>{var t,n;const{setFieldValue:r,values:i}=this.props.formik;this.setState({selectedImage:e});const s=e&&e.attributes.virtualizationType,l=e&&e.attributes.architecture,o=e&&e.imageName;if(i.virtualizationType=s,i.amiArchitecture=l,i.amiName=o,r("amiArchitecture",l),r("virtualizationType",s),r("amiName",o),i.imageChanged(i),e&&(null==(t=a.disabledImages)?void 0:t.length)&&(null==(n=kn.serverGroups)?void 0:n.enableIPv6)){a.disabledImages.some((t=>e.imageName.includes(t)))&&r("associateIPv6Address",!1)}this.props.formik.validateForm()},this.accountUpdated=e=>{var t,a,n,r,i,s,l,o,c,d,u;const{setFieldValue:p,values:m}=this.props.formik;m.credentials=e,m.credentialsChanged(m),m.subnetChanged(m),p("credentials",e);const g=m.backingData.credentialsKeyedByAccount[e];if(p("associateIPv6Address",(null==(a=null==(t=kn)?void 0:t.serverGroups)?void 0:a.enableIPv6)&&(null==(r=null==(n=kn)?void 0:n.serverGroups)?void 0:r.setIPv6InTest)&&"test"===g.environment),null==(i=kn.serverGroups)?void 0:i.enableIMDSv2){const t=!(null==(o=null==(l=null==(s=kn)?void 0:s.serverGroups)?void 0:l.accountDenyListIMDSv2)?void 0:o.includes(e)),a=null==(c=kn.serverGroups)?void 0:c.defaultIMDSv2AppAgeLimit,n=null==(u=null==(d=this.props.app)?void 0:d.attributes)?void 0:u.createTs;p("requireIMDSv2",t&&a&&n&&Number(n)>a)}},this.regionUpdated=e=>{const{values:t,setFieldValue:a}=this.props.formik;t.region=e,t.regionChanged(t),a("region",e)},this.subnetUpdated=()=>{const{setFieldValue:e,values:t}=this.props.formik;t.subnetChanged(t),e("subnetType",t.subnetType)},this.clientRequestsChanged=()=>{const{values:e,setFieldValue:t}=this.props.formik;e.toggleSuspendedProcess(e,"AddToLoadBalancer"),t("suspendedProcesses",e.suspendedProcesses),this.setState({})},this.navigateToLatestServerGroup=()=>{const{values:e}=this.props.formik,{latestServerGroup:t}=this.state,a={provider:e.selectedProvider,accountId:t.account,region:t.region,serverGroup:t.name},{$state:n}=h;n.is("home.applications.application.insight.clusters")?n.go(".serverGroup",a):n.go("^.serverGroup",a)},this.stackChanged=e=>{const{setFieldValue:t,values:a}=this.props.formik;a.stack=e,t("stack",e),a.clusterChanged(a)},this.handleReasonChanged=e=>{this.props.formik.setFieldValue("reason",e)},this.strategyChanged=(e,t)=>{e.onStrategyChange(e,t),this.props.formik.setFieldValue("strategy",t.key)},this.onStrategyFieldChange=(e,t)=>{this.props.formik.setFieldValue(e,t)};const{amiName:t,region:n,viewState:{imageId:r}}=e.formik.values,i=kl.makeFakeImage(t,r,n);this.state={...this.getStateFromProps(e),selectedImage:i}}getStateFromProps(e){const{app:t}=e,{values:a}=e.formik,n=re.getClusterName(t.name,a.stack,a.freeFormDetails),r=!t.clusters.find((e=>e.name===n)),i=t.serverGroups.data.filter((e=>e.cluster===n&&e.account===a.credentials&&e.region===a.region)).sort(((e,t)=>e.createdTime-t.createdTime)),s=i.length?i.pop():null;return{namePreview:n,createsNewCluster:r,latestServerGroup:s}}validate(e){const t={};var a,n;return a=e.stack,Nl(a)||/^([a-zA-Z_0-9._${}]*(\${.+})*)*$/.test(a)||(t.stack="Only dot(.) and underscore(_) special characters are allowed in the Stack field."),n=e.freeFormDetails,Nl(n)||/^([a-zA-Z_0-9._${}-]*(\${.+})*)*$/.test(n)||(t.freeFormDetails="Only dot(.), underscore(_), and dash(-) special characters are allowed in the Detail field."),e.viewState.disableImageSelection||e.amiName||(t.amiName="Image required."),e.resourceSummary&&(t.resourceSummary={id:"Cluster is managed"}),t}componentWillReceiveProps(e){this.setState(this.getStateFromProps(e))}render(){const{app:e,formik:t}=this.props,{errors:a,values:r}=t,{createsNewCluster:i,latestServerGroup:s,namePreview:l}=this.state,o=r.backingData.accounts,c=r.viewState.readOnlyFields||{};return Vt.createElement("div",{className:"container-fluid form-horizontal"},r.regionIsDeprecated(r)&&Vt.createElement("div",{className:"form-group row"},Vt.createElement("div",{className:"col-md-12 error-message"},Vt.createElement("div",{className:"alert alert-danger"},"You are deploying into a deprecated region within the ",r.credentials," account!"))),Vt.createElement(ct,{app:e,formik:t}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Vt.createElement("div",{className:"col-md-7"},Vt.createElement(Se,{value:r.credentials,onChange:e=>this.accountUpdated(e.target.value),readOnly:c.credentials,accounts:o,provider:"aws"}))),Vt.createElement(ke,{readOnly:c.region,labelColumns:3,component:r,field:"region",account:r.credentials,regions:r.backingData.filtered.regions,onChange:this.regionUpdated}),Vt.createElement(ci,{readOnly:c.subnet,labelColumns:3,helpKey:"aws.serverGroup.subnet",component:r,field:"subnetType",region:r.region,application:e,subnets:r.backingData.filtered.subnetPurposes,onChange:this.subnetUpdated,showSubnetWarning:!0}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Vt.createElement(n,{id:"aws.serverGroup.stack"})),Vt.createElement("div",{className:"col-md-7"},Vt.createElement("input",{type:"text",className:"form-control input-sm no-spel",value:r.stack,onChange:e=>this.stackChanged(e.target.value)}))),a.stack&&Vt.createElement("div",{className:"form-group row slide-in"},Vt.createElement("div",{className:"col-sm-9 col-sm-offset-2 error-message"},Vt.createElement("span",null,a.stack))),Vt.createElement(dt,{app:e,formik:t}),r.viewState.imageSourceText&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Image Source"),Vt.createElement("div",{className:"col-md-7",style:{marginTop:"5px"}},Vt.createElement(Ce,{tag:"span",message:r.viewState.imageSourceText}))),!r.viewState.disableImageSelection&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Image ",Vt.createElement(n,{id:"aws.serverGroup.imageName"})),Nl(r.amiName)?Vt.createElement(un,{name:"amiName"}):Vt.createElement(kl,{onChange:e=>this.imageChanged(e),value:this.state.selectedImage,application:e,credentials:r.credentials,region:r.region})),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Traffic ",Vt.createElement(n,{id:"aws.serverGroup.traffic"})),Vt.createElement("div",{className:"col-md-9 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",onChange:this.clientRequestsChanged,checked:!r.processIsSuspended(r,"AddToLoadBalancer"),disabled:""!==r.strategy&&"custom"!==r.strategy}),"Send client requests to new instances"))),!r.viewState.disableStrategySelection&&r.selectedProvider&&Vt.createElement(ut,{command:r,onFieldChange:this.onStrategyFieldChange,onStrategyChange:this.strategyChanged}),!r.viewState.hideClusterNamePreview&&Vt.createElement(pt,{createsNewCluster:i,latestServerGroupName:null==s?void 0:s.name,mode:r.viewState.mode,namePreview:l,navigateToLatestServerGroup:this.navigateToLatestServerGroup}),Vt.createElement(mt,{reason:r.reason,onChange:this.handleReasonChanged}))}}class Il extends Vt.Component{constructor(){super(...arguments),this.preferSourceCapacityOptions=[{label:"fail the stage",value:!1},{label:"use fallback values",value:!0}],this.useSourceCapacityUpdated=e=>{const t="true"===e.target.value,{command:a}=this.props;this.props.setFieldValue("useSourceCapacity",t),t||(delete a.preferSourceCapacity,this.props.setFieldValue("preferSourceCapacity",void 0)),this.setState({})},this.simpleInstancesChanged=e=>{this.setMinMax(e)},this.preferSourceCapacityChanged=e=>{this.props.setFieldValue("preferSourceCapacity",!(!e||!e.value)||void 0),this.setState({})},this.capacityFieldChanged=(e,t)=>{const{command:a,setFieldValue:n}=this.props;a.capacity={...a.capacity},a.capacity[e]=t,n("capacity",a.capacity)}}setSimpleCapacity(e){const{command:t}=this.props,a={...t.viewState,useSimpleCapacity:e};this.props.setFieldValue("useSourceCapacity",!1),this.props.setFieldValue("viewState",a),this.setMinMax(t.capacity.desired),this.setState({})}setMinMax(e){const{command:t}=this.props;t.viewState.useSimpleCapacity&&(t.capacity={min:e,max:e,desired:e},this.props.setFieldValue("useSourceCapacity",!1),this.props.setFieldValue("capacity",t.capacity)),this.setState({})}render(){const{command:e,MinMaxDesired:t}=this.props,a=e.viewState.readOnlyFields||{};return!e.viewState.useSimpleCapacity||e.useSourceCapacity?Vt.createElement("div",null,Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("p",null,"Sets up auto-scaling constraints for this server group."),Vt.createElement("p",null,"To set min, max, and desired instance counts to the same value use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!0)},"Simple Mode"),"."))),!a.useSourceCapacity&&"editPipeline"===e.viewState.mode&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Capacity"),Vt.createElement("div",{className:"col-md-9 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:e.useSourceCapacity,value:"true",id:"useSourceCapacityTrue",onChange:this.useSourceCapacityUpdated}),"Copy the capacity from the current server group",Vt.createElement(n,{id:"serverGroupCapacity.useSourceCapacityTrue"}))),e.useSourceCapacity&&Vt.createElement("div",{className:"col-md-9 col-md-offset-3 radio",style:{paddingLeft:"35px"}},Vt.createElement("div",null,"If no current server group is found,",Vt.createElement(rn,{clearable:!1,value:!!e.preferSourceCapacity,options:this.preferSourceCapacityOptions,onChange:this.preferSourceCapacityChanged})),e.preferSourceCapacity&&Vt.createElement("div",null,Vt.createElement("b",null,"Fallback values"),Vt.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged}))),Vt.createElement("div",{className:"col-md-9 col-md-offset-3 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:!e.useSourceCapacity,value:"false",id:"useSourceCapacityFalse",onChange:this.useSourceCapacityUpdated}),"Let me specify the capacity",Vt.createElement(n,{id:"serverGroupCapacity.useSourceCapacityFalse"})))),(!e.useSourceCapacity||"editPipeline"!==e.viewState.mode)&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-9 col-md-offset-3"},Vt.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged})))):Vt.createElement("div",null,Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("p",null,"Sets the min, max, and desired instance counts to the same value."),Vt.createElement("p",null," ","To set capacity for auto-scaling, use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!1)},"Advanced Mode"),"."))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Number of Instances"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:e.capacity.desired,min:0,onChange:this.simpleInstancesChanged}))))}}class Gl extends Vt.Component{render(){const{command:{capacity:{min:e,max:t,desired:a}},fieldChanged:n}=this.props;return Vt.createElement("div",null,Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-2"},"Min"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:e,min:0,max:"number"==typeof t?t:void 0,onChange:e=>n("min",e),required:!0}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-2"},"Max"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:t,min:"number"==typeof e?e:void 0,onChange:e=>n("max",e),required:!0}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-2"},"Desired"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:a,min:"number"==typeof e?e:void 0,max:"number"==typeof t?t:void 0,onChange:e=>n("desired",e),required:!0}))))}}class Al extends Vt.Component{validate(e){const t={};(gt(e.capacity.min)<0||gt(e.capacity.max)<0||gt(e.capacity.desired)<0)&&(t.capacity="Capacity min, max, and desired all have to be non-negative values.");const a=e;return void 0!==a.targetHealthyDeployPercentage&&null!==a.targetHealthyDeployPercentage||(t.targetHealthyDeployPercentage="Target Healthy Deploy Percentage required."),t}render(){const{setFieldValue:e,values:t}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"row"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement(Il,{command:t,setFieldValue:e,MinMaxDesired:Gl}))),Vt.createElement("div",{className:"row"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"form-group form-inline",style:{marginTop:"20px"}},Vt.createElement("div",{className:"col-md-12"},"Consider deployment successful when"," ",Vt.createElement(un,{type:"number",name:"targetHealthyDeployPercentage",min:"0",max:"100",className:"form-control input-sm inline-number",required:!0})," ","percent of instances are healthy.")))))}}function xl(e){return Vt.createElement("div",null,Vt.createElement("h4",{style:{marginTop:"10px"}},"This application is"),e.instanceProfileList.map((t=>Vt.createElement("div",{key:t.type,className:"instance-profile-header profile-button"},Vt.createElement("button",{type:"button",onClick:()=>e.handleProfileChange(t.type),className:e.currentProfile===t.type?"instance-profile active":"instance-profile"},e.currentProfile===t.type&&Vt.createElement("span",{className:"far fa-check-circle selected-indicator"}),Vt.createElement("div",{className:"panel-heading"},Vt.createElement("h4",null,Vt.createElement("span",{className:`glyphicon glyphicon-${t.icon}`}),Vt.createElement("div",null,t.label))))))))}function Pl(e){const{selectedInstanceTypes:t,currentProfile:a}=e,n=Xn.awsInstanceTypeService.isBurstingSupportedForAllTypes(t),r=!!Xn.awsInstanceTypeService.getInstanceTypesInCategory(t,a).length,[i,s]=Ut(!1);return qt((()=>{t&&t.length&&(n||e.setUnlimitedCpuCredits(void 0),s(n)),a&&s(t&&t.length>0&&n&&r)}),[a,t]),Vt.createElement("div",{className:"row",style:{fontSize:"110%"}},i&&Vt.createElement("div",null,Vt.createElement(ht,{toggleSize:ft.XSMALL,propLabel:"Unlimited CPU credits ",propHelpFieldId:"aws.serverGroup.unlimitedCpuCredits",tooltipPropOffBtn:"Toggle to turn OFF unlimited CPU credits",displayTextPropOffBtn:"Off",tooltipPropOnBtn:"Toggle to turn ON unlimited CPU credits",displayTextPropOnBtn:"On",onClick:t=>e.setUnlimitedCpuCredits(t),isPropertyActive:e.unlimitedCpuCredits})))}function Dl(e){var t,a,n,r,i,s,l,o,c,d,u,p,m,g,h,f,v,y,b,E,w,C,S,k,N;const T=(null==(a=null==(t=e.instanceType)?void 0:t.supportedUsageClasses)?void 0:a.includes("spot"))?"| SPOT supported":"",I=`${null==(n=e.instanceType)?void 0:n.defaultVCpus} vCPU | ${null==(r=e.instanceType)?void 0:r.memoryInGiB} Gib Memory ${T}`,G=(null==(i=e.instanceType)?void 0:i.instanceStorageSupported)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},`Instance Storage: ${Ht.toUpper(null==(l=null==(s=e.instanceType)?void 0:s.instanceStorageInfo)?void 0:l.storageTypes)} | ${null==(c=null==(o=e.instanceType)?void 0:o.instanceStorageInfo)?void 0:c.totalSizeInGB} Gib total size`)),A=(null==(d=e.instanceType)?void 0:d.ebsInfo)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},`EBS: optimization ${null==(p=null==(u=e.instanceType)?void 0:u.ebsInfo)?void 0:p.ebsOptimizedSupport} | NVMe ${null==(g=null==(m=e.instanceType)?void 0:m.ebsInfo)?void 0:g.nvmeSupport} | Encryption ${null==(f=null==(h=e.instanceType)?void 0:h.ebsInfo)?void 0:f.encryptionSupport}`)),x=(null==(v=e.instanceType)?void 0:v.gpuInfo)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},`GPU: ${null==(b=null==(y=e.instanceType)?void 0:y.gpuInfo)?void 0:b.totalGpuMemoryInMiB} MiB total memory`,null==(w=null==(E=e.instanceType)?void 0:E.gpuInfo)?void 0:w.gpus.map((e=>` | ${e.count} ${e.manufacturer} ${e.name} GPUs, size: ${e.gpuSizeInMiB} MiB`)))),P=void 0!==(null==(C=e.instanceType)?void 0:C.currentGeneration)&&null!==(null==(S=e.instanceType)?void 0:S.currentGeneration)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},(null==(k=e.instanceType)?void 0:k.currentGeneration)?"Current Generation":"Previous Generation"));return Vt.createElement("span",null,Vt.createElement("span",{className:"select-option-label"},null==(N=e.instanceType)?void 0:N.name),Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},I),G,A,x,P)}xr(".advanced-mode-selector .instance-profile-header {\n display: inline-block;\n}\n.advanced-mode-selector .instance-profile-header button {\n width: 100%;\n}\n.advanced-mode-selector .instance-profile-header h4 {\n min-height: 52px;\n}\n.advanced-mode-selector .instance-profile-header .panel-heading {\n padding: 0 0 0 0;\n}\n.advanced-mode-selector .instance-profile-header.profile-button {\n width: calc(25% - 20px);\n margin: 0 10px 15px 10px;\n}\n.advanced-mode-selector .sub-section {\n padding: 0 15px;\n margin-bottom: 5px;\n}\n.advanced-mode-selector .sub-section .description {\n padding: 0 10px;\n}\n.advanced-mode-selector .sub-section tr.unavailable {\n opacity: 0.5;\n}\n.advanced-mode-selector .sub-section tr.sortable .instance-type-drag-handle {\n display: inline-block;\n opacity: 0.9;\n font-size: 100%;\n padding-top: 8px;\n}\n.advanced-mode-selector .sub-section th {\n font-size: 110%;\n}\n.custom-profile .select {\n width: 97%;\n display: inline-flex;\n}\n.custom-profile .select-option-label {\n font-size: 100%;\n font-weight: bold;\n}\n.custom-profile .select-option-label-attributes {\n font-size: 90%;\n font-weight: normal;\n font-style: italic;\n}\n.instance-profile {\n vertical-align: top;\n text-align: left;\n min-height: 100px;\n font-size: 90%;\n border: 1px solid var(--color-silver);\n border-radius: 3px;\n color: var(--color-mineshaft);\n background-color: transparent;\n}\n.instance-profile:hover,\n.instance-profile:focus {\n color: var(--color-mineshaft);\n text-decoration: none;\n}\n.instance-profile .selected-indicator {\n display: flex;\n width: 100%;\n text-align: right;\n padding-right: 5px;\n font-size: 150%;\n color: var(--color-accent);\n}\n.instance-profile .selected-indicator.custom {\n margin-top: 5px;\n}\n.instance-profile h4 {\n margin-top: 0;\n text-align: center;\n word-spacing: 300px;\n}\n.instance-profile ul {\n font-size: 95%;\n padding-left: 20px;\n}\n.instance-profile .panel-heading {\n padding-top: 0;\n padding-bottom: 0;\n}\n.instance-profile:hover,\n.instance-profile:focus,\n.instance-profile.active {\n outline: 0;\n}\n.instance-profile.active {\n box-shadow: inset 0 0 3px 2px var(--color-accent);\n border-color: var(--color-accent);\n}\n.instance-profile:hover,\n.instance-profile:focus {\n box-shadow: 0 0 8px 2px var(--color-accent);\n}\n");const Bl=({min:e,max:t})=>{const a=Vt.createElement(Vt.Fragment,null,Vt.createElement("span",{className:"cost"},"$".repeat(e)),"$".repeat(4-e)),n=Vt.createElement(Vt.Fragment,null,Vt.createElement("span",{className:"cost"},"$".repeat(Math.min(4,t))),"$".repeat(4-Math.min(4,t)));return Vt.createElement("span",{className:"cost-factor"},a,t?` - ${n}`:"")};function zl(e){var t,a;const n=!!e.selectedType,[r,i]=Ut(""),s=n?e.selectedType.instanceType:e.instanceTypeDetails.name,o=!n&&e.instanceTypeDetails.unavailable,c=(t,a)=>{o||e.addOrUpdateInstanceType(t,a),i("")},d=e=>{i(e.target.value),n?c(s,e.target.value):document.getElementById(`selectInstanceType-${s}`).focus()};let u;if(e.isCustom){const a=Vt.createElement(Dl,{instanceType:e.selectedTypeInfo});u=Vt.createElement("tr",{key:s,className:"sortable clickable"},Vt.createElement("td",null,Vt.createElement(Fl,null)),Vt.createElement("td",null,`${s} `,Vt.createElement(ne,{placement:"right",template:a,className:"custom-profile"},Vt.createElement("span",{className:"clickable help-field"},Vt.createElement("i",{className:"small glyphicon glyphicon-info-sign"})))),Vt.createElement("td",{title:"Enter optional weight (allowed values: 1 to 999)."},Vt.createElement(l,{className:"form-control input input-sm",pattern:"[0-9]*",placeholder:"Enter optional weight (allowed values: 1 to 999).",value:(null==(t=e.selectedType)?void 0:t.weightedCapacity)||"",onChange:e=>c(s,e.target.value)})),Vt.createElement("td",null,Vt.createElement("div",null,Vt.createElement("span",null,Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeInstanceType(s),style:{padding:"5px"}},Vt.createElement(_,{value:"Remove instance type"},Vt.createElement("span",{className:"glyphicon glyphicon-trash"})))))))}else{const{cpu:t,memory:i,cpuCreditsPerHour:p,storage:m,costFactor:g}=e.instanceTypeDetails;u=Vt.createElement("tr",{key:s,className:n?"sortable clickable":"non-sortable "+(o?"unavailable":"clickable"),title:n?"Click to unselect instance type":o?"This instance type is not available for the selected configuration":"Click to select instance type",onClick:t=>{$(t.target).is("input")||(n?e.removeInstanceType(s):c(s,r))}},n?Vt.createElement("td",null,Vt.createElement(Fl,null)):Vt.createElement("td",null),Vt.createElement("td",null,Vt.createElement(_a,{id:`selectInstanceType-${s}`,checked:!!n,disabled:o,onChange:()=>{n?e.removeInstanceType(s):c(s,r)}})),Vt.createElement("td",null,s),Vt.createElement("td",null,t),Vt.createElement("td",null,i),p?Vt.createElement("td",null,p):Vt.createElement("td",{title:"Cpu credits not applicable to instance type."},"-"),"EBS"===m.type&&Vt.createElement("td",null,"EBS Only"),"SSD"===m.type&&Vt.createElement("td",null,m.count+"x"+m.size),Vt.createElement("td",null,Vt.createElement(Bl,{min:g})),Vt.createElement("td",{title:o?"":"Enter optional weight (allowed values: 1 to 999)."},Vt.createElement(l,{inputClassName:"form-control input input-sm",id:`weightedCapacity-${s}`,pattern:"[0-9]*",placeholder:"Enter optional weight (allowed values: 1 to 999).",disabled:o,value:(null==(a=e.selectedType)?void 0:a.weightedCapacity)||r||"",onChange:d})))}return u}const Fl=sn((()=>Vt.createElement(_,{value:"Drag to change priority"},Vt.createElement("span",{className:"instance-type-drag-handle glyphicon glyphicon-resize-vertical"}))));function Ml(e){return Vt.createElement($l,{isCustom:e.isCustom,selectedInstanceTypesMap:e.selectedInstanceTypesMap,selectedInstanceTypesInfo:e.selectedInstanceTypesInfo,removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType,instanceTypeDetails:e.isCustom?null:new Map(Object.entries(ya(Kt(e.profileFamiliesDetails.map((e=>e.instanceTypes))),"name"))),onSortEnd:t=>e.handleSortEnd(t),distance:1})}const $l=cn((e=>{const{isCustom:t,selectedInstanceTypesMap:a}=e;let n,r;if(t)n=a.size>0&&Array.from(a.values()).sort(((e,t)=>e.priority-t.priority)).map(((t,a)=>Vt.createElement(Ll,{key:`${t.instanceType}-${a}`,index:a,isCustom:!0,selectedType:t,selectedTypeInfo:e.selectedInstanceTypesInfo.find((e=>e.name===t.instanceType)),removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType})));else{const{instanceTypeDetails:t}=e,i=Array.from(null==t?void 0:t.keys()),s=la(i,Array.from(a.keys())),l=Array.from(a.values()).filter((e=>i.includes(e.instanceType))).sort(((e,t)=>e.priority-t.priority));n=l&&l.length>0&&l.map(((a,n)=>Vt.createElement(Ll,{key:`${a.instanceType}-${n}`,index:n,isCustom:!1,selectedType:a,instanceTypeDetails:t,removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType}))),r=s&&s.length>0&&s.map((a=>Vt.createElement(zl,{key:a,isCustom:!1,instanceTypeDetails:t.get(a),addOrUpdateInstanceType:e.addOrUpdateInstanceType})))}return Vt.createElement("tbody",null,n,t?null:r)})),Ll=on((e=>Vt.createElement(zl,{key:e.selectedType.instanceType,isCustom:e.isCustom,selectedType:e.selectedType,selectedTypeInfo:e.selectedTypeInfo,instanceTypeDetails:e.isCustom?null:e.instanceTypeDetails.get(e.selectedType.instanceType),removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType})));function Rl(e){return Vt.createElement("div",{className:"custom-profile"},Vt.createElement(rn,{className:"select",clearable:!1,multi:!1,placeholder:"Filter like 16vcpu, 32gib, spot, oldGen or Select an instance type to add",removeSelected:!0,searchable:!0,options:e.availableInstanceTypesList,optionRenderer:e=>Vt.createElement(Dl,{instanceType:e}),filterOption:(e,t)=>{const{name:a,defaultVCpus:n,memoryInGiB:r,instanceStorageInfo:i,ebsInfo:s,gpuInfo:l,supportedUsageClasses:o,currentGeneration:c}=e;return t.split(",").every((e=>{const t=Ht.toLower(e.trim());return t.match(/\d+\s*vcpu/)&&n>=Ht.toNumber(t.split("vcpu")[0].trim())||t.match(/\d+\s*gib/)&&r>=Ht.toNumber(t.split("gib")[0].trim())||t.match(/\b(ssd|hdd)\b/)&&(null==i?void 0:i.storageTypes.includes(t))||"spot"===t&&(null==o?void 0:o.includes(t))||"ebs"===t&&s||"gpu"===t&&l||"currentgen"===t&&c||"oldgen"===t&&!c||a.match(t)}))},valueRenderer:e=>Vt.createElement(Vt.Fragment,null,e.name),onChange:t=>e.addOrUpdateInstanceType(t.name,void 0)})," ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypesSelect"}))}function Ol(e){let t;return t=e.isCustom?Vt.createElement("p",null,"Choose the instance types that best suit the needs of your application."):Vt.createElement(Vt.Fragment,null,Vt.createElement("p",null,Vt.createElement("b",null,e.profileLabel)),Vt.createElement("ul",null,e.profileDescriptionArr.map(((e,t)=>Vt.createElement("li",{key:t},e))))),Vt.createElement("div",{className:"row sub-section"},Vt.createElement("h4",null,"Instance Types"),Vt.createElement("div",{className:"description"},t,Vt.createElement("p",null,"Learn about AWS recommended best practices in"," ",Vt.createElement("a",{target:"_blank",href:"https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates/#create-a-server-group-with-aws-recommended-best-practices-for-ec2-spot"},"examples and docs"),"."),Vt.createElement("i",null,Vt.createElement("b",null,"Note:"),Vt.createElement("ul",null,Vt.createElement("li",null,"The order of instance types sets their priority when On-Demand capacity is launched; instance type at the top is prioritized the highest."),Vt.createElement("li",null,"Some instance types might not be available for the selected configuration.")))))}function Vl(e){let t,a,r,i;return e.isCustom?(t=Vt.createElement("th",null),a=Vt.createElement("th",null,"Instance Type ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypes"})),r=null,i=Vt.createElement("th",null)):(t=Vt.createElement(Vt.Fragment,null,Vt.createElement("th",null),Vt.createElement("th",null)),a=Vt.createElement("th",null,"InstanceType"),r=Vt.createElement(Vt.Fragment,null,Vt.createElement("th",null,"vCPU"),Vt.createElement("th",null,"Mem (GiB)"),e.showCpuCredits&&Vt.createElement("th",null,"CPU Credits"),Vt.createElement("th",null,"Storage (GB)",Vt.createElement(n,{id:"aws.serverGroup.storageType"})),Vt.createElement("th",null,"Cost")),i=null),Vt.createElement("thead",null,Vt.createElement("tr",null,t,a,r,Vt.createElement("th",null,"Weight ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})),i))}function Ul(e){return e.isCustom?Vt.createElement("tfoot",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign",style:{paddingTop:"8px"}})),Vt.createElement("td",{colSpan:2},Vt.createElement(Rl,{availableInstanceTypesList:e.availableInstanceTypesList,addOrUpdateInstanceType:e.addOrUpdateInstanceType})),Vt.createElement("td",null))):null}function ql(e){return e.dirty.instanceType||e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0?Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),e.dirty.instanceType&&"The following instance type was found incompatible with the selected image/region and was removed:",e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0&&"The following instance type(s) were found incompatible with the selected image/region and were removed:"),Vt.createElement("ul",null,e.dirty.instanceType&&Vt.createElement("li",{key:e.dirty.instanceType},e.dirty.instanceType),e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0&&e.dirty.launchTemplateOverridesForInstanceType.map((e=>Vt.createElement("li",{key:e.instanceType},e.instanceType,e.weightedCapacity?" with weight "+e.weightedCapacity:"")))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>e.clearWarnings()},"Okay")))):null}function Hl(e){var t;const{currentProfile:a,selectedInstanceTypesMap:n}=e,r=e=>{const t=Array.from(n.values()).sort(((e,t)=>e.priority-t.priority)).map((e=>e.instanceType)),a=ln(t,e.oldIndex,e.newIndex);i(a)},i=t=>{n.forEach(((e,a)=>{const n=1+t.indexOf(a);e.priority!==n&&(e.priority=n)})),e.handleInstanceTypesChange(Array.from(n.values()))},s=t=>{const a=new Map(n);a.delete(t),e.handleInstanceTypesChange(Array.from(a.values()))},l=(t,a)=>{const r=Number(a),i=isNaN(r)||0===r?void 0:r.toString(),s=n.has(t)?{...n.get(t),weightedCapacity:i}:{instanceType:t,weightedCapacity:i,priority:1+Array.from(n.values()).reduce(((e,t)=>t.priority>e?t.priority:e),0)};n.set(t,s),e.handleInstanceTypesChange(Array.from(n.values()))},o=null==(t=kn.serverGroups)?void 0:t.enableCpuCredits,c=Array.from(n.keys()),d=Vt.createElement("div",null,Vt.createElement(Pl,{unlimitedCpuCredits:e.unlimitedCpuCreditsInCmd,currentProfile:a,selectedInstanceTypes:c,setUnlimitedCpuCredits:e.setUnlimitedCpuCredits}));if(a&&"custom"!==a){const{label:t,descriptionListOverride:a,families:i,showCpuCredits:c}=e.profileDetails,u=!1;return Vt.createElement("div",{className:"row sub-section"},Vt.createElement(Ol,{isCustom:u,profileLabel:t,profileDescriptionArr:a||i.map((e=>e.description))}),Vt.createElement(ql,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Vt.createElement("table",{className:"table table-hover"},Vt.createElement(Vl,{isCustom:u,showCpuCredits:c}),Vt.createElement(Ml,{isCustom:u,profileFamiliesDetails:i,selectedInstanceTypesMap:n,addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r})))}{const t=!0;return Vt.createElement("div",{className:"row sub-section"},Vt.createElement(Ol,{isCustom:t}),Vt.createElement(ql,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Vt.createElement("table",{className:"table table-hover"},Vt.createElement(Vl,{isCustom:t}),Vt.createElement(Ml,{isCustom:t,selectedInstanceTypesMap:n,selectedInstanceTypesInfo:e.availableInstanceTypesList.filter((e=>c.includes(e.name))),addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r}),Vt.createElement(Ul,{isCustom:t,availableInstanceTypesList:e.availableInstanceTypesList.filter((e=>!c.includes(e.name))),addOrUpdateInstanceType:l})))}}function Wl(e,t,a){const n=ia(e.values,t);Vt.useEffect((()=>{void 0===n&&void 0!==a&&e.setFieldValue(t,a)}),[t,a,n])}function jl(e){const{values:t,setFieldValue:a}=e.formik,r=[{label:"capacity-optimized (recommended)",value:"capacity-optimized"},{label:"capacity-optimized-prioritized",value:"capacity-optimized-prioritized"},{label:"lowest-price",value:"lowest-price"}];return Vt.useEffect((()=>{"lowest-price"!==t.spotAllocationStrategy?a("spotInstancePools",void 0):void 0===t.spotInstancePools&&a("spotInstancePools",2)}),[t.spotAllocationStrategy]),Wl(e.formik,"spotAllocationStrategy","capacity-optimized"),Wl(e.formik,"onDemandAllocationStrategy","prioritized"),Wl(e.formik,"onDemandBaseCapacity",0),Wl(e.formik,"onDemandPercentageAboveBaseCapacity",100),Vt.createElement("div",{className:"InstancesDistribution row sub-section form-group"},Vt.createElement("h4",null,"Instances Distribution"),Vt.createElement("div",{className:"description"},"Diversify and distribute instance types across purchase options."," ",Vt.createElement(n,{id:"aws.serverGroup.instancesDistribution"})),Vt.createElement("br",null),Vt.createElement(s,{label:"Spot Allocation Strategy",name:"spotAllocationStrategy",help:Vt.createElement(n,{id:"aws.serverGroup.spotAllocationStrategy"}),input:e=>Vt.createElement(c,{...e,mode:"PLAIN",options:r})}),"lowest-price"===e.formik.values.spotAllocationStrategy&&Vt.createElement(s,{label:"Spot Instance Pools Count",name:"spotInstancePools",help:Vt.createElement(n,{id:"aws.serverGroup.spotInstancePoolCount"}),input:e=>Vt.createElement(p,{...e})}),Vt.createElement(s,{label:"On-Demand Allocation Strategy",name:"onDemandAllocationStrategy",help:Vt.createElement(n,{id:"aws.serverGroup.odAllocationStrategy"}),input:e=>Vt.createElement(l,{...e,disabled:!0})}),Vt.createElement(s,{label:"On-Demand Base Capacity",name:"onDemandBaseCapacity",help:Vt.createElement(n,{id:"aws.serverGroup.odBase"}),input:e=>Vt.createElement(p,{...e})}),Vt.createElement(s,{label:"On-Demand Percentage Above Base Capacity",name:"onDemandPercentageAboveBaseCapacity",help:Vt.createElement(n,{id:"aws.serverGroup.odPercentAboveBase"}),input:e=>Vt.createElement(p,{...e})}),Vt.createElement(s,{label:"Spot Max Price",name:"spotPrice",help:Vt.createElement(n,{id:"aws.serverGroup.spotMaxPrice"}),input:e=>Vt.createElement(_,{value:"Recommended to leave empty and use AWS default i.e. On-Demand price"},Vt.createElement(l,{...e,placeholder:"Recommended to leave empty and use AWS default i.e. On-Demand price"}))}))}function Zl(e){const{instanceTypeDetails:t,setUnlimitedCpuCredits:a}=e,{values:n,setFieldValue:r}=e.formik,{instanceType:i,launchTemplateOverridesForInstanceType:s}=n;qt((()=>{!s&&i&&e.formik.setFieldValue("launchTemplateOverridesForInstanceType",[{instanceType:n.instanceType,priority:1}])}));const l=n.launchTemplateOverridesForInstanceType?n.launchTemplateOverridesForInstanceType:void 0,o=new Map(Object.entries(ya(l,"instanceType"))),[c,d]=Ut(n.viewState.instanceProfile||"custom"),u=vt(c);return t&&t.length>0?Vt.createElement("div",{className:"advanced-mode-selector"},Vt.createElement(xl,{currentProfile:c,handleProfileChange:e=>{d(e),r("viewState",{...n.viewState,instanceProfile:e});const t=u&&e&&u!==e,a="custom"!==e&&l&&l.length;if(t&&a){const t=Xn.awsInstanceTypeService.getInstanceTypesInCategory(l.map((e=>e.instanceType)),e),a=l.filter((e=>t.includes(e.instanceType)));r("launchTemplateOverridesForInstanceType",a),n.launchTemplateOverridesChanged(n)}},instanceProfileList:t}),Vt.createElement(jl,{formik:e.formik}),Vt.createElement(Hl,{currentProfile:c,selectedInstanceTypesMap:o,unlimitedCpuCreditsInCmd:n.unlimitedCpuCredits,profileDetails:t.find((e=>e.type===c)),availableInstanceTypesList:n.backingData&&n.backingData.filtered&&n.backingData.filtered.instanceTypesInfo||[],handleInstanceTypesChange:e=>{r("launchTemplateOverridesForInstanceType",e),n.launchTemplateOverridesChanged(n)},setUnlimitedCpuCredits:a,viewState:n.viewState,clearWarnings:e.clearWarnings})):null}function _l(e){var t,a;const{command:n}=e,{InstanceArchetypeSelector:r,InstanceTypeSelector:i}=yt,s=null==(t=kn.serverGroups)?void 0:t.enableLaunchTemplates,l=null==(a=kn.serverGroups)?void 0:a.enableCpuCredits,o=t=>{n.instanceTypeChanged(n),e.setFieldValue("instanceType",t)};return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"row"},Vt.createElement(r,{command:n,onTypeChanged:o,onProfileChanged:t=>{e.setFieldValue("viewState",{...n.viewState,instanceProfile:t})}}),Vt.createElement(ql,{dirty:n.viewState.dirty,clearWarnings:e.clearWarnings}),Vt.createElement("div",{style:{padding:"0 15px"}},n.viewState.instanceProfile&&"custom"!==n.viewState.instanceProfile&&Vt.createElement(i,{command:n,onTypeChanged:o}))),s&&l&&Vt.createElement("div",{className:"row"},Vt.createElement(Pl,{unlimitedCpuCredits:n.unlimitedCpuCredits,selectedInstanceTypes:[n.instanceType],currentProfile:n.viewState.instanceProfile,setUnlimitedCpuCredits:e.setUnlimitedCpuCredits})))}function Kl(e){var t;const{instanceTypeDetails:a}=e,{values:r,setFieldValue:i}=e.formik,s=null==(t=kn.serverGroups)?void 0:t.enableLaunchTemplates,l=r.viewState.useSimpleInstanceTypeSelector,[o,c]=Ut(r.unlimitedCpuCredits);qt((()=>{r.unlimitedCpuCredits!==o&&i("unlimitedCpuCredits",o)}),[o]);const d=()=>{const{formik:t}=e;t.values.viewState.dirty.instanceType=null,t.values.viewState.dirty.launchTemplateOverridesForInstanceType=null,t.validateForm()},u=e=>{if(l!==e)if(i("viewState",{...r.viewState,useSimpleInstanceTypeSelector:e}),e){const e=r.launchTemplateOverridesForInstanceType,t=r.viewState.dirty.launchTemplateOverridesForInstanceType;if(null==e?void 0:e.length){const t=e.reduce(((e,t)=>e.priority<t.priority?e:t)).instanceType;i("instanceType",t),i("launchTemplateOverridesForInstanceType",[]),r.instanceTypeChanged(r)}if(null==t?void 0:t.length){const e=t.reduce(((e,t)=>e.priority<t.priority?e:t)).instanceType;i("viewState.dirty.instanceType",e),i("viewState.dirty.launchTemplateOverridesForInstanceType",[])}}else if(!e){const e=r.instanceType,t=r.viewState.dirty.instanceType;if(e){const t=[{instanceType:e,priority:1}];i("instanceType",void 0),i("launchTemplateOverridesForInstanceType",t),r.launchTemplateOverridesChanged(r)}if(t){const e=[{instanceType:t,priority:1}];i("viewState.dirty.instanceType",void 0),i("viewState.dirty.launchTemplateOverridesForInstanceType",e)}}};return s&&!l?Vt.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Vt.createElement("div",null,Vt.createElement("p",null,"Switch to",Vt.createElement("a",{className:"clickable",onClick:()=>u(!0)},Vt.createElement("span",null," Simple Mode")),"."),Vt.createElement("i",null,Vt.createElement("b",null,"Note:")," If multiple instance types are already selected in advanced mode, the instance type with highest priority will be preserved in simple mode.")),Vt.createElement(Zl,{formik:e.formik,instanceTypeDetails:a,setUnlimitedCpuCredits:c,clearWarnings:d})):Vt.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Vt.createElement("div",null,Vt.createElement("span",null,"To configure mixed server groups and/or multiple instance types,"),!s&&Vt.createElement("span",null,Vt.createElement("a",{href:"https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates-setup/"},Vt.createElement("span",null," enable launch templates")),Vt.createElement("span",null," and")),Vt.createElement("span",null,Vt.createElement("a",{className:s?"clickable":"disabled",onClick:s?()=>u(!1):()=>{}},Vt.createElement("span",null," use Advanced Mode ")),Vt.createElement(n,{id:"aws.serverGroup.advancedMode"}),"."),Vt.createElement("p",null),s&&Vt.createElement("i",null,Vt.createElement("b",null,"Note:")," If an instance type is already selected in simple mode, it will be preserved in advanced mode.")),Vt.createElement(_l,{command:r,setUnlimitedCpuCredits:c,setFieldValue:i,clearWarnings:d}))}xr(".InstancesDistribution .StandardFieldLayout_Label {\n min-width: 300px;\n}\n");class Yl extends Vt.Component{constructor(){super(...arguments),this.state={instanceTypeDetails:[]},this.props$=new Ta,this.destroy$=new Ta}validate(e){const t={};if(e.viewState.useSimpleInstanceTypeSelector)e.viewState.dirty.instanceType?t.instanceType="You must confirm removed instance type and pick a compatible instance type.":e.instanceType||(t.instanceType="Instance Type required.");else{const a=e.viewState.dirty.launchTemplateOverridesForInstanceType;if(a&&a.length>0)t.instanceType="You must confirm removed instance types and/or pick more instance types.";else{const a=this.validateAdvancedModeFields(e,t);Object.assign(t,{...a})}}return t}validateAdvancedModeFields(e,t){e.launchTemplateOverridesForInstanceType.length||(t.instanceType="At least one instance type required."),e.launchTemplateOverridesForInstanceType.length>40&&(t.instanceType="Maximum of 40 instance types are allowed.");const a=e.launchTemplateOverridesForInstanceType.filter((e=>void 0!==e.weightedCapacity));if(a.length!==e.launchTemplateOverridesForInstanceType.length&&0!==a.length&&(t.instanceType="Weighted capacity must be specified for all instance types selected or none."),oa(a,(function(e){const t=Number(e.weightedCapacity);return t<1||t>999}))&&(t.instanceType="Weighted capacity must be a number between 1 and 999."),e.onDemandBaseCapacity<0&&(t.onDemandBaseCapacity="On-Demand base capacity must be non-negative."),e.onDemandBaseCapacity>gt(e.capacity.max)&&(t.onDemandBaseCapacity="On-Demand base capacity must be less than or equal to max capacity."),(e.onDemandPercentageAboveBaseCapacity<0||e.onDemandPercentageAboveBaseCapacity>100)&&(t.onDemandPercentageAboveBaseCapacity="On-Demand percentage above base capacity must be a number between 0 and 100."),e.spotPrice){const a=Number(e.spotPrice);Number.isNaN(a)&&(t.spotPrice="Spot Max Price must be a number or empty string, used to unset previous max price."),a<=0&&(t.spotPrice="Spot Max Price must be greater than 0, if specified.")}return e.spotInstancePools&&"lowest-price"!==e.spotAllocationStrategy&&(t.spotInstancePools="Spot Instance Pools is only supported for 'lowest-price' Spot Allocation Strategy."),(e.spotInstancePools<=0||e.spotInstancePools>20)&&(t.spotInstancePools="Spot Instance Pools count must be a number between 1 and 20, when applicable."),t}componentDidMount(){Promise.resolve(Xn.awsInstanceTypeService.getCategories()).then((e=>{this.setState({instanceTypeDetails:e})}))}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}render(){var e,t,a;const{values:n}=this.props.formik,r=!(!n.viewState.disableImageSelection&&!n.amiName),i=null!=(a=null==(t=null==(e=n.backingData)?void 0:e.filtered)?void 0:t.instanceTypes)?a:[],s=Array.from(this.state.instanceTypeDetails);return!n.viewState.disableImageSelection&&i.length&&s.forEach((e=>{e.families.forEach((e=>{e.instanceTypes.forEach((e=>{e.unavailable=!i.includes(e.name)}))}))})),r&&n?Vt.createElement(Kl,{formik:this.props.formik,instanceTypeDetails:s}):Vt.createElement("h5",{className:"text-center"},"Please select an image.")}}class Xl extends Vt.Component{constructor(){super(...arguments),this.handleAvailabilityZonesChanged=e=>{const{values:t,setFieldValue:a}=this.props.formik;t.usePreferredZonesChanged(t),a("availabilityZones",e)},this.rebalanceToggled=()=>{const{values:e,setFieldValue:t}=this.props.formik;e.toggleSuspendedProcess(e,"AZRebalance"),t("suspendedProcesses",e.suspendedProcesses),this.setState({})}}validate(e){const t={};return e.availabilityZones&&0!==e.availabilityZones.length||(t.availabilityZones="You must select at least one availability zone."),t}render(){const{values:e}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement(li,{credentials:e.credentials,region:e.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:e.availabilityZones,allZones:e.backingData.filtered.availabilityZones,usePreferredZones:e.viewState.usePreferredZones}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},Vt.createElement("b",null,"AZ Rebalance")),Vt.createElement("div",{className:"col-md-7 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",onChange:this.rebalanceToggled,checked:!e.processIsSuspended(e,"AZRebalance")}),"Keep instances evenly distributed across zones"))))}}const Jl=e=>({value:e,label:e});class Ql extends Vt.Component{constructor(){super(...arguments),this.state={refreshing:!1,refreshed:!1,showVpcLoadBalancers:!1},this.refreshLoadBalancers=()=>{const{values:e}=this.props.formik;this.setState({refreshing:!0});h.providerServiceDelegate.getDelegate(e.cloudProvider||e.selectedProvider,"serverGroup.configurationService").refreshLoadBalancers(e).then((()=>{this.setState({refreshing:!1,refreshed:!0})}))},this.targetGroupsChanged=e=>{const t=e.map((e=>e.value));this.props.formik.setFieldValue("targetGroups",t)},this.loadBalancersChanged=e=>{const t=e.map((e=>e.value));this.props.formik.setFieldValue("loadBalancers",t)},this.vpcLoadBalancersChanged=e=>{const t=e.map((e=>e.value));this.props.formik.setFieldValue("vpcLoadBalancers",t)}}validate(e){const t={};return e.viewState.dirty.targetGroups&&(t.targetGroups="You must confirm the removed target groups."),e.viewState.dirty.loadBalancers&&(t.loadBalancers="You must confirm the removed load balancers."),t}clearWarnings(e){this.props.formik.values.viewState.dirty[e]=null,this.props.formik.validateForm()}render(){var e;const{hideLoadBalancers:t,hideTargetGroups:a}=this.props,{values:r}=this.props.formik,{dirty:i}=r.viewState,{refreshed:s,refreshing:l,showVpcLoadBalancers:o}=this.state;let c=null;if(!a){const t=(r.backingData.filtered.targetGroups||[]).concat(r.viewState.spelTargetGroups||[]).map(Jl);c=Vt.createElement(Vt.Fragment,null,i.targetGroups&&Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following target groups could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,i.targetGroups.map((e=>Vt.createElement("li",{key:e},e)))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("targetGroups")},"Okay")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Target Groups "),Vt.createElement(n,{id:"aws.loadBalancer.targetGroups"})),Vt.createElement("div",{className:"col-md-7"},0===t.length&&Vt.createElement("div",{className:"form-control-static"},"No ",Vt.createElement("b",null,null!=(e=this.props.targetGroupTypeHelpText)?e:"instance")," target groups found in the selected account/region/VPC"),t.length>0&&Vt.createElement(f,{multi:!0,options:t,value:r.targetGroups,onChange:this.targetGroupsChanged}))))}let d=null;if(!t){const e=(r.backingData.filtered.loadBalancers||[]).concat(r.viewState.spelLoadBalancers||[]).map(Jl),t=(r.backingData.filtered.vpcLoadBalancers||[]).map(Jl),a=r.vpcLoadBalancers&&r.vpcLoadBalancers.length>0;d=Vt.createElement(Vt.Fragment,null,i.loadBalancers&&Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following load balancers could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,i.loadBalancers.map((e=>Vt.createElement("li",{key:e},e)))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("loadBalancers")},"Okay")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Classic Load Balancers "),Vt.createElement(n,{id:"aws.loadBalancer.loadBalancers"})),Vt.createElement("div",{className:"col-md-7"},0===e.length&&Vt.createElement("div",{className:"form-control-static"},"No load balancers found in the selected account/region/VPC"),e.length>0&&Vt.createElement(f,{multi:!0,options:e,value:r.loadBalancers,onChange:this.loadBalancersChanged}))),!r.vpcId&&Vt.createElement("div",{className:"form-group"},!a&&!o&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-8 col-md-offset-3"},Vt.createElement("a",{className:"clickable",onClick:()=>this.setState({showVpcLoadBalancers:!0})},"Add VPC Load Balancers"))),a&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"VPC Load Balancers")),Vt.createElement("div",{className:"col-md-8"},t.length>0&&Vt.createElement(f,{multi:!0,options:t,value:r.vpcLoadBalancers,onChange:this.vpcLoadBalancersChanged})))),!s&&Vt.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Vt.createElement("div",{className:"col-md-8 col-md-offset-4"},l&&Vt.createElement("p",null,Vt.createElement("span",{className:"fa fa-sync-alt fa-spin"}),Vt.createElement("span",null," refreshing...")),!l&&Vt.createElement("p",null,"If you are looking for a load balancer or target group from a different application, ",Vt.createElement("br",null),Vt.createElement("a",{className:"clickable",onClick:this.refreshLoadBalancers},"click here")," ","to load all load balancers."))))}return Vt.createElement("div",{className:"container-fluid form-horizontal"},c,d)}}class eo extends Vt.Component{constructor(e){super(e),this.refreshSecurityGroups=()=>{this.setState({refreshing:!0}),this.props.refresh?this.props.refresh().then((()=>this.setState({refreshing:!1}))):h.providerServiceDelegate.getDelegate(this.props.command.selectedProvider,"serverGroup.configurationService").refreshSecurityGroups(this.props.command).then((()=>{this.setState({refreshing:!1,refreshTime:Ne.get("securityGroups").getStats().ageMax})}))},this.onChange=e=>{const t=e.map((e=>e.value));this.props.onChange(t)},this.state={refreshing:!1,refreshTime:Ne.get("securityGroups").getStats().ageMax}}render(){const{availableGroups:e,groupsToEdit:t,helpKey:a,hideLabel:r}=this.props,{refreshing:i,refreshTime:s}=this.state,l=e.map((e=>({label:`${e.name} (${e.id})`,value:e.id})));return Vt.createElement(Vt.Fragment,null,Vt.createElement("div",{className:"form-group"},!r&&Vt.createElement("div",{className:"col-md-3 sm-label-right"},Vt.createElement("b",null,U.get("Firewalls")),a&&Vt.createElement(n,{key:a})),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(pn,{ignoreAccents:!0,options:l,onChange:this.onChange,value:t,multi:!0}))),Vt.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Vt.createElement("div",{className:`col-md-${r?12:9} col-md-offset-${r?0:3}`},Vt.createElement("p",null,i&&Vt.createElement("span",null,Vt.createElement("span",{className:"fa fa-sync-alt fa-spin"})),U.get("Firewalls"),!i&&Vt.createElement("span",null," last refreshed ",z(s)),i&&Vt.createElement("span",null," refreshing...")),Vt.createElement("p",null,"If you're not finding a ",U.get("firewall")," that was recently added,"," ",Vt.createElement("a",{className:"clickable",onClick:this.refreshSecurityGroups},"click here")," ","to refresh the list."))))}}class to extends Vt.Component{render(){const{command:e,onClear:t,removed:a}=this.props,n=(e&&e.viewState.dirty.securityGroups||[]).concat(a||[]);return 0===n.length?null:Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following ",U.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,n.map((e=>Vt.createElement("li",{key:e},e)))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:t},"Okay"))))}}to.defaultProps={onClear:C};class ao extends Vt.Component{constructor(){super(...arguments),this.onChange=e=>{this.props.formik.setFieldValue("securityGroups",e)},this.acknowledgeRemovedGroups=()=>{const{viewState:e}=this.props.formik.values;e.dirty.securityGroups=null,this.props.formik.setFieldValue("viewState",e)}}validate(e){const t={};return e.viewState.dirty.securityGroups&&(t.securityGroups="You must acknowledge removed security groups."),t}render(){const{values:e}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement(to,{command:e,onClear:this.acknowledgeRemovedGroups}),Vt.createElement(eo,{command:e,availableGroups:e.backingData.filtered.securityGroups,groupsToEdit:e.securityGroups,onChange:this.onChange}))}}class no extends Vt.Component{constructor(){super(...arguments),this.duplicateKeys=!1,this.validate=e=>{const t={};return e.keyPair||(t.keyPair="Key Name is required"),this.duplicateKeys&&(t.tags="Tags have duplicate keys."),t},this.selectBlockDeviceMappingsSource=e=>{const{values:t}=this.props.formik;t.selectBlockDeviceMappingsSource(t,e),this.setState({})},this.toggleSuspendedProcess=e=>{const{values:t,setFieldValue:a}=this.props.formik;t.toggleSuspendedProcess(t,e),a("suspendedProcesses",t.suspendedProcesses),this.setState({})},this.platformHealthOverrideChanged=e=>{this.props.formik.setFieldValue("interestingHealthProviderNames",e)},this.tagsChanged=(e,t)=>{this.duplicateKeys=t,this.props.formik.setFieldValue("tags",e)}}render(){const{app:e}=this.props,{setFieldValue:t,values:a}=this.props.formik,r=a.getBlockDeviceMappingsSource(a),i=a.backingData.filtered.keyPairs||[],s=kn.serverGroups;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Cooldown")),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(un,{type:"text",required:!0,name:"cooldown",className:"form-control input-sm no-spel"}))," ","seconds"),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Enabled Metrics "),Vt.createElement(n,{id:"aws.serverGroup.enabledMetrics"})),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{multi:!0,value:a.enabledMetrics,options:a.backingData.enabledMetrics.map((e=>({label:e,value:e}))),onChange:e=>t("enabledMetrics",e.map((e=>e.value)))}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Health Check Type")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{value:a.healthCheckType,clearable:!1,placeholder:"Select...",options:a.backingData.healthCheckTypes.map((e=>({label:e,value:e}))),onChange:e=>t("healthCheckType",e.value)}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Health Check Grace Period")),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(un,{type:"text",required:!0,className:"form-control input-sm no-spel",name:"healthCheckGracePeriod"}))," ","seconds"),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Termination Policies")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{multi:!0,value:a.terminationPolicies,options:a.backingData.terminationPolicies.map((e=>({label:e,value:e}))),onChange:e=>t("terminationPolicies",e.map((e=>e.value)))}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Key Name")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{value:a.keyPair,required:!0,clearable:!1,options:i.map((e=>({label:e,value:e}))),onChange:e=>t("keyPair",e.value)}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Ramdisk Id (optional)")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(un,{type:"text",name:"ramdiskId",className:"form-control input-sm no-spel"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"IAM Instance Profile (optional)")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(un,{type:"text",className:"form-control input-sm no-spel",name:"iamRole"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"UserData (optional) "),Vt.createElement(n,{id:"aws.serverGroup.base64UserData"})),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(un,{type:"text",className:"form-control input-sm no-spel",name:"base64UserData"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Instance Monitoring "),Vt.createElement(n,{id:"aws.serverGroup.instanceMonitoring"})),Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:a.instanceMonitoring,onChange:e=>t("instanceMonitoring",e.target.checked)})," ","Enforce Instance Monitoring"," "))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"EBS Optimized")),Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:a.ebsOptimized,onChange:e=>t("ebsOptimized",e.target.checked)})," ","Optimize Instances for EBS"))),(null==s?void 0:s.enableIMDSv2)&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"IMDSv2 "),Vt.createElement(n,{id:"aws.serverGroup.imdsv2"})),Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:!0===a.requireIMDSv2,onChange:e=>t("requireIMDSv2",e.target.checked)})," ","Require IMDSv2"," "))),!kn.disableSpotPricing&&a.viewState.useSimpleInstanceTypeSelector&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Spot Instances Price (optional)")," ",Vt.createElement(n,{id:"aws.serverGroup.spotMaxPrice"})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(un,{type:"text",className:"form-control input-sm",name:"spotPrice"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"AMI Block Device Mappings")),Vt.createElement("div",{className:"col-md-6 radio"},Vt.createElement("div",null,Vt.createElement("label",null,Vt.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("source"),checked:"source"===r,name:"blockDeviceMappingsSource"}),"Copy from current server group ",Vt.createElement(n,{id:"aws.blockDeviceMappings.useSource"}))),Vt.createElement("div",null,Vt.createElement("label",null,Vt.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("ami"),checked:"ami"===r,name:"blockDeviceMappingsSource"}),"Prefer AMI block device mappings ",Vt.createElement(n,{id:"aws.blockDeviceMappings.useAMI"}))),Vt.createElement("div",null,Vt.createElement("label",null,Vt.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("default"),checked:"default"===r,name:"blockDeviceMappingsSource"}),"Defaults for selected instance type ",Vt.createElement(n,{id:"aws.blockDeviceMappings.useDefaults"}))))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,`Associate ${(null==s?void 0:s.enableIPv6)?"IPv6 (Recommended)":"Public IPv4"} Address`),Vt.createElement(n,{id:"serverGroup.ipv6"})),(null==s?void 0:s.enableIPv6)&&Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:!0===a.associateIPv6Address,onChange:e=>t("associateIPv6Address",e.target.checked),id:"associateIPv6AddressToggle"})," ","Assign an IPv6 address to instances"," ")),!(null==s?void 0:s.enableIPv6)&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-2 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:!0===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!0),id:"associatePublicIpAddressTrue"}),"Yes")),Vt.createElement("div",{className:"col-md-2 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:!1===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!1),id:"associatePublicIpAddressFalse"}),"No")),Vt.createElement("div",{className:"col-md-2 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:null===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",null),id:"associatePublicIpAddressDefault"}),"Default")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Scaling Processes")),Vt.createElement("div",{className:"col-md-6 checkbox"},a.backingData.scalingProcesses.map((e=>Vt.createElement("div",{key:e.name},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",onChange:()=>this.toggleSuspendedProcess(e.name),checked:!a.suspendedProcesses.includes(e.name)})," ",e.name," ",Vt.createElement(n,{content:e.description}))))))),e.attributes.platformHealthOnlyShowOverride&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Task Completion")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(bt,{interestingHealthProviderNames:a.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"sm-label-left"},Vt.createElement("b",null,"Tags (optional)"),Vt.createElement(n,{id:"aws.serverGroup.tags"})),Vt.createElement(Et,{model:a.tags,allowEmpty:!0,onChange:this.tagsChanged})))}}var ro=Object.defineProperty,io=Object.getOwnPropertyDescriptor;let so=class extends Vt.Component{constructor(){super(...arguments),this.validators=new Map,this.validate=e=>{const t={};return this.validators.forEach((a=>{const n=a(e);Object.assign(t,{...n})})),t},this.handleRef=e=>{e?this.validators.set("common",e.validate):this.validators.delete("common")}}render(){const{formik:e,app:t}=this.props;return Vt.createElement(no,{formik:e,app:t,ref:this.handleRef})}};so=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?io(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&ro(t,a,i),i})([ie("aws.serverGroup.advancedSettings")],so);class lo extends Vt.Component{constructor(){super(...arguments),this.ref=Vt.createRef()}validate(e){return this.ref&&this.ref.current?this.ref.current.validate(e):{}}render(){const{app:e,formik:t}=this.props;return Vt.createElement(so,{formik:t,app:e,ref:this.ref})}}const oo=class extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.templateSelected=()=>{this.setState({requiresTemplateSelection:!1}),this.configureCommand()},this.onTaskComplete=()=>{this.props.application.serverGroups.refresh(),this.props.application.serverGroups.onNextRefresh(null,this.onApplicationRefresh)},this.onApplicationRefresh=()=>{if(this._isUnmounted)return;const{command:e}=this.props,{taskMonitor:t}=this.state,a=t.task.execution.stages.find((e=>"cloneServerGroup"===e.type));if(a&&a.context["deploy.server.groups"]){const t=a.context["deploy.server.groups"][e.region];if(t){const a={serverGroup:t,accountId:e.credentials,region:e.region,provider:"aws"};let n="^.^.^.clusters.serverGroup";h.$state.includes("**.clusters.serverGroup")&&(n="^.serverGroup"),h.$state.includes("**.clusters.cluster.serverGroup")&&(n="^.^.serverGroup"),h.$state.includes("**.clusters")&&(n=".serverGroup"),h.$state.go(n,a)}}},this.initializeCommand=()=>{const{command:e}=this.props;e.credentialsChanged(e),e.regionChanged(e),Xn.awsServerGroupConfigurationService.configureSubnetPurposes(e)},this.configureCommand=()=>{const{application:e,command:t}=this.props;Xn.awsServerGroupConfigurationService.configureCommand(e,t).then((()=>{this.initializeCommand(),this.setState({loaded:!0,requiresTemplateSelection:!1})}))},this.normalizeCommand=({tags:e})=>{e&&Object.keys(e).forEach((t=>{t.length||e[t].length||delete e[t]}))},this.submit=e=>{this.normalizeCommand(e);"editPipeline"===e.viewState.mode||"createPipeline"===e.viewState.mode?this.props.closeModal&&this.props.closeModal(e):this.state.taskMonitor.submit((()=>h.serverGroupWriter.cloneServerGroup(e,this.props.application)))};const t=ia(e,"command.viewState.requiresTemplateSelection",!1);t||this.configureCommand(),this.state={firewallsLabel:U.get("Firewalls"),loaded:!1,requiresTemplateSelection:t,taskMonitor:new v({application:e.application,title:"Creating your server group",modalInstance:v.modalInstanceEmulation((()=>this.props.dismissModal())),onTaskComplete:this.onTaskComplete})}}static show(e){return b.show(oo,e,{dialogClassName:"wizard-modal modal-lg"})}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}render(){const{application:e,command:t,dismissModal:a,title:n}=this.props,{loaded:r,taskMonitor:i,requiresTemplateSelection:s}=this.state;return s?Vt.createElement(Sl,{app:e,command:t,onDismiss:a,onTemplateSelected:this.templateSelected}):Vt.createElement(E,{heading:n,initialValues:t,loading:!r,taskMonitor:i,dismissModal:a,closeModal:this.submit,submitButtonLabel:t.viewState.submitButtonLabel,render:({formik:a,nextIdx:n,wizard:r})=>Vt.createElement(Vt.Fragment,null,Vt.createElement(w,{label:"Basic Settings",wizard:r,order:n(),render:({innerRef:t})=>Vt.createElement(Tl,{ref:t,formik:a,app:e})}),Vt.createElement(w,{label:"Load Balancers",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Ql,{ref:e,formik:a})}),Vt.createElement(w,{label:U.get("Firewalls"),wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(ao,{ref:e,formik:a})}),Vt.createElement(w,{label:t.viewState.useSimpleInstanceTypeSelector?"Instance Type":"Instance Types",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Yl,{ref:e,formik:a})}),Vt.createElement(w,{label:"Capacity",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Al,{ref:e,formik:a})}),Vt.createElement(w,{label:"Availability Zones",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Xl,{ref:e,formik:a})}),Vt.createElement(w,{label:"Advanced Settings",wizard:r,order:n(),render:({innerRef:t})=>Vt.createElement(lo,{ref:t,formik:a,app:e})}))})}};let co=oo;co.defaultProps={closeModal:C,dismissModal:C};class uo extends Vt.Component{constructor(){super(...arguments),this.state={verified:!1,requireVerification:!1},this.handleVerification=e=>{this.setState({verified:e})}}componentDidMount(){o.accounts$.pipe(Ua(1),Da((e=>e.find((e=>e.name===this.props.account))))).subscribe((e=>{this.setState({requireVerification:!!e&&e.challengeDestructiveActions})}))}render(){const{account:e,onCancel:t,onSubmit:a,isValid:n}=this.props,{verified:r,requireVerification:i}=this.state;return Vt.createElement(Ka,null,Vt.createElement("form",{onSubmit:()=>(this.props.onSubmit(),!1)},i&&Vt.createElement(wt,{expectedValue:e,onValidChange:this.handleVerification})),Vt.createElement("button",{className:"btn btn-default",onClick:t},"Cancel"),Vt.createElement("button",{type:"submit",className:"btn btn-primary",onClick:a,disabled:!n||i&&!r},"Submit"))}}uo.defaultProps={isValid:!0};const po=class extends Vt.Component{constructor(e){super(e),this.formikRef=Vt.createRef(),this.validate=e=>{const{min:t,max:a,desired:n}=e,r={};return this.state.advancedMode?(t>a&&t>n?r.min="Min cannot be larger than Max/Desired":a<t&&a<n?r.max="Max cannot be smaller than Min/Desired":(t>a&&(r.min="Min cannot be larger than Max"),this.isDesiredControlledByAutoscaling()||(n<t&&(r.desired="Desired cannot be smaller than Min"),n>a&&(r.desired="Desired cannot be larger than Max"))),r):r},this.toggleAdvancedMode=()=>{const{desired:e}=this.formikRef.current.getFormikContext().values;this.formikRef.current.setFieldValue("min",e),this.formikRef.current.setFieldValue("max",e),this.setState({advancedMode:!this.state.advancedMode})},this.close=e=>{this.props.dismissModal.apply(null,e)},this.platformHealthOverrideChanged=e=>{this.setState({interestingHealthProviderNames:e})},this.isDesiredControlledByAutoscaling=()=>{const{serverGroup:e}=this.props,{suspendedProcesses:t}=e.asg,{advancedMode:a}=this.state;return(e.scalingPolicies||[]).length&&a&&t.every((e=>"AlarmNotification"!==e.processName))},this.submit=e=>{const{min:t,max:a,desired:n,enforceCapacityConstraints:r,reason:i}=e,{interestingHealthProviderNames:s}=this.state,{serverGroup:l,application:o}=this.props,{asg:c}=l,d={capacity:na({min:t!==c.minSize?t:void 0,max:a!==c.maxSize?a:void 0,desired:n!==c.desiredCapacity?n:void 0},(e=>void 0!==e)),reason:i,interestingHealthProviderNames:s};r&&(d.constraints={capacity:{min:c.minSize,max:c.maxSize,desired:c.desiredCapacity}}),this.state.taskMonitor.submit((()=>h.serverGroupWriter.resizeServerGroup(l,o,d)))};const{minSize:t,maxSize:a,desiredCapacity:n}=e.serverGroup.asg,{attributes:r}=e.application;this.state={advancedMode:t!==a,initialValues:{min:t,max:a,desired:n,enforceCapacityConstraints:!1},taskMonitor:new v({application:e.application,title:"Resizing your server group",modalInstance:v.modalInstanceEmulation((()=>this.props.dismissModal())),onTaskComplete:()=>this.props.application.serverGroups.refresh()}),platformHealthOnlyShowOverride:r.platformHealthOnlyShowOverride,interestingHealthProviderNames:r.platformHealthOnlyShowOverride&&r.platformHealthOnly?["Amazon"]:null}}static show(e){const t={},{serverGroup:a,application:n}=e;return lt(a,n).then((a=>{a&&b.show(po,e,t)}))}autoIncrementDesiredIfNeeded(){if(!this.isDesiredControlledByAutoscaling())return;const e=this.formikRef.current.getFormikContext(),{asg:t}=this.props.serverGroup,{min:a,max:n,desired:r}=e.values,i=Math.min(n,Math.max(a,t.desiredCapacity));r!==i&&e.setFieldValue("desired",i)}renderSimpleMode(e){const{serverGroup:t}=this.props,{asg:a}=t;return Vt.createElement("div",null,Vt.createElement("p",null,"Sets min, max, and desired instance counts to the same value."),Vt.createElement("p",null,"To allow autoscaling, use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Current size"),Vt.createElement("div",{className:"col-md-4"},Vt.createElement("div",{className:"horizontal middle"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:a.desiredCapacity,disabled:!0}),Vt.createElement("div",{className:"sp-padding-xs-xaxis"},"instances")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Vt.createElement("div",{className:"col-md-4"},Vt.createElement("div",{className:"horizontal middle"},Vt.createElement(s,{name:"desired",input:e=>Vt.createElement(p,{...e,min:0}),touched:!0,onChange:t=>{e.setFieldValue("min",t),e.setFieldValue("max",t)}}),Vt.createElement("div",{className:"sp-padding-xs-xaxis"},"instances")))))}renderAdvancedMode(e){const{serverGroup:t}=this.props,{errors:a}=e,{asg:n}=t,r=a.min||a.max||a.desired;return Vt.createElement("div",null,Vt.createElement("p",null,"Sets up autoscaling for this server group."),Vt.createElement("p",null,"To disable autoscaling, use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Simple Mode"),"."),Vt.createElement("div",{className:"form-group bold"},Vt.createElement("div",{className:"col-md-2 col-md-offset-3"},"Min"),Vt.createElement("div",{className:"col-md-2"},"Max"),Vt.createElement("div",{className:"col-md-2"},"Desired")),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Current"),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:n.minSize,disabled:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:n.maxSize,disabled:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:n.desiredCapacity,disabled:!0}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(s,{name:"min",input:e=>Vt.createElement(p,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Vt.createElement(Vt.Fragment,null,e),touched:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(s,{name:"max",input:e=>Vt.createElement(p,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Vt.createElement(Vt.Fragment,null,e),touched:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(s,{name:"desired",input:e=>Vt.createElement(p,{...e,min:0,disabled:this.isDesiredControlledByAutoscaling()}),layout:({input:e})=>Vt.createElement(Vt.Fragment,null,e),touched:!0}))),!!r&&Vt.createElement("div",{className:"col-md-offset-3 col-md-9"},Vt.createElement(pe,{message:r,type:"error"})))}renderCapacityConstraintSelector(){return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement(s,{name:"enforceCapacityConstraints",input:e=>Vt.createElement(Vt.Fragment,null,Vt.createElement(d,{...e,text:"Enforce Capacity Constraints"}),Vt.createElement(n,{id:"aws.serverGroup.capacityConstraint"}))})))}renderScalingPolicyWarning(e){const{serverGroup:t}=this.props,{min:a,max:n}=e.values,{advancedMode:r}=this.state,i=t.scalingPolicies||[];return i.length&&a===n?Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement("div",{className:"well-compact alert alert-warning"},Vt.createElement("b",null,"Warning"),": this server group has",1===i.length&&Vt.createElement("span",null," a scaling policy. "),i.length>1&&Vt.createElement("span",null," scaling policies. "),!r&&Vt.createElement("span",null,"Scaling policies will not take effect in Simple Mode. Switch to"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),r&&Vt.createElement("span",null,"Scaling policies will not take effect when ",Vt.createElement("b",null,"Min")," is the same as ",Vt.createElement("b",null,"Max"),".")))):this.isDesiredControlledByAutoscaling()?Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-8 col-md-offset-1"},Vt.createElement("div",{className:"well-compact alert alert-warning"},Vt.createElement("p",null,Vt.createElement("b",null,"Desired")," capacity is managed by Autoscaling Policies."),Vt.createElement("p",null,"If you need to scale ",Vt.createElement("b",null,"down")," this server group, set ",Vt.createElement("b",null,"Max")," to the new desired size."),Vt.createElement("p",null,"If you need to scale ",Vt.createElement("b",null,"up")," this server group, set ",Vt.createElement("b",null,"Min")," to the new desired size.")))):null}render(){const{serverGroup:e}=this.props,{advancedMode:t,initialValues:a,platformHealthOnlyShowOverride:n}=this.state;return Vt.createElement(Vt.Fragment,null,Vt.createElement(Ct,{monitor:this.state.taskMonitor}),Vt.createElement(le,{ref:this.formikRef,initialValues:a,validate:this.validate,onSubmit:this.submit,render:a=>{const{asg:r}=e,i={min:r.minSize,max:r.maxSize,desired:r.desiredCapacity},s=a.values;return Vt.createElement(Vt.Fragment,null,Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Resize ",e.name)),Vt.createElement(Ha.Body,null,Vt.createElement(dn,{className:"form-horizontal"},t&&this.renderAdvancedMode(a),!t&&this.renderSimpleMode(a),this.renderScalingPolicyWarning(a),this.renderCapacityConstraintSelector(),n&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-8 col-md-offset-3"},Vt.createElement(bt,{interestingHealthProviderNames:this.state.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged,showHelpDetails:!0}))),Vt.createElement(mt,{reason:a.values.reason,onChange:e=>a.setFieldValue("reason",e)}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Changes"),Vt.createElement("div",{className:"col-md-9 sm-control-field"},Vt.createElement(St,{current:i,next:s}))))),Vt.createElement(uo,{onSubmit:()=>this.submit(a.values),onCancel:this.close,isValid:a.isValid,account:e.account}))}}))}};let mo=po;mo.defaultProps={closeModal:C,dismissModal:C};var go=Object.defineProperty,ho=Object.getOwnPropertyDescriptor;let fo=class extends Vt.Component{constructor(){super(...arguments),this.resizeServerGroup=()=>{mo.show(this.props)}}render(){return Vt.createElement(Ya,{onClick:this.resizeServerGroup},"Resize")}};fo=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?ho(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&go(t,a,i),i})([ie("AmazonServerGroupActions.resize")],fo);class vo extends Vt.Component{constructor(){super(...arguments),this.destroyServerGroup=()=>{const{app:e,serverGroup:t}=this.props,a={application:e,title:"Destroying "+t.name,onTaskComplete:()=>{h.$state.includes("**.serverGroup",n)&&h.$state.go("^")}},n={name:t.name,accountId:t.account,region:t.region},r={header:"Really destroy "+t.name+"?",buttonText:"Destroy "+t.name,account:t.account,taskMonitorConfig:a,interestingHealthProviderNames:void 0,submitMethod:a=>h.serverGroupWriter.destroyServerGroup(t,e,a),askForReason:!0,platformHealthOnlyShowOverride:e.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon"};kt.addDestroyWarningMessage(e,t,r),e.attributes.platformHealthOnlyShowOverride&&e.attributes.platformHealthOnly&&(r.interestingHealthProviderNames=["Amazon"]),S.confirm(r)},this.disableServerGroup=()=>{const{app:e,serverGroup:t}=this.props,a={application:e,title:"Disabling "+t.name},n={header:"Really disable "+t.name+"?",buttonText:"Disable "+t.name,account:t.account,interestingHealthProviderNames:void 0,taskMonitorConfig:a,platformHealthOnlyShowOverride:e.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon",submitMethod:a=>h.serverGroupWriter.disableServerGroup(t,e.name,a),askForReason:!0};kt.addDisableWarningMessage(e,t,n),e.attributes.platformHealthOnlyShowOverride&&e.attributes.platformHealthOnly&&(n.interestingHealthProviderNames=["Amazon"]),S.confirm(n)},this.enableServerGroup=()=>{if(!this.isRollbackEnabled())return void this.showEnableServerGroupModal();const e={header:"Rolling back?",body:"Spinnaker provides an orchestrated rollback feature to carefully restore a different version of this\n server group. Do you want to use the orchestrated rollback?",buttonText:"Yes, take me to the rollback settings modal",cancelButtonText:"No, I just want to enable the server group"};S.confirm(e).then((()=>new Promise((e=>setTimeout(e,500))))).then((()=>this.rollbackServerGroup())).catch((e=>{"footer"===(null==e?void 0:e.source)&&this.showEnableServerGroupModal()}))},this.rollbackServerGroup=()=>{const{app:e}=this.props;let t,a=this.props.serverGroup,n=e.getDataSource("serverGroups").data.filter((e=>e.cluster===a.cluster&&e.region===a.region&&e.account===a.account));a.isDisabled&&(t=a,a=Xt(n.filter((e=>e.name!==t.name&&!e.isDisabled)),["instanceCounts.total","createdTime"],["desc","desc"])[0]),n=n.filter((e=>e.name!==a.name)),1!==n.length||t||(t=n[0]),Nt.modalService.open({templateUrl:h.overrideRegistry.getTemplate("aws.rollback.modal","amazon/src/serverGroup/details/rollback/rollbackServerGroup.html"),controller:"awsRollbackServerGroupCtrl as ctrl",resolve:{serverGroup:()=>a,previousServerGroup:()=>t,disabledServerGroups:()=>{const t=ba(e.clusters,{name:a.cluster,account:a.account,serverGroups:[]});return ea(t.serverGroups,{isDisabled:!0,region:a.region})},allServerGroups:()=>n,application:()=>e}})},this.cloneServerGroup=()=>{const{app:e,serverGroup:t}=this.props;Xn.awsServerGroupCommandBuilder.buildServerGroupCommandFromExisting(e,t).then((a=>{const n=`Clone ${t.name}`;co.show({title:n,application:e,command:a})}))}}isEnableLocked(){if(this.props.serverGroup.isDisabled){if((this.props.serverGroup.runningTasks||[]).filter((e=>ia(e,"execution.stages",[]).some((e=>"resizeServerGroup"===e.type)))).length)return!0}return!1}isRollbackEnabled(){const{app:e,serverGroup:t}=this.props;return!t.isDisabled||e.getDataSource("serverGroups").data.some((e=>e.cluster===t.cluster&&e.region===t.region&&e.account===t.account&&!e.isDisabled))}hasDisabledInstances(){return this.props.serverGroup.isDisabled||ia(this.props.serverGroup,"instanceCounts.outOfService",0)>0}showEnableServerGroupModal(){const{app:e,serverGroup:t}=this.props,a={application:e,title:"Enabling "+t.name},n={header:"Really enable "+t.name+"?",buttonText:"Enable "+t.name,account:t.account,interestingHealthProviderNames:void 0,taskMonitorConfig:a,platformHealthOnlyShowOverride:e.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon",submitMethod:a=>h.serverGroupWriter.enableServerGroup(t,e,a),askForReason:!0};e.attributes.platformHealthOnlyShowOverride&&e.attributes.platformHealthOnly&&(n.interestingHealthProviderNames=["Amazon"]),S.confirm(n)}render(){const{app:e,serverGroup:t}=this.props,n=a.feature&&a.feature.entityTags,r=Tt.buildClusterTargets(t);return Vt.createElement(Vt.Fragment,null,kn.adHocInfraWritesEnabled&&Vt.createElement(qa,{className:"dropdown",id:"server-group-actions-dropdown"},Vt.createElement(qa.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},"Server Group Actions"),Vt.createElement(qa.Menu,{className:"dropdown-menu"},this.isRollbackEnabled()&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.rollbackServerGroup},"Rollback"),this.isRollbackEnabled()&&Vt.createElement("li",{role:"presentation",className:"divider"}),Vt.createElement(fo,{application:e,serverGroup:t}),!t.isDisabled&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.disableServerGroup},"Disable"),this.hasDisabledInstances()&&!this.isEnableLocked()&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.enableServerGroup},"Enable"),this.isEnableLocked()&&Vt.createElement("li",{className:"disabled"},Vt.createElement(ja,{value:"Cannot enable this server group until resize operation completes",placement:"left"},Vt.createElement("a",null,Vt.createElement("span",{className:"small glyphicon glyphicon-lock"})," Enable"))),Vt.createElement(Ie,{resource:t,application:e,onClick:this.destroyServerGroup},"Destroy"),Vt.createElement("li",null,Vt.createElement("a",{className:"clickable",onClick:this.cloneServerGroup},"Clone")),n&&Vt.createElement(N,{component:t,application:e,entityType:"serverGroup",ownerOptions:r,onUpdate:()=>e.serverGroups.refresh()}))))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/rollback/rollbackServerGroup.html",'<div modal-page class="confirmation-modal">\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Rollback {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body confirmation-modal">\n <div class="row">\n <div class="col-sm-3 sm-label-right">Restore to</div>\n <div class="col-md-7">\n <ui-select\n ng-model="command.rollbackContext.restoreServerGroupName"\n class="form-control input-sm"\n ng-if="command.rollbackType === \'EXPLICIT\'"\n >\n <ui-select-match placeholder="Select...">{{ctrl.label($select.selected)}}</ui-select-match>\n <ui-select-choices group-by="ctrl.group" repeat="serverGroup.name as serverGroup in allServerGroups">\n <span ng-bind-html="ctrl.label(serverGroup)"></span>\n </ui-select-choices>\n </ui-select>\n <div ng-if="command.rollbackType === \'PREVIOUS_IMAGE\'" style="margin-top: 5px">\n {{ previousServerGroup.name }} <span class="small">(no longer deployed)</span><br />\n <span class="small">\n <strong>Image</strong>: {{ previousServerGroup.imageName}}\n <span ng-if="previousServerGroup.imageId">({{ previousServerGroup.imageId }})</span><br />\n </span>\n <span class="small" ng-if="previousServerGroup.buildNumber">\n <strong>Build</strong> #{{ previousServerGroup.buildNumber }}\n </span>\n </div>\n </div>\n </div>\n\n <div class="row" ng-if="command.platformHealthOnlyShowOverride">\n <div class="col-sm-10 col-sm-offset-1">\n <platform-health-override\n command="command"\n platform-health-type="\'Amazon\'"\n show-help-details="true"\n field-columns="12"\n >\n </platform-health-override>\n </div>\n </div>\n\n <task-reason command="command"></task-reason>\n\n <div class="row">\n <div class="col-sm-11 col-sm-offset-1">\n Wait\n <input\n placeholder="0"\n min="0"\n type="number"\n ng-model="command.rollbackContext.delayBeforeDisableSeconds"\n class="form-control input-sm inline-number"\n />\n seconds before disabling <em>{{ ctrl.label(serverGroup) }}</em>.\n </div>\n </div>\n\n <div class="row">\n <div class="col-sm-11 col-sm-offset-1">\n Consider rollback successful when\n <input\n type="number"\n min="0"\n max="100"\n ng-model="command.rollbackContext.targetHealthyRollbackPercentage"\n class="form-control input-sm inline-number"\n />\n percent of instances are healthy.\n </div>\n </div>\n\n <div class="row">\n <div class="col-sm-4 sm-label-right">Rollback Operations</div>\n </div>\n <div class="row" ng-if="command.rollbackType === \'EXPLICIT\'">\n <div class="col-sm-11 col-sm-offset-1">\n <ol>\n <li>Enable <em>{{ command.rollbackContext.restoreServerGroupName || \'previous server group\' }}</em></li>\n <li>\n Resize <em>{{ command.rollbackContext.restoreServerGroupName || \'previous server group\' }}</em> to [\n <strong>min</strong>: {{serverGroup.capacity.desired}}, <strong>max</strong>: {{ serverGroup.capacity.max\n }}, <strong>desired</strong>: {{ serverGroup.capacity.desired }} ] <br />(minimum capacity pinned at\n {{serverGroup.capacity.desired}} to prevent autoscaling down during rollback)\n </li>\n\n <li ng-if="command.rollbackContext.targetHealthyRollbackPercentage < 100">\n Wait for at least {{minHealthy(command.rollbackContext.targetHealthyRollbackPercentage)}} instances to\n report as healthy\n </li>\n <li ng-if="command.rollbackContext.delayBeforeDisableSeconds > 0">\n Wait {{ command.rollbackContext.delayBeforeDisableSeconds }} seconds\n </li>\n <li>Disable <em>{{ serverGroup.name }}</em></li>\n <li>\n Restore minimum capacity of\n <em>{{ command.rollbackContext.restoreServerGroupName || \'previous server group\' }}</em> [\n <strong>min</strong>: {{ serverGroup.capacity.min }} ]\n </li>\n </ol>\n <p>This rollback will affect server groups in {{ serverGroup.account }} ({{ serverGroup.region }}).</p>\n </div>\n </div>\n <div class="row" ng-if="command.rollbackType === \'PREVIOUS_IMAGE\'">\n <div class="col-sm-11 col-sm-offset-1">\n <ol>\n <li>\n Deploy <em>{{ previousServerGroup.imageId }}</em> [ <strong>min</strong>:\n {{serverGroup.capacity.desired}}, <strong>max</strong>: {{ serverGroup.capacity.max }},\n <strong>desired</strong>: {{ serverGroup.capacity.desired }} ] <br />(minimum capacity pinned at\n {{serverGroup.capacity.desired}} to prevent autoscaling down during deploy)\n </li>\n <li ng-if="command.rollbackContext.targetHealthyRollbackPercentage < 100">\n Wait for at least {{minHealthy(command.rollbackContext.targetHealthyRollbackPercentage)}} instances to\n report as healthy\n </li>\n <li>Disable {{ serverGroup.name }}</li>\n <li>\n Restore minimum capacity of <em>new server group</em> [ <strong>min</strong>: {{ serverGroup.capacity.min\n }} ]\n </li>\n </ol>\n <p>This rollback will affect server groups in {{ serverGroup.account }} ({{ serverGroup.region }}).</p>\n </div>\n </div>\n </div>\n <aws-footer\n action="ctrl.rollback()"\n cancel="ctrl.cancel()"\n is-valid="ctrl.isValid()"\n account="serverGroup.account"\n verification="verification"\n ></aws-footer>\n </form>\n</div>\n')}]);class yo{static getDisabledDate(e){if(e.isDisabled){const t=this.normalizeScalingProcesses(e).find((e=>"AddToLoadBalancer"===e.name&&!e.enabled));if(t)return t.suspensionDate}return null}static normalizeScalingProcesses(e){if(!e.asg||!e.asg.suspendedProcesses)return[];const t=e.asg.suspendedProcesses;return this.listProcesses().map((e=>{const a=t.find((t=>t.processName===e.name)),n={name:e.name,enabled:!a,description:e.description};if(a){const e=a.suspensionReason.replace("User suspended at ","");n.suspensionDate=new Date(e).getTime()}return n}))}static listProcesses(){return[{name:"Launch",description:"Controls if new instances should be launched into the ASG. If this is disabled, scale-up events will not produce new instances."},{name:"Terminate",description:"Controls if instances should be terminated during a scale-down event."},{name:"AddToLoadBalancer",description:"Controls if new instances should be added to the ASG’s ELB."},{name:"AlarmNotification",description:"This disables autoscaling."},{name:"AZRebalance",description:"Controls whether AWS should attempt to maintain an even distribution of instances across all healthy Availability Zones configured for the ASG."},{name:"HealthCheck",description:"If disabled, the instance’s health will no longer be reported to the autoscaling processor."},{name:"ReplaceUnhealthy",description:"Controls whether instances should be replaced if they failed the health check."},{name:"ScheduledActions",description:"Controls whether scheduled actions should be executed."}]}}function bo(e,t){const{app:a,serverGroup:n}=e;return new Pa((r=>{(function(e){const{app:t,serverGroup:a}=e;return t.ready().then((()=>{let e=t.serverGroups.data.find((e=>e.name===a.name&&e.account===a.accountId&&e.region===a.region));return e||t.loadBalancers.data.some((t=>t.account===a.accountId&&t.region===a.region&&t.serverGroups.some((t=>t.name===a.name&&(e=t,!0))))),e}))})(e).then((e=>{It.getServerGroup(a.name,n.accountId,n.region,n.name).then((a=>{Object.assign(a,e,{account:n.accountId});const i=Xn.awsServerGroupTransformer.normalizeServerGroupDetails(a);if(o.getAccountDetails(i.account).then((e=>{i.accountDetails=e,r.next(i)})),Wt(i))t();else{const e=i.asg?i.asg.vpczoneIdentifier:"";if(""!==e){const t=e.split(",")[0];g.listSubnets().then((e=>{const a=e.find((e=>e.id===t));i.subnetType=a.purpose,r.next(i)}))}i.disabledDate=yo.getDisabledDate(i),r.next(i)}}),t)}),t)}))}function Eo(e){const t=Ot.useRef(),a=Ot.useRef(),{lines:n,className:r="",style:i={}}=e;return Ot.useEffect((()=>t?(a.current=function(e){const t={type:"line",data:{labels:[],datasets:[{data:[]}]},options:{plugins:{tooltip:{mode:"index",itemSort:(e,t)=>{var a,n;const r=e.chart.data.datasets.map((e=>e.label)),i=null!=(a=e.dataset.label)?a:r[0],s=null!=(n=t.dataset.label)?n:r[0];return r.indexOf(s)-r.indexOf(i)}}},hover:{mode:"index"},elements:{point:{hitRadius:12,radius:1,hoverRadius:5}},scales:{x:{type:"time",display:!0,scaleLabel:{labelString:"Date"},ticks:{major:{enabled:!0}}},y:{min:0,stacked:!0}}}};return new mn(e,t)}(t.current),()=>{var e;return null==(e=a.current)?void 0:e.destroy()}):null),[t.current]),Ot.useEffect((()=>{const e=a.current;e&&n&&(e.options.animation=!1,e.data.datasets=n,e.update())}),[a.current,n]),Ot.createElement("canvas",{ref:t,...i,className:r})}function wo(e){return e.serverGroup&&e.alarm?Ot.createElement(Co,{...e}):null}function Co(e){var t,a;const n=null!=(t=e.alarm)?t:{},r=null!=(a=e.serverGroup)?a:{},{account:i,awsAccount:s,region:l,type:o}=r,{metricName:c,namespace:d,statistic:u,period:p}=n,{status:m,result:g}=F((async()=>{var t;const a={namespace:d,statistics:u,period:p};n.dimensions.forEach((e=>a[e.name]=e.value));const r="aws"===o?i:s,m=await Gt.getMetricStatistics("aws",r,l,c,a);return m.datapoints=m.datapoints||[],null==(t=e.onChartLoaded)||t.call(e,m),m}),{datapoints:[],unit:""},[d,u,p,o,i,l,c,n.dimensions]);if("PENDING"===m)return Ot.createElement("div",{className:"flex-container-v middle center sp-margin-xl"},Ot.createElement(ae,null));if("REJECTED"===m)return Ot.createElement(Ot.Fragment,null,Ot.createElement("div",null,"no data"),Ot.createElement("div",null,"something went wrong fetching stats"));if(0===g.datapoints.length)return Ot.createElement(Ot.Fragment,null,"no data");const h=new Date,f=new Date(Date.now()-864e5),v={label:c,fill:"stack",borderColor:"green",borderWidth:2,data:g.datapoints.map((e=>({x:new Date(e.timestamp),y:ia(e,[n.statistic.toLowerCase()],void 0)})))},y={label:"threshold",borderWidth:1,borderColor:"red",data:[{x:f,y:n.threshold},{x:h,y:n.threshold}]};return Ot.createElement(Eo,{lines:[v,y]})}mn.register(gn,hn,fn,vn,yn,bn,En,wn,Cn);const So={ASGAverageCPUUtilization:"CPUUtilization",ASGAverageNetworkIn:"NetworkIn",ASGAverageNetworkOut:"NetworkOut",ALBRequestCountPerTarget:"RequestCountPerTarget"},ko=({config:e,serverGroup:t,updateUnit:a})=>{const[n,r]=Ot.useState({alarmName:null,alarmArn:null,metricName:null,namespace:null,statistic:"Average",dimensions:[],period:60,threshold:e.targetValue,comparisonOperator:"GreaterThanThreshold",okactions:[],insufficientDataActions:[],alarmActions:[],evaluationPeriods:null,alarmDescription:null,unit:null});Ot.useEffect((()=>{(()=>{const a=null==e?void 0:e.customizedMetricSpecification,i=null==e?void 0:e.predefinedMetricSpecification,s={...n,dimensions:(null==a?void 0:a.dimensions)||[{name:"AutoScalingGroupName",value:t.name}],metricName:(null==a?void 0:a.metricName)||So[null==i?void 0:i.predefinedMetricType],namespace:(null==a?void 0:a.namespace)||"AWS/EC2",threshold:null==e?void 0:e.targetValue};if(a&&(s.statistic=null==a?void 0:a.statistic),i&&"ALBRequestCountPerTarget"===i.predefinedMetricType&&(s.statistic="Sum",s.namespace="AWS/ApplicationELB",null==i?void 0:i.resourceLabel)){const e=null==i?void 0:i.resourceLabel.split("/"),t=e.slice(0,3).join("/"),a=e.slice(3).join("/");s.dimensions=[{name:"LoadBalancer",value:t},{name:"TargetGroup",value:a}]}r(s)})()}),[e]);return Ot.createElement(wo,{alarm:n,onChartLoaded:e=>{a&&a(e.unit)},serverGroup:t})};xr("dimensions-editor {\n display: block;\n padding-left: 5px;\n}\ndimensions-editor h5 {\n margin-bottom: 0;\n}\ndimensions-editor .dimensions-row {\n margin-top: 5px;\n margin-left: -20px;\n}\ndimensions-editor .add-new {\n margin-left: 0;\n padding: 4px;\n width: 100%;\n}\n");const No=({alarm:e,serverGroup:t,updateAvailableMetrics:a})=>{const n=e.dimensions||[],{result:r}=F((()=>Gt.listMetrics("aws",t.account,t.region,{namespace:e.namespace}).then((e=>{const t=Ea(e,(e=>e.dimensions));return sa(t.filter((e=>e)).map((e=>e.name))).sort()})).catch((()=>[]))),[],[e.namespace,t.name]),i=(e,t,r)=>{const i=[...n];i[r][e]=t,a(i)};return Ot.createElement("div",null,Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12 small"},Ot.createElement("h5",null,"Dimensions"))),n.map(((t,n)=>Ot.createElement("div",{key:`dimension-${n}`,className:"row dimensions-row horizontal middle"},Ot.createElement("div",{className:"col-md-6"},Ot.createElement(c,{onChange:e=>i("name",e.target.value,n),value:t.name,stringOptions:r})),Ot.createElement(l,{onChange:e=>i("value",e.target.value,n),value:t.value}),!e.disableEditingDimensions&&Ot.createElement("div",{className:"col-md-1",onClick:()=>(t=>{const n=e.dimensions.filter(((e,a)=>a!==t));a(n)})(n)},Ot.createElement("a",null,Ot.createElement("i",{className:"glyphicon glyphicon-trash clickable"})))))),!e.disableEditingDimensions&&Ot.createElement("div",{className:"row"},Ot.createElement("div",null,Ot.createElement("button",{type:"button",className:"btn btn-block btn-xs add-new",onClick:()=>{const e=[...n,{}];a(e)}},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign sp-margin-xs-left"}),"Add dimension"))))},To=["AWS/ApplicationELB","AWS/AutoScaling","AWS/AmazonMQ","AWS/Billing","AWS/CloudFront","AWS/CloudSearch","AWS/Events","AWS/DynamoDB","AWS/ECS","AWS/ElastiCache","AWS/EBS","AWS/EC2","AWS/ELB","AWS/ElasticMapReduce","AWS/ES","AWS/Kinesis","AWS/Lambda","AWS/ML","AWS/OpsWorks","AWS/Redshift","AWS/RDS","AWS/Route53","AWS/SNS","AWS/SQS","AWS/S3","AWS/SWF","AWS/StorageGateway","AWS/WAF","AWS/WorkSpaces"];xr(".MetricSelector {\n font-size: 12px;\n}\n.MetricSelector .simple-input {\n width: 216px;\n}\n.MetricSelector .advanced-input-namespace {\n width: 138px;\n}\n.MetricSelector .advanced-input-metric {\n width: 300px;\n}\n");const Io=({alarm:e,updateAlarm:t,serverGroup:a})=>{var r,i;const s=((null==(i=null==(r=kn)?void 0:r.metrics)?void 0:i.customNamespaces)||[]).concat(To),[l,o]=Ot.useState(!1),d=((null==e?void 0:e.dimensions)||[]).reduce(((e,t)=>(e[t.name]=t.value,e)),{}),{result:u}=F((()=>{const t="aws"===a.cloudProvider?a.account:null==a?void 0:a.awsAccount,n=l?{namespace:null==e?void 0:e.namespace}:{AutoScalingGroupName:a.name};return Gt.listMetrics("aws",t,a.region,n).then((e=>(e||[]).map((e=>{return{label:`(${e.namespace}) ${e.name}`,dimensions:[],dimensionValues:(t=e.dimensions||[],t.sort(((e,t)=>{var a;return null==(a=e.name)?void 0:a.localeCompare(t.name)})).map((e=>e.value)).join(", ")),value:e,...e};var t})).sort(((e,t)=>{var a;return null==(a=e.label)?void 0:a.localeCompare(t.label)})))).catch((()=>[]))}),[],[a,null==e?void 0:e.namespace]),p=(u||[]).filter((t=>t.namespace===(null==e?void 0:e.namespace))),m=p.find((t=>t.name===(null==e?void 0:e.metricName)&&t.namespace===(null==e?void 0:e.namespace)))||p.find((e=>e.name.match("CPUUtilization")))||p[0],{name:g,namespace:h}=m||{},f=()=>{const n=!l;if(n)d.namespace=null==e?void 0:e.namespace;else{const n={...e,dimension:[{name:"AutoScalingGroupName",value:a.name}]};t(n)}o(n)},v=a=>{const n={...e,metricName:a.name,namespace:a.namespace,dimensions:a.dimensions};t(n)},y=(a,n)=>{const r={...e,metricName:n,namespace:a};t(r)};return Ot.useEffect((()=>{m&&v(m)}),[m]),l?Ot.createElement("div",{className:"MetricSelector"},Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(c,{value:h,onChange:t=>y(t.target.value,null==e?void 0:e.metricName),stringOptions:s,inputClassName:"advanced-input-namespace sp-margin-m-right"}),Ot.createElement(c,{value:g,onChange:t=>y(null==e?void 0:e.namespace,t.target.value),stringOptions:u.map((e=>e.name)),placeholder:"name",searchable:!0,inputClassName:"advanced-input-metric"})),Ot.createElement("div",{className:"vertical"},!Boolean(u.length)&&Ot.createElement("span",{className:"input-label"},Ot.createElement("b",null,"Note:")," no metrics found for selected namespace + dimensions"),Ot.createElement("a",{className:"clickable",onClick:f},Ot.createElement("span",{className:"sp-margin-s-yaxis sp-margin-xs-right"},"Only show metrics for this auto scaling group"),Ot.createElement(n,{id:"aws.scalingPolicy.search.restricted"}))),Ot.createElement(No,{alarm:e,serverGroup:a,updateAvailableMetrics:a=>{const n={...e,dimensions:a};t(n)}})):Ot.createElement("div",{className:"MetricSelector horizontal middle"},Ot.createElement(c,{value:m,onChange:e=>v(e.target.value),options:u,clearable:!1,inputClassName:"sp-margin-s-right simple-input"}),Ot.createElement("a",{className:"clickable",onClick:f},Ot.createElement("span",{className:"sp-margin-xs-right"},"Search all metrics"),Ot.createElement(n,{id:"aws.scalingPolicy.search.all"})))};xr(".TargetMetricFields .metric-select-input {\n font-size: 12px;\n width: 180px;\n}\n.TargetMetricFields .target-input {\n width: 120px;\n}\n");const Go=({allowDualMode:e,cloudwatch:t,command:a,isCustomMetric:n,app:r,serverGroup:i,toggleMetricType:s,updateCommand:l})=>{var o,d,u,m;const[g,h]=Ot.useState(null),f=(e,t)=>{const n=_t(a);da(n,e,t),l(n)};return Ot.createElement("div",{className:"TargetMetricFields sp-margin-l-xaxis"},Ot.createElement("p",null,"With target tracking policies, Amazon will automatically adjust the size of your ASG to keep the selected metric as close as possible to the selected value."),t&&Ot.createElement("p",null,Ot.createElement("b",null,"Note:"),' metrics must be sent to Amazon CloudWatch before they can be used in auto scaling. If you do not see a metric below, click "Configure available metrics" in the server group details to set up forwarding from Atlas to CloudWatch.'),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Metric"),Ot.createElement("div",{className:"col-md-10 content-fields"},!n&&Ot.createElement(c,{value:null==(o=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:o.predefinedMetricType,stringOptions:["ASGAverageCPUUtilization","ASGAverageNetworkOut","ASGAverageNetworkIn","ALBRequestCountPerTarget"],onChange:e=>f("targetTrackingConfiguration.predefinedMetricSpecification.predefinedMetricType",e.target.value),inputClassName:"metric-select-input"}),n&&Ot.createElement(Io,{alarm:a.targetTrackingConfiguration.customizedMetricSpecification,serverGroup:i,updateAlarm:e=>{f("targetTrackingConfiguration.customizedMetricSpecification",e)}}),e&&Ot.createElement("a",{className:"clickable",onClick:()=>{const e=_t(a);n?(da(e,"targetTrackingConfiguration.predefinedMetricSpecification",{predefinedMetricType:"ASGAverageCPUUtilization"}),da(e,"targetTrackingConfiguration.customizedMetricSpecification",null)):(da(e,"targetTrackingConfiguration.predefinedMetricSpecification",null),da(e,"targetTrackingConfiguration.customizedMetricSpecification",{metricName:"CPUUtilization",namespace:"AWS/EC2",dimensions:[{name:"AutoScalingGroupName",value:i.name}],statistic:"Average"})),l(e),s(n?"predefined":"custom")}},n?"Use a predefined metric":"Select a custom metric"))),!n&&"ALBRequestCountPerTarget"===(null==(d=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:d.predefinedMetricType)&&Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Target Group"),Ot.createElement("div",{className:"col-md-10 content-fields horizontal"},Ot.createElement(c,{value:null==(u=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:u.resourceLabel,options:r.loadBalancers.data.filter((e=>e.account===i.account&&e.region===i.region)).flatMap((e=>e.targetGroups.filter((e=>i.targetGroups.some((t=>t===e.name)))).map((t=>({...t,loadBalancerArn:e.loadBalancerArn}))))).map((e=>({label:e.name,value:`${e.loadBalancerArn.substring(e.loadBalancerArn.indexOf("app"))}/${e.targetGroupArn.substring(e.targetGroupArn.indexOf("targetgroup"))}`}))),onChange:e=>f("targetTrackingConfiguration.predefinedMetricSpecification.resourceLabel",e.target.value),inputClassName:"metric-select-input"}))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Target"),Ot.createElement("div",{className:"col-md-10 content-fields horizontal"},n&&Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(c,{value:null==(m=a.targetTrackingConfiguration.customizedMetricSpecification)?void 0:m.statistic,stringOptions:["Average","Maximum","Minimum","SampleCount","Sum"],onChange:e=>f("targetTrackingConfiguration.customizedMetricSpecification.statistic",e.target.value),inputClassName:"form-control input-sm target-input"}),Ot.createElement("span",{className:"sp-margin-xs-xaxis"},"of")),Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(p,{value:a.targetTrackingConfiguration.targetValue,onChange:e=>f("targetTrackingConfiguration.targetValue",Number.parseInt(e.target.value)),inputClassName:"form-control input-sm sp-margin-xs-right"}),Ot.createElement("span",null,g)))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement(ko,{config:a.targetTrackingConfiguration,serverGroup:i,unit:g,updateUnit:e=>h(e)}))))};xr(".TargetTrackingAdditionalSettings {\n font-size: 14px;\n}\n.TargetTrackingAdditionalSettings .row {\n margin-bottom: 10px;\n}\n.TargetTrackingAdditionalSettings .number-input-sm {\n width: 120px;\n}\n");const Ao=({command:e,cooldowns:t,policyName:a,updateCommand:r})=>{var i;const s=(t,a)=>{const n={...e};da(n,t,a),r(n)},l=null==(i=e.targetTrackingConfiguration)?void 0:i.disableScaleIn;return Ot.createElement("div",{className:"section-body TargetTrackingAdditionalSettings"},a&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},a)),Boolean(e.estimatedInstanceWarmup)&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static"},"Instances need"),Ot.createElement(p,{value:e.estimatedInstanceWarmup,onChange:e=>s("estimatedInstanceWarmup",Number.parseInt(e.target.value)),inputClassName:"form-control number-input-sm sp-margin-xs-xaxis"}),Ot.createElement("span",{className:"input-label"}," seconds to warm up "))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Scale In"),Ot.createElement("div",{className:"col-md-9"},Ot.createElement("div",{className:"checkbox"},Ot.createElement(d,{text:"Disable Scale-downs",checked:l,onChange:e=>s("targetTrackingConfiguration.disableScaleIn",e.target.checked)}),Ot.createElement("div",{className:"small"},Ot.createElement("p",null,"This option disables scale-downs for the target tracking policy, while keeping the scale-ups. This means that ASG will not scale down unless you explicitly set up a separate step policy to scale it down."),Ot.createElement("p",null,"This is useful when you have special requirements, such as gradual or delayed scale-down."))))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},l&&Ot.createElement("div",{className:"well"},"This policy will not scale down. Make sure you have another policy (either TT or Step) that will scale down this ASG."),!1===l&&Ot.createElement("div",{className:"well"},"This policy will scale both up and down. Make sure you don't have other scaling policies, as they will likely interfere with each other."))),t&&!l&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("span",{className:"sp-margin-xs-right"},"Scale In Cooldown"),Ot.createElement(n,{id:"titus.autoscaling.scaleIn.cooldown"})),Ot.createElement("div",{className:"col-md-9 horizontal middle"},Ot.createElement(p,{value:e.targetTrackingConfiguration.scaleInCooldown,onChange:e=>s("targetTrackingConfiguration.scaleInCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds "))),t&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("span",{className:"sp-margin-xs-right"},"Scale Out Cooldown"),Ot.createElement(n,{id:"titus.autoscaling.scaleOut.cooldown"})),Ot.createElement("div",{className:"col-md-9 horizontal middle"},Ot.createElement(p,{value:e.targetTrackingConfiguration.scaleOutCooldown,onChange:e=>s("targetTrackingConfiguration.scaleOutCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds "))))},xo={buildAlarm:(e,t,a)=>{const n=(null==e?void 0:e.alarms)?e.alarms[0]:{};return{name:n.alarmName,actionsEnabled:!0,alarmActionArns:n.alarmActions,alarmDescription:n.alarmDescription,asgName:a,comparisonOperator:n.comparisonOperator,dimensions:n.dimensions,evaluationPeriods:n.evaluationPeriods,insufficientDataActionArns:n.insufficientDataActions,metricName:n.metricName,namespace:n.namespace,okActionArns:n.okactions,period:n.period,region:t,statistic:n.statistic,threshold:n.threshold,unit:n.unit}},buildStepPolicy:(e,t,a)=>{var n,r;const i=e.stepAdjustments.map((e=>{const a={scalingAdjustment:Math.abs(e.scalingAdjustment)};return void 0!==e.metricIntervalUpperBound&&(a.metricIntervalUpperBound=e.metricIntervalUpperBound+t),void 0!==e.metricIntervalLowerBound&&(a.metricIntervalLowerBound=e.metricIntervalLowerBound+t),a}));return{estimatedInstanceWarmup:null!=(r=null!=(n=e.estimatedInstanceWarmup)?n:a)?r:600,metricAggregationType:"Average",stepAdjustments:i}},buildSimplePolicy:e=>{var t,a;return{cooldown:null!=(t=e.cooldown)?t:600,scalingAdjustment:null!=(a=Math.abs(e.scalingAdjustment))?a:1}},buildNewCommand:(e,t,a)=>{var n,r,i;const s={name:a.policyName,adjustmentType:"Step"===e?a.adjustmentType:null,cloudProvider:t.cloudProvider,credentials:t.account,provider:t.type,region:t.region,serverGroupName:t.name};return"Step"===e&&(s.alarm=xo.buildAlarm(a,t.region,t.name),s.minAdjustmentMagnitude=null!=(n=a.minAdjustmentMagnitude)?n:1,(null==(r=a.stepAdjustments)?void 0:r.length)?s.step=xo.buildStepPolicy(a,s.alarm.threshold,s.cooldown):s.simple=xo.buildSimplePolicy(a)),"TargetTracking"===e&&(s.estimatedInstanceWarmup=null!=(i=a.estimatedInstanceWarmup)?i:600,s.targetTrackingConfiguration={...a.targetTrackingConfiguration}),s},prepareCommandForUpsert:(e,t)=>{const a=_t(e);return"PercentChangeInCapacity"!==a.adjustmentType&&delete a.minAdjustmentMagnitude,a.step?a.step.stepAdjustments.forEach((e=>{t&&(e.scalingAdjustment=0-e.scalingAdjustment,delete a.step.estimatedInstanceWarmup),void 0!==e.metricIntervalLowerBound&&(e.metricIntervalLowerBound-=a.alarm.threshold),void 0!==e.metricIntervalUpperBound&&(e.metricIntervalUpperBound-=a.alarm.threshold)})):t&&(e.simple.scalingAdjustment=0-e.simple.scalingAdjustment),a}},Po=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i;const[s,l]=Ot.useState(Boolean(null==(i=n.targetTrackingConfiguration)?void 0:i.customizedMetricSpecification)),[o,c]=Ot.useState({});Ot.useEffect((()=>{const e=xo.buildNewCommand("TargetTracking",r,n);c(e)}),[]);const d=n.policyName?"Update":"Create";return Ot.createElement(At,{closeModal:t,dismissModal:a,title:`${d} scaling policy`,application:e,description:`${d} scaling policy for ${r.name}`,initialValues:o,mapValuesToTask:()=>({application:e,job:[{type:"upsertScalingPolicy",...o}]}),render:()=>Ot.createElement("div",{className:"modal-body"},Ot.createElement("h4",{className:"section-heading"},"Target Metric"),Ot.createElement(Go,{allowDualMode:!0,cloudwatch:!1,command:o,isCustomMetric:s,app:e,serverGroup:r,toggleMetricType:e=>l("custom"===e),updateCommand:c}),Ot.createElement("h4",{className:"section-heading"},"Additional Settings"),Ot.createElement(Ao,{command:o,cooldowns:!1,policyName:n.policyName,updateCommand:c}))})};function Do(e){const[t,a]=Vt.useState(null),r=e=>{a(e.currentTarget.id)},i="step"===t?"card active":"card",s="targetTracking"===t?"card active":"card",l="aws.scalingPolicy.additionalHelp",o=!!P.getHelpField(l);return Vt.createElement(Ha,{show:!0,onHide:e.showCallback},Vt.createElement(Ha.Header,{closeButton:!0},Vt.createElement("h3",null,"Select a policy type")),Vt.createElement(Ha.Body,null,Vt.createElement("div",{className:"card-choices"},Vt.createElement("div",{className:s,onClick:r,id:"targetTracking"},Vt.createElement("h3",null,"Target Tracking"),Vt.createElement("div",null,"Continuously adjusts the size of the ASG to keep a specified metric at the target value")),Vt.createElement("div",{className:i,onClick:r,id:"step"},Vt.createElement("h3",null,"Step"),Vt.createElement("div",null,"Rule-based scaling, with the ability to define different scaling amounts depending on the magnitude of the alarm breach"))),o&&Vt.createElement(pe,{type:"info",message:Vt.createElement(n,{id:l,expand:!0})}),e.warnOnMinMaxCapacity&&Vt.createElement(pe,{type:"warning",message:Vt.createElement(Vt.Fragment,null,Vt.createElement("p",null,"This server group's ",Vt.createElement("em",null,"min")," and ",Vt.createElement("em",null,"max")," capacity are identical, so scaling policies will have ",Vt.createElement("b",null,"no effect.")),Vt.createElement("p",null,"Scaling policies work by adjusting the server group's ",Vt.createElement("em",null,"desired")," capacity to a value between the min and max."))})),Vt.createElement(Ha.Footer,null,Vt.createElement("button",{className:"btn btn-default",onClick:e.showCallback},"Cancel"),Vt.createElement("button",{className:"btn btn-primary",disabled:!t,onClick:()=>{e.typeSelectedCallback(t)}},"Next")))}xr(".ScalingPolicyAdditionalSettings .section-additional-settings .row {\n margin-bottom: 10px;\n}\n.ScalingPolicyAdditionalSettings .section-additional-settings .number-input-sm {\n width: 60px;\n}\n");const Bo=({command:e,isInstanceType:t,isNew:a,operator:r,updateCommand:i})=>{var s,l,o,c;const d=(t,a)=>{const n={...e};da(n,t,a),i(n)};return Ot.createElement("div",{className:"ScalingPolicyAdditionalSettings"},Ot.createElement("h4",{className:"section-heading"},"Additional Settings"),Ot.createElement("div",{className:"section-body section-additional-settings"},!a&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"},e.name))),!t&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Adjustment Step"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"},`${r} instances in increments of at least `),Ot.createElement(p,{value:e.minAdjustmentMagnitude,onChange:e=>d("minAdjustmentMagnitude",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," instance(s) "))),Boolean(e.simple)&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Cooldown"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"}," Wait at least "),Ot.createElement(p,{value:null==(s=e.simple)?void 0:s.cooldown,onChange:e=>d("simple.cooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds before another scaling event "))),Boolean(null==(l=e.step)?void 0:l.estimatedInstanceWarmup)&&"Remove"!==r&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"},"Instances need"),Ot.createElement(p,{value:e.step.estimatedInstanceWarmup,onChange:e=>d("step.estimatedInstanceWarmup",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds to warm up after each step "))),Boolean(null==(o=e.step)?void 0:o.cooldown)&&"Remove"!==r&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},Ot.createElement("span",{className:"sp-margin-xs-right"},"Cooldown"),Ot.createElement(n,{id:`${e.cloudProvider||e.provider}.autoscaling.cooldown`})),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement(p,{value:null==(c=e.step)?void 0:c.cooldown,onChange:e=>d("step.cooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds ")))))};xr(".AlarmConfigurer {\n font-size: 12px;\n margin: 0px;\n}\n.AlarmConfigurer .configurer-field-lg {\n width: 90px;\n}\n.AlarmConfigurer .configurer-field-small {\n width: 32px;\n}\n.AlarmConfigurer .configurer-field-med {\n width: 60px;\n}\n.AlarmConfigurer .number-input-field {\n margin: 0px;\n}\n");const zo=["Average","Maximum","Minimum","SampleCount","Sum"],Fo=[{label:">=",value:"GreaterThanOrEqualToThreshold"},{label:">",value:"GreaterThanThreshold"},{label:"<=",value:"LessThanOrEqualToThreshold"},{label:"<",value:"LessThanThreshold"}],Mo=[{label:"1 minute",value:60},{label:"5 minutes",value:300},{label:"15 minutes",value:900},{label:"1 hour",value:3600},{label:"4 hours",value:14400},{label:"1 day",value:86400}],$o=({alarm:e,multipleAlarms:t,serverGroup:a,stepAdjustments:n,stepsChanged:r,updateAlarm:i})=>{var s,l;const o=0===(null==(s=e.comparisonOperator)?void 0:s.indexOf("Greater"))?"max":"min",[d,u]=Ot.useState(null==e?void 0:e.unit),m=vt(o);Ot.useEffect((()=>{if(n&&void 0!==m){const t="max"===o?"metricIntervalLowerBound":"metricIntervalUpperBound",a={scalingAdjustment:1,[t]:e.threshold};r([a])}}),[o]),Ot.useEffect((()=>{const t="max"===o?"metricIntervalLowerBound":"metricIntervalUpperBound";if(null==n?void 0:n.length){const a=[...n];a[0][t]=e.threshold,r(a)}}),[e.threshold]);const g=(t,a)=>{const n={...e,[t]:a};i(n)};return Ot.createElement("div",{className:"AlarmConfigurer"},t&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"})," This scaling policy is configured with multiple alarms. You are only editing the first alarm."),Ot.createElement("p",null,"To edit or remove the additional alarms, you will need to use the AWS console.")))),(null==(l=e.alarmActionArns)?void 0:l.length)>1&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"})," This alarm is used in multiple scaling policies. Any changes here will affect those other scaling policies.")))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Whenever"),Ot.createElement("div",{className:"col-md-10 horizontal"},Ot.createElement(c,{value:e.statistic,onChange:e=>g("statistic",e.target.value),stringOptions:zo,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}),Ot.createElement("span",{className:"input-label sp-margin-xs-right sp-margin-s-top"}," of "),Ot.createElement(Io,{alarm:e,serverGroup:a,updateAlarm:e=>{i(e)}}))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"is"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement(c,{value:e.comparisonOperator,onChange:e=>g("comparisonOperator",e.target.value),options:Fo,clearable:!1,inputClassName:"sp-margin-s-right configurer-field-small"}),Ot.createElement("div",{className:"sp-margin-xl-left"},Ot.createElement(p,{value:e.threshold,onChange:e=>g("threshold",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-right configurer-field-lg"})),Ot.createElement("span",{className:"input-label"},d))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"for at least"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement(p,{value:e.evaluationPeriods,onChange:e=>g("evaluationPeriods",Number.parseInt(e.target.value)),inputClassName:"configurer-field-med number-input-field"}),Ot.createElement("span",{className:"input-label sp-margin-s-xaxis"}," consecutive period(s) of "),Ot.createElement(c,{value:e.period,onChange:e=>g("period",e.target.value),options:Mo,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},e&&Ot.createElement("div",null,Ot.createElement(wo,{alarm:e,serverGroup:a,onChartLoaded:e=>u(e.unit)})))))};xr(".SimplePolicyAction .action-input {\n width: 65px;\n}\n.SimplePolicyAction .adjustment-type-input {\n width: 110px;\n}\n");const Lo=({adjustmentType:e,adjustmentTypeChanged:t,operator:a,scalingAdjustment:n,updateScalingAdjustment:r})=>{const i="Set to"===a?["instances"]:["instances","percent of group"],[s,l]=Ot.useState(e),[o,d]=Ot.useState(n);return Ot.createElement("div",{className:"SimplePolicyAction row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1 horizontal middle"},Ot.createElement(c,{value:a,stringOptions:["Add","Remove","Set to"],onChange:a=>{return n=a.target.value,void t(n,e);var n},clearable:!1,inputClassName:"action-input"}),Ot.createElement(p,{value:o,min:1,onChange:e=>{return t=Number.parseInt(e.target.value),d(t),void r(t);var t},inputClassName:"action-input"}),Ot.createElement(c,{value:s,stringOptions:i,onChange:e=>{return n=e.target.value,l(n),void t(a,n);var n},clearable:!1,inputClassName:"adjustment-type-input"})))};xr(".StepPolicyAction .step-policy-row {\n padding: 5px 0;\n border-bottom: 1px solid var(--color-seashell);\n}\n.StepPolicyAction .step-policy-row .action-input {\n width: 65px !important;\n}\n.StepPolicyAction .step-policy-row .adjustment-type-input {\n width: 110px;\n}\n.StepPolicyAction .step-policy-row .remove-step-action-icon {\n margin-left: auto;\n}\n");const Ro=({adjustmentType:e,adjustmentTypeChanged:t,alarm:a,isMin:n,operator:r,step:i,stepAdjustments:s,stepsChanged:l})=>{const o=null==a?void 0:a.comparisonOperator.includes("Equal"),d=["Add","Remove","Set to"],u="Set to"===r?["instances"]:["instances","percent of group"],m=(null==i?void 0:i.stepAdjustments)||s,g=(e,t)=>{const a=[...m];a[t]=e,l(a)};return Ot.createElement("div",{className:"StepPolicyAction row"},null==m?void 0:m.map(((i,s)=>Ot.createElement("div",{key:`step-adjustment-${s}`,className:"step-policy-row col-md-10 col-md-offset-1 horizontal middle"},Boolean(s)?Ot.createElement("span",{className:"action-input sp-margin-xs-left"},r):Ot.createElement(c,{value:r,stringOptions:d,onChange:a=>{return n=a.target.value,void t(n,e);var n},clearable:!1,inputClassName:"action-input sp-margin-xs-right"}),Ot.createElement(p,{value:i.scalingAdjustment,min:1,onChange:e=>g({...i,scalingAdjustment:Number.parseInt(e.target.value)},s),inputClassName:"action-input"}),Boolean(s)?Ot.createElement("span",{className:"sp-margin-xs-left"},e):Ot.createElement(c,{value:e,stringOptions:u,onChange:e=>{return a=e.target.value,void t(r,a);var a},clearable:!1,inputClassName:"adjustment-type-input sp-margin-xs-left"}),Ot.createElement("span",{className:"sp-margin-xs-xaxis"}," ","when ",Ot.createElement("b",null,null==a?void 0:a.metricName)," is"," "),s===m.length-1&&Ot.createElement("span",null,` ${n?"less":"greater"} than${!Boolean(s)||o?" or equal to":""} ${n?i.metricIntervalUpperBound||"":i.metricIntervalLowerBound||""} `),s<m.length-1&&Ot.createElement(Ot.Fragment,null,Ot.createElement("span",{className:"sp-margin-xs-xaxis"},"between"),n?Ot.createElement(p,{value:i.metricIntervalLowerBound,max:i.metricIntervalUpperBound,step:.1,onChange:e=>g({...i,metricIntervalLowerBound:Number.parseFloat(e.target.value)},s),inputClassName:"action-input"}):Ot.createElement("span",null,i.metricIntervalLowerBound),Ot.createElement("span",{className:"sp-margin-xs-xaxis"},"and"),n?Ot.createElement("span",null,i.metricIntervalUpperBound):Ot.createElement(p,{value:i.metricIntervalUpperBound,min:i.metricIntervalLowerBound,step:.1,onChange:e=>g({...i,metricIntervalUpperBound:Number.parseFloat(e.target.value)},s),inputClassName:"action-input"})),Boolean(s)&&Ot.createElement("a",{className:"glyphicon glyphicon-trash clickable sp-margin-xs-xaxis remove-step-action-icon",onClick:()=>(e=>{const t=m.filter(((t,a)=>a!==e));l(t)})(s)})))),Ot.createElement("div",{className:"row sp-margin-s"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement("button",{type:"button",className:"btn btn-block btn-sm add-new",onClick:()=>{const e=[...m,{scalingAdjustment:1}];l(e)}},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),"Add step"))),Ot.createElement("div",{className:"row sp-margin-s-xaxis"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement("a",{href:"http://docs.aws.amazon.com/autoscaling/latest/userguide/as-scale-based-on-demand.html#as-scaling-steps",target:"_blank"},Ot.createElement("i",{className:"far fa-file-alt sp-margin-xs-right"}),"Documentation"))))},Oo=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i,s,l;const o={closeModal:t,dismissModal:a},[c,d]=Ot.useState({});Ot.useEffect((()=>{const e=xo.buildNewCommand("Step",r,n);d(e)}),[]);const u=(null==(i=n.stepAdjustments)?void 0:i.length)?n.stepAdjustments[0].scalingAdjustment:n.scalingAdjustment,[p,m]=Ot.useState("ExactCapacity"===c.adjustmentType?"Set to":u>0?"Add":"Remove"),g="ExactCapacity"===c.adjustmentType||"ChangeInCapacity"===c.adjustmentType?"instances":"percent of group",h=c.step,f=n.policyARN?"Edit":"Create",v=0===(null==(l=null==(s=null==c?void 0:c.alarm)?void 0:s.comparisonOperator)?void 0:l.indexOf("Greater"))?"max":"min",y=e=>{const t="min"===v?"metricIntervalLowerBound":"metricIntervalUpperBound",a="metricIntervalLowerBound"===t?"metricIntervalUpperBound":"metricIntervalLowerBound",n=e.stepAdjustments;(n||[]).forEach(((e,r)=>{n.length>r+1&&(n[r+1][a]=e[t])})),delete n[n.length-1][t]},b=e=>{const t=_t(c);t.simplescalingAdjustment=e,d(t)},E=e=>{const t=_t(c);t.step.stepAdjustments=e,y(t.step),d(t)},w=(e,t)=>{m(e);const a="instances"!==t?"PercentChangeInCapacity":"Set to"===e?"ExactCapacity":"ChangeInCapacity";d({...c,adjustmentType:a})},C=()=>{const e=_t(c),t=c.step?c.step.estimatedInstanceWarmup:c.simple.cooldown;if(c.step)delete e.step,e.simple=xo.buildSimplePolicy({cooldown:t});else{const a=[{scalingAdjustment:c.simple.scalingAdjustment}];"min"===v?a[0].metricIntervalUpperBound=0:a[0].metricIntervalLowerBound=0;const n={estimatedInstanceWarmup:t,stepAdjustments:a};delete e.simple,e.step=xo.buildStepPolicy(n,e.alarm.threshold,t),y(e.step)}d(e)};return Ot.createElement(At,{...o,title:`${f} scaling policy`,application:e,description:`${f} scaling policy for ${r.name}`,initialValues:c,mapValuesToTask:()=>{const t=xo.prepareCommandForUpsert(c,"Remove"===p);return{application:e,job:[{type:t.type||"upsertScalingPolicy",...t}]}},render:()=>{var e,t,a,i,s;return Ot.createElement("div",null,Ot.createElement("h4",{className:"section-heading"},"Conditions"),Ot.createElement("div",{className:"section-body"},Ot.createElement($o,{alarm:c.alarm,multipleAlarms:Boolean((null==(e=null==n?void 0:n.alarms)?void 0:e.length)>1),serverGroup:r,stepAdjustments:c.step.stepAdjustments,stepsChanged:E,updateAlarm:e=>d({...c,alarm:e})})),Ot.createElement("h4",{className:"section-heading"},"Actions"),Ot.createElement("div",{className:"section-body"},!(null==(t=c.alarm)?void 0:t.metricName)&&Ot.createElement("h4",{className:"text-center"},"Select a metric"),(null==(a=c.alarm)?void 0:a.metricName)&&!h&&Ot.createElement("div",null,Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement("p",null,"This is a simple scaling policy. To declare different actions based on the magnitude of the alarm,",Ot.createElement("b",null,"switch to a",Ot.createElement("a",{className:"clickable sp-margin-xs-l",onClick:C},"step policy"),".")))),Ot.createElement(Lo,{adjustmentType:g,adjustmentTypeChanged:w,operator:p,scalingAdjustment:null==(i=c.simple)?void 0:i.scalingAdjustment,updateScalingAdjustment:b})),(null==(s=c.alarm)?void 0:s.metricName)&&h&&Ot.createElement(Ro,{adjustmentType:g,adjustmentTypeChanged:w,alarm:c.alarm,isMin:"min"===v,operator:p,step:c.step,stepsChanged:E})),Ot.createElement(Bo,{command:c,isInstanceType:"instances"===g,isNew:Boolean(!n.policyARN),operator:p,updateCommand:d}))}})};class Vo extends Vt.Component{constructor(e){super(e),this.handleClick=()=>{this.setState({showSelection:!0})},this.typeSelected=e=>{this.setState({typeSelection:e,showSelection:!1,showModal:!0}),"step"===e&&this.createStepPolicy(),"targetTracking"===e&&this.createTargetTrackingPolicy()},this.showModalCallback=()=>{this.setState({showSelection:!1,showModal:!1,typeSelection:null})},this.state={showSelection:!1,showModal:!1,typeSelection:null}}createStepPolicy(){const{serverGroup:e,application:t}=this.props,a={app:t,policy:Xn.awsServerGroupTransformer.constructNewStepScalingPolicyTemplate(e),serverGroup:e};b.show(Oo,a,{dialogClassName:"wizard-modal modal-lg"})}createTargetTrackingPolicy(){const{serverGroup:e,application:t}=this.props,a={app:t,policy:Xn.awsServerGroupTransformer.constructNewTargetTrackingPolicyTemplate(),serverGroup:e};b.show(Po,a,{dialogClassName:"wizard-modal modal-lg"})}render(){const{min:e,max:t}=this.props.serverGroup.capacity;return Vt.createElement("div",null,Vt.createElement("a",{className:"clickable",onClick:this.handleClick},"Create new scaling policy"),this.state.showSelection&&Vt.createElement(Do,{warnOnMinMaxCapacity:e===t,typeSelectedCallback:this.typeSelected,showCallback:this.showModalCallback}))}}class Uo{static upsertScalingPolicy(e,t){return t.type=t.type||"upsertScalingPolicy",O.executeTask({application:e,description:"Upsert scaling policy "+(t.name||t.serverGroupName),job:[t]})}static deleteScalingPolicy(e,t,a){return O.executeTask({application:e,description:"Delete scaling policy "+a.policyName,job:[{type:"deleteScalingPolicy",cloudProvider:"aws",credentials:t.account,region:t.region,policyName:a.policyName,serverGroupName:t.name}]})}}const qo={GreaterThanOrEqualToThreshold:">=",GreaterThanThreshold:">",LessThanOrEqualToThreshold:"<=",LessThanThreshold:"<"},Ho=({alarm:e})=>Ot.createElement("div",null,Ot.createElement("div",null,Ot.createElement("b",null,"Whenever"),` ${e.statistic} of ${e.metricName}`),Ot.createElement("div",null,Ot.createElement("b",null,"for at least"),` ${e.evaluationPeriods} consecutive periods of ${e.period} seconds`)),Wo=({policy:e,serverGroup:t})=>{var a;const{adjustmentType:n,alarms:r,cooldown:i,estimatedInstanceWarmup:s,minAdjustmentMagnitude:l,stepAdjustments:o}=e,c=!!i||"decrease"===(null==(a=null==o?void 0:o[0])?void 0:a.operator),d=r[0]||{},u=null==d?void 0:d.comparisonOperator.includes("Greater"),p=e=>"ExactCapacity"===n?`set capacity to ${e.scalingAdjustment} instance${e.scalingAdjustment>1?"s":""}`:`${e.operator} capacity by ${e.absAdjustment}${"PercentChangeInCapacity"===n?"%":" instance"}${"ChangeInCapacity"===n&&e.absAdjustment>1?"s":""}`;return Ot.createElement("div",null,Ot.createElement(W,{className:"dl-horizontal dl-narrow"},Ot.createElement(B,{label:"Whenever",value:`${d.statistic} of ${d.metricName} is ${qo[d.comparisonOperator]} ${d.threshold}`}),Ot.createElement(B,{label:"for at least",value:`${d.evaluationPeriods} consecutive periods of ${d.period} seconds`}),Boolean(null==o?void 0:o.length)&&Ot.createElement(B,{label:"then",value:o.map(((e,t)=>Ot.createElement("div",{key:`step-adjustment-boundary-${t}`},o.length>1&&Ot.createElement("span",null,(e=>{const t=void 0!==e.metricIntervalLowerBound&&void 0!==e.metricIntervalUpperBound?`is between ${d.threshold+e.metricIntervalLowerBound} and ${d.threshold+e.metricIntervalUpperBound} `:"",a=u?e.metricIntervalLowerBound:e.metricIntervalUpperBound,n=`is ${u?"greater":"less"} than ${d.threshold+a}`;return`if ${d.metricName} ${t}${n}`})(e)),Ot.createElement("span",null,p(e)))))}),!Boolean(null==o?void 0:o.length)&&Ot.createElement(B,{label:"then",value:p(e)}),Boolean(l)&&Ot.createElement(B,{label:"in",value:`increments of at least ${l} instance${l>1?"s":""}`}),Boolean(c)&&Ot.createElement(B,{label:"wait",value:`${i} seconds before allowing another scaling activity.`}),Boolean(s)&&Ot.createElement(B,{label:"wait",value:`${s} seconds to warm up after each step.`})),Ot.createElement(wo,{alarm:d,serverGroup:t}))};xr(".StepPolicySummary .HoverablePopover {\n text-decoration: none;\n}\n.StepPolicySummary .actions {\n margin: 0 0 15px 0;\n border-bottom: 1px solid var(--color-alto);\n}\n");const jo=({application:e,policy:t,serverGroup:a})=>{var n,r;const i=a.type||a.cloudProvider||"aws",s=V.getValue(i,"serverGroup"),l="aws"===i?t.policyName:t.id,o=s.UpsertStepPolicyModal,c=()=>{const n={app:e,policy:t,serverGroup:a};b.show(o,n,{dialogClassName:"wizard-modal modal-lg"})},d=()=>{const n={application:e,title:`Deleting scaling policy ${l}`},r={type:"deleteScalingPolicy",cloudProvider:i,credentials:a.account,region:a.region,scalingPolicyID:t.id,serverGroupName:a.name};"aws"===i&&(delete r.scalingPolicyID,r.policyName=t.policyName),S.confirm({header:`Really delete ${l}?`,buttonText:"Delete scaling policy",account:a.account,taskMonitorConfig:n,submitMethod:()=>O.executeTask({application:e,description:`Delete scaling policy ${l}`,job:[r]})})};return Ot.createElement("div",{className:"StepPolicySummary"},Ot.createElement("div",null,!Boolean(null==(n=t.alarms)?void 0:n.length)&&Ot.createElement("div",null,"No alarms configured for this policy - it's safe to delete."),Boolean(null==(r=t.alarms)?void 0:r.length)&&t.alarms.map((e=>Ot.createElement("div",{key:`step-summary-${t.policyName}`},Ot.createElement(ne,{Component:()=>Ot.createElement(Wo,{policy:t,serverGroup:a}),placement:"left",title:t.policyName},Ot.createElement("div",null,Ot.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Ot.createElement(Ho,{alarm:e}))),Ot.createElement("div",{className:"actions"},Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:c},Ot.createElement("span",{className:"glyphicon glyphicon-cog"}),Ot.createElement("span",{className:"sr-only"},"Edit policy")),Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:d},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}),Ot.createElement("span",{className:"sr-only"},"Delete policy"))))))))};xr(".TargetTrackingSummary .HoverablePopover {\n min-height: 600px;\n text-decoration: none;\n}\n.TargetTrackingSummary .actions {\n margin: 0 0 15px 0;\n border-bottom: 1px solid var(--color-alto);\n}\n");const Zo=({application:e,policy:t,serverGroup:a})=>{var n,r,i;const s=a.type||a.cloudProvider||"aws",l=V.getValue(s,"serverGroup"),o="aws"===s?t.policyName:t.id,c=l.UpsertTargetTrackingModal,d=l.TargetTrackingChart,u=t.targetTrackingConfiguration;return Ot.createElement("div",{className:"TargetTrackingSummary"},Ot.createElement(ne,{Component:()=>Ot.createElement(d,{config:t.targetTrackingConfiguration,serverGroup:a}),placement:"left",title:o},Ot.createElement("div",null,Ot.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Ot.createElement("div",null,Ot.createElement("b",null,"Target"),Ot.createElement("span",{className:"sp-margin-xs-left"},(null==(n=u.predefinedMetricSpecification)?void 0:n.predefinedMetricType)||(null==(r=u.customizedMetricSpecification)?void 0:r.metricName)),Boolean(null==(i=u.customizedMetricSpecification)?void 0:i.statistic)&&Ot.createElement("span",null,` @ ${u.targetValue}`)))),Ot.createElement("div",{className:"actions"},Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:()=>{const n={app:e,policy:t,serverGroup:a};b.show(c,n,{dialogClassName:"wizard-modal modal-lg"})}},Ot.createElement("span",{className:"glyphicon glyphicon-cog"}),Ot.createElement("span",{className:"sr-only"},"Edit policy")),Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:()=>{const n={application:e,title:`Deleting scaling policy ${o}`},r={type:"deleteScalingPolicy",cloudProvider:s,credentials:a.account,region:a.region,scalingPolicyID:t.id,serverGroupName:a.name};"aws"===s&&(delete r.scalingPolicyID,r.policyName=t.policyName),S.confirm({header:`Really delete ${o}?`,buttonText:"Delete scaling policy",account:a.account,taskMonitorConfig:n,submitMethod:()=>O.executeTask({application:e,description:`Delete scaling policy ${o}`,job:[r]})})}},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}),Ot.createElement("span",{className:"sr-only"},"Delete policy"))))},_o=({application:e,policy:t,serverGroup:a})=>"TargetTrackingScaling"===(t.policyType?t.policyType:t.targetTrackingConfiguration?"TargetTrackingScaling":"StepScaling")?Ot.createElement(Zo,{application:e,policy:t,serverGroup:a}):Ot.createElement(jo,{application:e,policy:t,serverGroup:a});class Ko extends Vt.Component{constructor(){super(...arguments),this.editAdvancedSettings=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/advancedSettings/editAsgAdvancedSettings.modal.html",controller:"EditAsgAdvancedSettingsCtrl as ctrl",resolve:{application:()=>e,serverGroup:()=>t}})))}}render(){const{serverGroup:e}=this.props,t=e.asg;return Vt.createElement(x,{heading:"Advanced Settings"},Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},Vt.createElement("dt",null,"Cooldown"),Vt.createElement("dd",null,t.defaultCooldown," seconds"),t.enabledMetrics.length>0&&[Vt.createElement("dt",{key:"t-metrics"},"Enabled Metrics"),Vt.createElement("dd",{key:"d-metrics"},t.enabledMetrics.map((e=>e.metric)).join(", "))],Vt.createElement("dt",null,"Health Check Type"),Vt.createElement("dd",null,t.healthCheckType),Vt.createElement("dt",null,"Grace Period"),Vt.createElement("dd",null,t.healthCheckGracePeriod," seconds"),Vt.createElement("dt",null,"Termination Policies"),Vt.createElement("dd",null,t.terminationPolicies.join(", ")),t.capacityRebalance&&[Vt.createElement("dt",null,"Capacity Rebalance ",Vt.createElement(n,{id:"aws.serverGroup.capacityRebalance"})),Vt.createElement("dd",null,`${t.capacityRebalance}`)]),kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:this.editAdvancedSettings},"Edit Advanced Settings"))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/advancedSettings/editAsgAdvancedSettings.modal.html",'<div modal-page>\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form" name="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Edit Advanced Settings for {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Cooldown</b></div>\n <div class="col-md-2">\n <input type="number" required class="form-control input-sm" ng-model="command.cooldown" />\n </div>\n seconds\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right">\n <b>Enabled Metrics</b>\n <help-field key="aws.serverGroup.enabledMetrics"></help-field>\n </div>\n <div class="col-md-6">\n <ui-select multiple ng-model="command.enabledMetrics" class="form-control input-sm">\n <ui-select-match>{{$item}}</ui-select-match>\n <ui-select-choices\n repeat="enabledMetric in command.backingData.enabledMetrics | filter: $select.search | orderBy: \'toString()\'"\n >\n <span ng-bind-html="enabledMetric | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Health Check Type</b></div>\n <div class="col-md-6">\n <ui-select ng-model="command.healthCheckType" class="form-control input-sm">\n <ui-select-match placeholder="Select...">{{$select.selected}}</ui-select-match>\n <ui-select-choices\n repeat="healthCheckType in command.backingData.healthCheckTypes | filter: $select.search"\n >\n <span ng-bind-html="healthCheckType | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Health Check Grace Period</b></div>\n <div class="col-md-2">\n <input type="text" required class="form-control input-sm" ng-model="command.healthCheckGracePeriod" />\n </div>\n seconds\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Termination Policies</b></div>\n <div class="col-md-6">\n <ui-select multiple ng-model="command.terminationPolicies" class="form-control input-sm">\n <ui-select-match>{{$item}}</ui-select-match>\n <ui-select-choices\n repeat="terminationPolicy in command.backingData.terminationPolicies | filter: $select.search | orderBy: \'toString()\'"\n >\n <span ng-bind-html="terminationPolicy | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right">\n <b>Capacity Rebalance</b><help-field key="aws.serverGroup.capacityRebalance" />\n </div>\n <div class="col-md-6">\n <input type="checkbox" ng-model="command.capacityRebalance" /> Enable capacity rebalance\n </div>\n </div>\n </div>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <button type="submit" class="btn btn-primary" ng-disabled="form.$invalid" ng-click="ctrl.submit()">Submit</button>\n </div>\n </form>\n</div>\n')}]);class Yo extends Vt.Component{constructor(e){super(e),this.state={changeConfig:this.getChangeConfig(e.serverGroup)}}getChangeConfig(e){const t={metadata:ia(e.entityTags,"creationMetadata")};return wa(e,"buildInfo.jenkins")&&(t.buildInfo={ancestor:void 0,jenkins:e.buildInfo.jenkins,target:void 0}),t}componentWillReceiveProps(e){this.setState({changeConfig:this.getChangeConfig(e.serverGroup)})}render(){const{serverGroup:e}=this.props,{changeConfig:t}=this.state,n=a.feature&&a.feature.entityTags,r=e.entityTags||{};return Vt.createElement(x,{heading:"Server Group Information",defaultExpanded:!0},Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Created"),Vt.createElement("dd",null,z(e.createdTime)),n&&Vt.createElement(xt,{metadata:r.creationMetadata}),n&&Vt.createElement(Pt,{changeConfig:t,linkText:"view changes",nameItem:e,viewType:"description"}),Vt.createElement("dt",null,"In"),Vt.createElement("dd",null,Vt.createElement(G,{account:e.account}),e.region),Vt.createElement("dt",null,"VPC"),Vt.createElement("dd",null,Vt.createElement(yr,{vpcId:e.vpcId})),e.vpcId&&e.subnetType&&Vt.createElement("dt",null,"Subnet"),e.vpcId&&e.subnetType&&Vt.createElement("dd",null,e.subnetType),e.asg&&Vt.createElement("dt",null,"Zones"),e.asg&&Vt.createElement("dd",null,Vt.createElement("ul",null,e.asg.availabilityZones.map((e=>Vt.createElement("li",{key:e},e)))))))}}var Xo=Object.defineProperty,Jo=Object.getOwnPropertyDescriptor;let Qo=class extends Vt.Component{render(){const{serverGroup:e,app:t}=this.props,a={min:e.asg.minSize,max:e.asg.maxSize,desired:e.asg.desiredCapacity};return Vt.createElement(x,{heading:"Capacity",defaultExpanded:!0},Vt.createElement(Dt,{current:e.instances.length,capacity:a}),Vt.createElement("div",null,kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:()=>mo.show({application:t,serverGroup:e})},"Resize Server Group")),Vt.createElement("div",null,Vt.createElement(Bt,{serverGroup:e})))}};Qo=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Jo(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&Xo(t,a,i),i})([ie("amazon.serverGroup.CapacityDetailsSection")],Qo);class ec extends Vt.Component{render(){const{serverGroup:e}=this.props;return e.instanceCounts.total>0?Vt.createElement(x,{heading:"Health",defaultExpanded:!0},Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Instances"),Vt.createElement("dd",null,Vt.createElement(X,{container:e.instanceCounts,className:"pull-left"})))):null}}const tc=({serverGroup:e})=>{if(!e.mixedInstancesPolicy)return null;const t=e.mixedInstancesPolicy.instancesDistribution;return Vt.createElement(x,{heading:"Instances Distribution"},Vt.createElement(W,{className:"horizontal-when-filters-collapsed"},Vt.createElement(B,{label:"On-Demand Allocation Strategy",helpFieldId:"aws.serverGroup.odAllocationStrategy",value:t.onDemandAllocationStrategy}),Vt.createElement(B,{label:"On-Demand Base Capacity",helpFieldId:"aws.serverGroup.odBase",value:t.onDemandBaseCapacity}),Vt.createElement(B,{label:"On-Demand Percentage Above Base Capacity",helpFieldId:"aws.serverGroup.odPercentAboveBase",value:t.onDemandPercentageAboveBaseCapacity}),Vt.createElement(B,{label:"Spot Allocation Strategy",helpFieldId:"aws.serverGroup.spotAllocationStrategy",value:t.spotAllocationStrategy}),t.spotInstancePools&&Vt.createElement(B,{label:"Spot Instance Pools",helpFieldId:"aws.serverGroup.spotInstancePoolCount",value:t.spotInstancePools}),Vt.createElement(B,{label:"Max Spot Price",helpFieldId:"aws.serverGroup.spotMaxPrice",value:t.spotMaxPrice||"on-demand price, default"})))},ac=e=>{let t;return(e||"").split(", ").forEach((e=>{const a=e.split("=");2===a.length&&"ancestor_name"===a[0]&&(t=a[1])})),t};class nc extends Vt.Component{constructor(e){super(e),this.state={image:this.getImage(e.serverGroup)}}getImage(e){const t=e.image?e.image:void 0;return e.image&&e.image.description&&(t.baseImage=ac(e.image.description)),t}componentWillReceiveProps(e){this.setState({image:this.getImage(e.serverGroup)})}render(){const{name:e,launchConfig:t}=this.props.serverGroup,{image:a}=this.state;return t?Vt.createElement(x,{heading:"Launch Configuration"},Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},Vt.createElement("dt",null,"Name"),Vt.createElement("dd",null,t.launchConfigurationName),Vt.createElement("dt",null,"Image ID"),Vt.createElement("dd",null,t.imageId),a&&a.imageLocation&&Vt.createElement("dt",null,"Image Name"),a&&a.imageLocation&&Vt.createElement("dd",null,a.imageLocation),a&&a.baseImage&&Vt.createElement("dt",null,"Base Image Name"),a&&a.baseImage&&Vt.createElement("dd",null,a.baseImage),Vt.createElement("dt",null,"Instance Type"),Vt.createElement("dd",null,t.instanceType),Vt.createElement("dt",null,"IAM Profile"),Vt.createElement("dd",null,t.iamInstanceProfile),t.instanceMonitoring&&Vt.createElement(Vt.Fragment,null,Vt.createElement("dt",null,"Instance Monitoring"),Vt.createElement("dd",null,t.instanceMonitoring.enabled?"enabled":"disabled")),t.spotPrice&&Vt.createElement("dt",null,"Spot Price"),t.spotPrice&&Vt.createElement("dd",null,t.spotPrice),t.keyName&&Vt.createElement("dt",null,"Key Name"),t.keyName&&Vt.createElement("dd",null,t.keyName),t.kernelId&&Vt.createElement("dt",null,"Kernel ID"),t.kernelId&&Vt.createElement("dd",null,t.kernelId),t.ramdiskId&&Vt.createElement("dt",null,"Ramdisk ID"),t.ramdiskId&&Vt.createElement("dd",null,t.ramdiskId),Vt.createElement("dt",null,"User Data"),t.userData&&Vt.createElement("dd",null,Vt.createElement(zt,{serverGroupName:e,userData:t.userData})),!t.userData&&Vt.createElement("dd",null,"[none]"))):null}}function rc(e){return e.instanceTypeOverrides?Vt.createElement(x,{heading:"Instance Types",defaultExpanded:!0,outerDivClassName:"multiple-instance-types-subsection",toggleClassName:"clickable subsection-heading",headingClassName:"collapsible-subheading"},Vt.createElement("table",{className:"table table-condensed packed",id:"MultipleInstanceTypes"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{id:"instanceType"},"Type ",Vt.createElement(n,{id:"aws.serverGroup.multipleInstanceTypes"})),Vt.createElement("th",{id:"weight"},"Weighted Capacity ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})))),Vt.createElement("tbody",null,e.instanceTypeOverrides.map((e=>[Vt.createElement("tr",{key:e.instanceType},Vt.createElement("td",{headers:"instanceType"},e.instanceType),Vt.createElement("td",{headers:"weight"},e.weightedCapacity))]))))):null}xr('.multiple-instance-types-subsection {\n padding: 0;\n}\n.multiple-instance-types-subsection a.subsection-heading {\n color: var(--color-black);\n}\n.multiple-instance-types-subsection h4.collapsible-subheading {\n padding: 10px 0px;\n background-color: var(--color-alabaster);\n margin: 0;\n font-size: 103%;\n font-weight: 600;\n text-transform: none;\n}\n.multiple-instance-types-subsection h4.collapsible-subheading .glyphicon {\n font-size: 10px;\n opacity: 0.5;\n margin-right: 4px;\n}\n.multiple-instance-types-subsection .content-body {\n animation: 0.15 ease-in 0 fadeIn;\n animation-iteration-count: 1;\n padding-left: 17px;\n margin: 10px 0 20px 0;\n}\n.multiple-instance-types-subsection .content-body:before,\n.multiple-instance-types-subsection .content-body:after {\n display: table;\n content: " ";\n}\n.multiple-instance-types-subsection .content-body:after {\n clear: both;\n}\n.multiple-instance-types-subsection .content-body ul {\n list-style-type: none;\n padding-left: 0;\n}\n.multiple-instance-types-subsection:last-child {\n border-bottom-width: 0;\n}\n.multiple-instance-types-subsection:first-child {\n padding-top: 0;\n}\n');const ic=({serverGroup:e})=>{var t,a,n;const{image:r}=e,i=ac(null==r?void 0:r.description);if(!e.launchTemplate&&!e.mixedInstancesPolicy)return null;const s=!!e.mixedInstancesPolicy,l=s?e.mixedInstancesPolicy.launchTemplates[0]:e.launchTemplate,{launchTemplateData:o}=l,c=s?e.mixedInstancesPolicy.instancesDistribution.spotMaxPrice:null==(a=null==(t=null==o?void 0:o.instanceMarketOptions)?void 0:t.spotOptions)?void 0:a.maxPrice,d=null==(n=null==o?void 0:o.creditSpecification)?void 0:n.cpuCredits,u=s?e.mixedInstancesPolicy.launchTemplateOverridesForInstanceType:null;return Vt.createElement(x,{heading:"Launch Template"},Vt.createElement(W,{className:"horizontal-when-filters-collapsed"},Vt.createElement(B,{label:"Name",value:l.launchTemplateName}),Vt.createElement(B,{label:"Image ID",value:o.imageId}),(null==r?void 0:r.imageLocation)&&Vt.createElement(B,{label:"Image Name",value:null==r?void 0:r.imageLocation}),i&&Vt.createElement(B,{label:"Base Image Name",value:i}),u&&u.length>0?Vt.createElement(rc,{instanceTypeOverrides:u}):Vt.createElement(B,{label:"Instance Type",value:o.instanceType}),d&&Vt.createElement(B,{label:"CPU Credit Specification",value:d}),Vt.createElement(B,{label:"IAM Profile",value:o.iamInstanceProfile.name}),o.monitoring&&Vt.createElement(B,{label:"Instance Monitoring",value:o.monitoring.enabled?"enabled":"disabled"}),c&&Vt.createElement(B,{label:"Max Spot Price",value:c}),o.keyName&&Vt.createElement(B,{label:"Key Name",value:o.keyName}),o.kernelId&&Vt.createElement(B,{label:"Kernel ID",value:o.kernelId}),o.ramDiskId&&Vt.createElement(B,{label:"Ramdisk ID",value:o.ramDiskId}),o.userData&&Vt.createElement(B,{label:"User Data",value:Vt.createElement(zt,{serverGroupName:e.name,userData:o.userData})})))};class sc extends Vt.Component{render(){return Vt.createElement(x,{heading:"Logs"},Vt.createElement("ul",null,Vt.createElement("li",null,Vt.createElement(Bt,{serverGroup:this.props.serverGroup}))))}}class lc extends Vt.Component{constructor(e){super(e),this.state=this.getState(e)}getState(e){const{serverGroup:t}=e,a=t.buildInfo||{};let n=null;a.commit&&(n=t.buildInfo.commit.substring(0,8));let r=null;if(a.buildInfoUrl)r=t.buildInfo.buildInfoUrl;else if(a.jenkins){const e=t.buildInfo.jenkins;r=`${e.host}job/${e.name}/${e.number}`}return{commitHash:n,jenkinsLink:r}}componentWillReceiveProps(e){this.setState(this.getState(e))}render(){const{serverGroup:e}=this.props,{commitHash:t,jenkinsLink:a}=this.state;return e.buildInfo&&e.buildInfo.jenkins?Vt.createElement(x,{heading:"Package"},Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},Vt.createElement("dt",null,"Job"),Vt.createElement("dd",null,e.buildInfo.jenkins.name),Vt.createElement("dt",null,"Package"),Vt.createElement("dd",null,e.buildInfo.package_name),Vt.createElement("dt",null,"Build"),Vt.createElement("dd",null,e.buildInfo.jenkins.number),Vt.createElement("dt",null,"Commit"),Vt.createElement("dd",null,t),Vt.createElement("dt",null,"Version"),Vt.createElement("dd",null,e.buildInfo.version),Vt.createElement("dt",null,"Build Link"),Vt.createElement("dd",null,Vt.createElement("a",{target:"_blank",href:a},a)))):null}}var oc=Object.defineProperty,cc=Object.getOwnPropertyDescriptor;let dc=class extends Vt.Component{constructor(e){super(e)}static arePoliciesDisabled(e){const t=yo.normalizeScalingProcesses(e);return e.scalingPolicies.length>0&&t.filter((e=>!e.enabled)).some((e=>["Launch","Terminate","AlarmNotification"].includes(e.name)))}render(){const{app:e,serverGroup:t}=this.props,a=dc.arePoliciesDisabled(t);return Vt.createElement(x,{cacheKey:"Scaling Policies",heading:({chevron:e})=>Vt.createElement("h4",{className:"collapsible-heading"},e,Vt.createElement("span",null,a&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Policies"))},a&&Vt.createElement("div",{className:"band band-warning"},"Some scaling processes are disabled that may prevent scaling policies from working."),t.scalingPolicies.map((a=>Vt.createElement(_o,{key:a.policyARN,policy:a,serverGroup:t,application:e}))),kn.adHocInfraWritesEnabled?Vt.createElement(Vo,{serverGroup:t,application:e}):Vt.createElement("p",null,"Can not create scaling policy, because ad-hoc operations are disabled for AWS providers."))}};dc=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?cc(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=(n?r(t,a,i):r(i))||i);return n&&i&&oc(t,a,i),i})([ie("aws.serverGroup.ScalingPoliciesDetailsSection")],dc);class uc extends Vt.Component{constructor(e){super(e),this.toggleScalingProcesses=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/scalingProcesses/modifyScalingProcesses.html",controller:"ModifyScalingProcessesCtrl as ctrl",resolve:{serverGroup:()=>t,application:()=>e,processes:()=>this.state.autoScalingProcesses}})))},this.state=this.getState(e)}getState(e){const{serverGroup:t}=e,a=yo.normalizeScalingProcesses(t),n=t.scalingPolicies.length>0&&a.filter((e=>!e.enabled)).some((e=>["Launch","Terminate","AlarmNotification"].includes(e.name))),r=t.scheduledActions.length>0&&a.filter((e=>!e.enabled)).some((e=>["Launch","Terminate","ScheduledAction"].includes(e.name)));return{autoScalingProcesses:a,scalingPoliciesDisabled:n,scheduledActionsDisabled:r}}componentWillReceiveProps(e){this.setState(this.getState(e))}render(){const{autoScalingProcesses:e,scalingPoliciesDisabled:t,scheduledActionsDisabled:a}=this.state;return Vt.createElement(x,{cacheKey:"Scaling Processes",heading:({chevron:e})=>Vt.createElement("h4",{className:"collapsible-heading"},e,Vt.createElement("span",null,t&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),a&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Processes"))},Vt.createElement("ul",{className:"scaling-processes"},e.map((e=>Vt.createElement("li",{key:e.name},Vt.createElement("span",{style:{visibility:e.enabled?"visible":"hidden"},className:"fa fa-check small"}),Vt.createElement("span",{className:e.enabled?"":"text-disabled"},e.name," "),Vt.createElement(n,{content:e.description,placement:"bottom"}),e.suspensionDate&&Vt.createElement("div",{className:"text-disabled small",style:{marginLeft:"35px"}},"Suspended ",z(e.suspensionDate)))))),kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:this.toggleScalingProcesses},"Edit Scaling Processes"))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/scalingProcesses/modifyScalingProcesses.html",'<div modal-page class="confirmation-modal">\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Modify Scaling Processes for {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-sm-offset-2 col-sm-10">\n <div class="checkbox" ng-repeat="process in command">\n <label>\n <input type="checkbox" ng-model="process.enabled" />\n {{process.name}}\n </label>\n <help-field content="{{process.description}}" placement="right"></help-field>\n </div>\n </div>\n </div>\n </div>\n <task-reason command="command"></task-reason>\n <aws-footer\n action="ctrl.submit()"\n cancel="ctrl.cancel()"\n is-valid="ctrl.isValid()"\n account="serverGroup.account"\n verification="verification"\n ></aws-footer>\n </form>\n</div>\n')}]);class pc extends Vt.Component{render(){const{action:e}=this.props;return Vt.createElement("dl",{className:"horizontal-when-filters-collapsed",style:{marginBottom:"20px"}},Vt.createElement("dt",null,"Schedule"),Vt.createElement("dd",null,e.recurrence),void 0!==e.minSize&&Vt.createElement("dt",null,"Min Size"),void 0!==e.minSize&&Vt.createElement("dd",null,e.minSize),void 0!==e.maxSize&&Vt.createElement("dt",null,"Max Size"),void 0!==e.maxSize&&Vt.createElement("dd",null,e.maxSize),void 0!==e.desiredCapacity&&Vt.createElement("dt",null,"Desired Size"),void 0!==e.desiredCapacity&&Vt.createElement("dd",null,e.desiredCapacity))}}class mc extends Vt.Component{constructor(e){super(e),this.editScheduledActions=()=>{Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/scheduledAction/editScheduledActions.modal.html",controller:"EditScheduledActionsCtrl as ctrl",resolve:{application:()=>this.props.app,serverGroup:()=>this.props.serverGroup}})},this.state=this.getState(e)}getState(e){const{serverGroup:t}=e,a=yo.normalizeScalingProcesses(t);return{scheduledActionsDisabled:t.scheduledActions.length>0&&a.filter((e=>!e.enabled)).some((e=>["Launch","Terminate","ScheduledAction"].includes(e.name)))}}componentWillReceiveProps(e){this.setState(this.getState(e))}render(){const{serverGroup:e}=this.props,{scheduledActionsDisabled:t}=this.state;return Vt.createElement(x,{cacheKey:"Scheduled Actions",heading:({chevron:e})=>Vt.createElement("h4",{className:"collapsible-heading"},e,Vt.createElement("span",null,t&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scheduled Actions"))},e.scheduledActions.map(((e,t)=>Vt.createElement(pc,{key:t,action:e}))),e.scheduledActions.length>0&&Vt.createElement("p",null,Vt.createElement("strong",null,"Note:")," Schedules are evaluated in UTC."),0===e.scheduledActions.length&&Vt.createElement("p",null,"No Scheduled Actions are configured for this server group."),kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:this.editScheduledActions},"Edit Scheduled Actions"))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/scheduledAction/editScheduledActions.modal.html",'<div modal-page>\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form" name="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Edit Scheduled Actions for {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-md-12">\n <p>You must specify at least one of: Min Size, Max Size, Desired Capacity</p>\n <p><strong>Note:</strong> CRON expressions are evaluated in UTC.</p>\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th>Recurrence (CRON)</th>\n <th>Min Size</th>\n <th>Max Size</th>\n <th>Desired Capacity</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="action in command.scheduledActions">\n <td>\n <input\n class="form-control input-sm no-spel"\n type="text"\n ng-model="action.recurrence"\n name="recurrence-{{$index}}"\n required\n />\n \x3c!-- TODO: Add cron-validator when endpoint is fixed --\x3e\n <div class="form-group row slide-in" ng-if="form[\'recurrence-\' + $index].$error.cronExpression">\n <div class="error-message">{{cronErrors[\'action.recurrence.cronExpression\']}}</div>\n </div>\n </td>\n <td>\n <input\n class="form-control input-sm"\n type="number"\n min="0"\n max="{{action.maxSize || Infinity}}"\n ng-model="action.minSize"\n />\n </td>\n <td>\n <input\n class="form-control input-sm"\n type="number"\n min="{{action.minSize || 0}}"\n ng-model="action.maxSize"\n />\n </td>\n <td>\n <input\n class="form-control input-sm"\n type="number"\n ng-model="action.desiredCapacity"\n min="{{command.minSize || 0}}"\n max="{{command.maxSize || Infinity}}"\n />\n </td>\n <td>\n <a href class="sm-label" ng-click="ctrl.removeScheduledAction($index)"\n ><span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addScheduledAction()">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new Scheduled Action\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n </div>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <button type="submit" class="btn btn-primary" ng-disabled="form.$invalid" ng-click="ctrl.submit()">Submit</button>\n </div>\n </form>\n</div>\n')}]);class gc extends Vt.Component{constructor(e){super(e),this.updateSecurityGroups=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/securityGroup/editSecurityGroups.modal.html",controller:"EditSecurityGroupsCtrl as $ctrl",resolve:{application:()=>e,serverGroup:()=>t,securityGroups:()=>this.state.securityGroups}})))},this.state={securityGroups:this.getSecurityGroups(e)}}tryFindingSecurityGroupInIndex(e,t,a,n){try{return bl.resolveIndexedSecurityGroup(e,{account:t,region:a},n)}catch(e){return}}getSecurityGroups(e){let t;const{app:a,serverGroup:n}=e;return n.securityGroups&&n.securityGroups.length&&(t=ta(n.securityGroups).map((e=>ba(a.securityGroups.data,{accountName:n.account,region:n.region,id:e})||ba(a.securityGroups.data,{accountName:n.account,region:n.region,name:e})||this.tryFindingSecurityGroupInIndex(a.securityGroupsIndex,n.account,n.region,e)||{id:e,name:e})).compact().value()),t}componentWillReceiveProps(e){this.setState({securityGroups:this.getSecurityGroups(e)})}render(){const{serverGroup:e}=this.props,{securityGroups:t}=this.state;return Vt.createElement(x,{heading:U.get("Firewalls")},Vt.createElement("ul",null,Qt(t,"name").map((t=>Vt.createElement("li",{key:t.name},Vt.createElement(Qa,{to:"^.firewallDetails",params:{name:t.name,accountId:t.accountName,region:e.region,vpcId:e.vpcId,provider:e.type}},Vt.createElement("a",null,t.name," (",t.id,")")))))),kn.adHocInfraWritesEnabled&&e.vpcId&&Vt.createElement("a",{className:"clickable",onClick:this.updateSecurityGroups},"Edit ",U.get("Firewalls")))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/securityGroup/editSecurityGroups.modal.html",'<div modal-page>\n <task-monitor monitor="$ctrl.taskMonitor"></task-monitor>\n <form role="form" name="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">\n Edit <firewall-label label="Firewalls"></firewall-label> for {{$ctrl.serverGroup.name}}\n </h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-md-10 col-md-offset-1">\n <ui-select\n multiple\n ng-model="$ctrl.command.securityGroups"\n uis-open-close="$ctrl.resetCurrentItems()"\n class="form-control input-sm"\n >\n <ui-select-match>{{$item.name}} ({{$item.id}})</ui-select-match>\n <ui-select-choices\n repeat="securityGroup as securityGroup in $ctrl.availableSecurityGroups | filter: $select.search | limitTo: $ctrl.infiniteScroll.currentItems"\n infinite-scroll="$ctrl.addMoreItems()"\n infinite-scroll-distance="4"\n >\n <span ng-bind-html="securityGroup.name | highlight: $select.search"></span>\n (<span ng-bind-html="securityGroup.id | highlight: $select.search"></span>)\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n </div>\n <aws-footer\n action="$ctrl.submit()"\n cancel="$ctrl.cancel()"\n is-valid="$ctrl.isValid()"\n account="$ctrl.serverGroup.account"\n verification="$ctrl.state.verification"\n ></aws-footer>\n </form>\n</div>\n')}]);class hc extends Vt.Component{render(){const{serverGroup:e}=this.props;return Vt.createElement(x,{heading:"Tags"},0===e.asg.tags.length&&Vt.createElement("div",null,"No tags associated with this server group"),e.asg.tags.length>0&&Vt.createElement("dl",null,Qt(e.asg.tags,"key").map((e=>[Vt.createElement("dt",{key:e.key},e.key),Vt.createElement("dd",{key:e.value},e.value)]))))}}class fc{static listKeyPairs(){return D("/keyPairs").useCache().get().then((e=>e.sort(((e,t)=>e.keyName.localeCompare(t.keyName)))))}}class vc{constructor(e,t,a,n,r){this.securityGroupReader=e,this.awsInstanceTypeService=t,this.cacheInitializer=a,this.loadBalancerReader=n,this.serverGroupCommandRegistry=r,this.enabledMetrics=["GroupMinSize","GroupMaxSize","GroupDesiredCapacity","GroupInServiceInstances","GroupPendingInstances","GroupStandbyInstances","GroupTerminatingInstances","GroupTotalInstances"],this.healthCheckTypes=["EC2","ELB"],this.terminationPolicies=["OldestInstance","NewestInstance","OldestLaunchConfiguration","ClosestToNextInstanceHour","Default"]}configureUpdateCommand(e){e.backingData={enabledMetrics:Ca(this.enabledMetrics),healthCheckTypes:Ca(this.healthCheckTypes),terminationPolicies:Ca(this.terminationPolicies)}}configureCommand(e,t){return this.applyOverrides("beforeConfiguration",t),t.toggleSuspendedProcess=(e,t)=>{e.suspendedProcesses=e.suspendedProcesses||[];const a=e.suspendedProcesses.indexOf(t);e.suspendedProcesses=-1===a?e.suspendedProcesses.concat(t):e.suspendedProcesses.filter((e=>e!==t))},t.processIsSuspended=(e,t)=>e.suspendedProcesses.includes(t),t.onStrategyChange=(e,t)=>{var a;(null==(a=kn.serverGroups)?void 0:a.enableLaunchTemplates)&&(e.setLaunchTemplate="rollingpush"===t.key||void 0),""!==t.key&&"custom"!==t.key&&(e.suspendedProcesses=(e.suspendedProcesses||[]).filter((e=>"AddToLoadBalancer"!==e)))},t.getBlockDeviceMappingsSource=e=>e.copySourceCustomBlockDeviceMappings?"source":e.useAmiBlockDeviceMappings?"ami":"default",t.selectBlockDeviceMappingsSource=(e,t)=>{"source"===t?(e.copySourceCustomBlockDeviceMappings=!0,e.useAmiBlockDeviceMappings=!1):"ami"===t?(e.copySourceCustomBlockDeviceMappings=!1,e.useAmiBlockDeviceMappings=!0):(e.copySourceCustomBlockDeviceMappings=!1,e.useAmiBlockDeviceMappings=!1)},t.regionIsDeprecated=e=>wa(e,"backingData.filtered.regions")&&e.backingData.filtered.regions.some((t=>t.name===e.region&&t.deprecated)),Xa.all([o.getCredentialsKeyedByAccount("aws"),this.securityGroupReader.getAllSecurityGroups(),g.listSubnets(),o.getPreferredZonesByAccount("aws"),fc.listKeyPairs(),this.awsInstanceTypeService.getAllTypesByRegion(),Xa.when(Ca(this.enabledMetrics)),Xa.when(Ca(this.healthCheckTypes)),Xa.when(Ca(this.terminationPolicies))]).then((([a,n,r,i,s,l,o,c,d])=>{var u,p;const m={credentialsKeyedByAccount:a,securityGroups:n,subnets:r,preferredZones:i,keyPairs:s,instanceTypesInfo:l,enabledMetrics:o,healthCheckTypes:c,terminationPolicies:d};let g=Xa.when();if(m.accounts=Sa(m.credentialsKeyedByAccount),m.filtered={},m.scalingProcesses=yo.listProcesses(),m.appLoadBalancers=e.getDataSource("loadBalancers").data,m.managedResources=null==(p=null==(u=e.getDataSource("managedResources"))?void 0:u.data)?void 0:p.resources,t.backingData=m,this.configureVpcId(t),m.filtered.securityGroups=this.getRegionalSecurityGroups(t),t.viewState.disableImageSelection&&this.configureInstanceTypes(t),t.securityGroups&&t.securityGroups.length){const e=aa(this.getRegionalSecurityGroups(t),"id");va(t.securityGroups,e).length<t.securityGroups.length&&(g=this.refreshSecurityGroups(t,!0))}return g.then((()=>{this.applyOverrides("afterConfiguration",t),this.attachEventHandlers(t)}))}))}applyOverrides(e,t){this.serverGroupCommandRegistry.getCommandOverrides("aws").forEach((a=>{a[e]&&a[e](t)}))}configureKeyPairs(e){const t={dirty:{}};if(e.credentials&&e.region){const a=oa(e.backingData.credentialsKeyedByAccount,(t=>t.defaultKeyPair&&e.keyPair&&0===e.keyPair.indexOf(t.defaultKeyPair.replace("{{region}}","")))),n=ta(e.backingData.keyPairs).filter({account:e.credentials,region:e.region}).map("keyName").value();if(e.keyPair&&n.length&&!n.includes(e.keyPair)){const r=e.backingData.credentialsKeyedByAccount[e.credentials]||{regions:[],defaultKeyPair:null};if(r.defaultKeyPair){const i=r.defaultKeyPair.replace("{{region}}",e.region);a&&n.includes(i)?e.keyPair=i:(e.keyPair=null,t.dirty.keyPair=!0)}else e.keyPair=null,t.dirty.keyPair=!0}e.backingData.filtered.keyPairs=n}else e.backingData.filtered.keyPairs=[];return t}configureInstanceTypes(e){const t={dirty:{}};if(e.region&&(e.virtualizationType||e.viewState.disableImageSelection)){let a=this.awsInstanceTypeService.getAvailableTypesForRegions(e.backingData.instanceTypesInfo,[e.region]);(e.virtualizationType||e.amiArchitecture)&&(a=this.awsInstanceTypeService.filterInstanceTypes(a,e.virtualizationType,!!e.vpcId,e.amiArchitecture));const n=aa(a,"name");e.instanceType&&!n.includes(e.instanceType)&&(t.dirty.instanceType=e.instanceType,e.instanceType=null);const r=aa(e.launchTemplateOverridesForInstanceType,"instanceType"),i=va(r,n),s=la(r,i);e.launchTemplateOverridesForInstanceType&&s.length>0&&(t.dirty.launchTemplateOverridesForInstanceType=e.launchTemplateOverridesForInstanceType.filter((e=>s.includes(e.instanceType))),e.launchTemplateOverridesForInstanceType=e.launchTemplateOverridesForInstanceType.filter((e=>i.includes(e.instanceType)))),e.backingData.filtered.instanceTypes=n,e.backingData.filtered.instanceTypesInfo=a}else e.backingData.filtered.instanceTypes=[],e.backingData.filtered.instanceTypesInfo=[];return ha(e.viewState.dirty,t.dirty),t}configureImages(e){const t={dirty:{}};return e.amiName||(e.virtualizationType=null,e.amiArchitecture=null),e.viewState.disableImageSelection||e.amiName&&!e.region&&(t.dirty.amiName=!0,e.amiName=null),t}configureAvailabilityZones(e){e.backingData.filtered.availabilityZones=ba(e.backingData.credentialsKeyedByAccount[e.credentials].regions,{name:e.region}).availabilityZones}configureSubnetPurposes(e){const t={dirty:{}},a=e.backingData.filtered;return null===e.region||(a.subnetPurposes=ta(e.backingData.subnets).filter({account:e.credentials,region:e.region}).reject({target:"elb"}).reject({purpose:null}).uniqBy("purpose").value(),ta(a.subnetPurposes).some({purpose:e.subnetType}).value()||(e.subnetType=null,t.dirty.subnetType=!0)),t}getRegionalSecurityGroups(e){const t=e.backingData.securityGroups[e.credentials]||{aws:{}};return ta(t.aws[e.region]).filter({vpcId:e.vpcId||null}).sortBy("name").value()}configureSecurityGroupOptions(e){const t={dirty:{}},a=e.backingData.filtered.securityGroups,n=this.getRegionalSecurityGroups(e),r="string"==typeof e.securityGroups&&e.securityGroups.includes("${");if(a&&e.securityGroups&&!r){const r=e.securityGroups.map((e=>{const t=ba(a,{id:e});return t?t.name:e})),i=e.securityGroups.map((e=>{const t=ba(a,{id:e})||ba(a,{name:e});return t?t.name:null})).map((e=>ba(n,{name:e}))).filter((e=>e)),s=aa(i,"name"),l=ka(r,s);e.securityGroups=aa(i,"id"),l.length&&(t.dirty.securityGroups=l)}return e.backingData.filtered.securityGroups=n.sort(((e,t)=>e.name.localeCompare(t.name))),t}refreshSecurityGroups(e,t){return this.cacheInitializer.refreshCache("securityGroups").then((()=>this.securityGroupReader.getAllSecurityGroups().then((a=>{e.backingData.securityGroups=a,t||this.configureSecurityGroupOptions(e)}))))}getLoadBalancerMap(e){if(e.backingData.loadBalancers)return ta(e.backingData.loadBalancers).map("accounts").flattenDeep().filter({name:e.credentials}).map("regions").flattenDeep().filter({name:e.region}).map("loadBalancers").flattenDeep().value();return(e.backingData.appLoadBalancers||[]).filter((t=>t.region===e.region&&t.account===e.credentials))}getLoadBalancerNames(e){return this.getLoadBalancerMap(e).filter((t=>(!t.loadBalancerType||"classic"===t.loadBalancerType)&&t.vpcId===e.vpcId)).map((e=>e.name)).sort()}getVpcLoadBalancerNames(e){return this.getLoadBalancerMap(e).filter((e=>(!e.loadBalancerType||"classic"===e.loadBalancerType)&&e.vpcId)).map((e=>e.name)).sort()}getTargetGroupNames(e){const t=this.getLoadBalancerMap(e).filter((e=>"classic"!==e.loadBalancerType));return Kt(t.map((e=>e.targetGroups.filter((e=>"instance"===e.targetType))))).map((e=>e.name)).sort()}getValidMatches(e,t){const a=t.filter((e=>e.includes("${"))),n=va(e,t),[r,i]=ua(t,(e=>n.includes(e)||a.includes(e)));return{valid:r,invalid:i,spel:a}}configureLoadBalancerOptions(e){const t={dirty:{}},a=(e.loadBalancers||[]).concat(e.vpcLoadBalancers||[]),n=e.targetGroups||[],r=this.getLoadBalancerNames(e),i=this.getVpcLoadBalancerNames(e),s=this.getTargetGroupNames(e);if(a&&e.loadBalancers){const n=e.vpcId?r:r.concat(i),{valid:s,invalid:l,spel:o}=this.getValidMatches(n,a);e.loadBalancers=va(r.concat(o),s),e.vpcId?delete e.vpcLoadBalancers:e.vpcLoadBalancers=va(i,s),l.length&&(t.dirty.loadBalancers=l),e.viewState.spelLoadBalancers=o||[]}if(n&&e.targetGroups&&!n.includes("${")){const{valid:a,invalid:r,spel:i}=this.getValidMatches(s,n);e.targetGroups=a,r.length&&(t.dirty.targetGroups=r),e.viewState.spelTargetGroups=i||[]}return e.backingData.filtered.loadBalancers=r,e.backingData.filtered.vpcLoadBalancers=i,e.backingData.filtered.targetGroups=s,t}refreshLoadBalancers(e,t){return this.loadBalancerReader.listLoadBalancers("aws").then((a=>{e.backingData.loadBalancers=a,t||this.configureLoadBalancerOptions(e)}))}configureVpcId(e){const t={dirty:{}};if(e.subnetType){const t=ba(e.backingData.subnets,{purpose:e.subnetType,account:e.credentials,region:e.region});e.vpcId=t?t.vpcId:null}else e.vpcId=null,t.dirty.vpcId=!0;return ha(t.dirty,this.configureInstanceTypes(e).dirty),t}attachEventHandlers(e){e.usePreferredZonesChanged=e=>{const t=e.availabilityZones?e.availabilityZones.length:0,a={dirty:{}},n=e.backingData.preferredZones[e.credentials];if(n&&n[e.region]&&e.viewState.usePreferredZones)e.availabilityZones=_t(n[e.region].sort());else{e.availabilityZones=va(e.availabilityZones,e.backingData.filtered.availabilityZones);t!==(e.availabilityZones?e.availabilityZones.length:0)&&(a.dirty.availabilityZones=!0)}return a},e.subnetChanged=e=>{const t=this.configureVpcId(e);return ha(t.dirty,this.configureSecurityGroupOptions(e).dirty),ha(t.dirty,this.configureLoadBalancerOptions(e).dirty),e.viewState.dirty=e.viewState.dirty||{},ha(e.viewState.dirty,t.dirty),t},e.regionChanged=e=>{const t={dirty:{}},a=e.backingData.filtered;return ha(t.dirty,this.configureSubnetPurposes(e).dirty),e.region?(ha(t.dirty,e.subnetChanged(e).dirty),ha(t.dirty,this.configureInstanceTypes(e).dirty),this.configureAvailabilityZones(e),ha(t.dirty,e.usePreferredZonesChanged(e).dirty),ha(t.dirty,this.configureImages(e).dirty),ha(t.dirty,this.configureKeyPairs(e).dirty)):a.regionalAvailabilityZones=null,Mt(e),t},e.clusterChanged=e=>{e.moniker=re.getMoniker(e.application,e.stack,e.freeFormDetails),Mt(e)},e.credentialsChanged=e=>{const t={dirty:{}},a=e.backingData;if(e.credentials){const n=a.credentialsKeyedByAccount[e.credentials]||{regions:[],defaultKeyPair:null};a.filtered.regions=n.regions,oa(a.filtered.regions,{name:e.region})?ha(t.dirty,e.regionChanged(e).dirty):(e.region=null,t.dirty.region=!0)}else e.region=null;return Mt(e),t},e.imageChanged=e=>this.configureInstanceTypes(e),e.instanceTypeChanged=e=>{e.ebsOptimized=this.awsInstanceTypeService.isEbsOptimized(e.instanceType)},e.launchTemplateOverridesChanged=e=>{var t;e.ebsOptimized=null==(t=e.launchTemplateOverridesForInstanceType)?void 0:t.every((e=>this.awsInstanceTypeService.isEbsOptimized(e.instanceType)))},this.applyOverrides("attachEventHandlers",e)}}vc.$inject=["securityGroupReader","awsInstanceTypeService","cacheInitializer","loadBalancerReader","serverGroupCommandRegistry"];const yc="spinnaker.amazon.serverGroup.configure.service";t(yc,[Ge,hr,Ae,st,Ft]).service("awsServerGroupConfigurationService",vc);const bc="spinnaker.amazon.serverGroupCommandBuilder.service";e.module(bc,[$t,yc]).factory("awsServerGroupCommandBuilder",["$q","instanceTypeService","awsServerGroupConfigurationService",function(t,a,n){function i(e,a){a=a||{};const n=o.getCredentialsKeyedByAccount("aws"),r=a.account||e.defaultCredentials.aws||kn.defaults.account,i=a.region||e.defaultRegions.aws||kn.defaults.region,l=a.subnet||kn.defaults.subnetType||"",c=o.getAvailabilityZonesForAccountAndRegion("aws",r,i);return t.all([c,n]).then((function([t,n]){var o,c,d,u,p,m,g,h;const f=n[r],v=f?f.defaultKeyPair:null,y=null!=(d=null==(c=null==(o=e.attributes)?void 0:o.providerSettings)?void 0:c.aws)?d:{};let b=kn.defaults.iamRole||"BaseIAMRole";b=b.replace("{{application}}",e.name);const E=y.useAmiBlockDeviceMappings||!1,w={application:e.name,credentials:r,region:i,strategy:"",capacity:{min:1,max:1,desired:1},targetHealthyDeployPercentage:100,cooldown:10,enabledMetrics:[],healthCheckType:"EC2",healthCheckGracePeriod:600,instanceMonitoring:!1,ebsOptimized:!1,selectedProvider:"aws",iamRole:b,terminationPolicies:["Default"],vpcId:null,subnetType:l,availabilityZones:t,keyPair:v,suspendedProcesses:[],securityGroups:[],stack:"",freeFormDetails:"",spotPrice:"",tags:{},useAmiBlockDeviceMappings:E,copySourceCustomBlockDeviceMappings:!1,viewState:{instanceProfile:"custom",useSimpleInstanceTypeSelector:!0,useAllImageSelection:!1,useSimpleCapacity:!0,usePreferredZones:!0,mode:a.mode||"create",disableStrategySelection:!0,dirty:{},submitButtonLabel:s(a.mode||"create")}};if((null==(u=e.attributes)?void 0:u.platformHealthOnlyShowOverride)&&(null==(p=e.attributes)?void 0:p.platformHealthOnly)&&(w.interestingHealthProviderNames=["Amazon"]),"test"===r&&(null==(m=kn.serverGroups)?void 0:m.enableIPv6)&&(w.associateIPv6Address=!0),null==(g=kn.serverGroups)?void 0:g.enableIMDSv2){const t=kn.serverGroups.defaultIMDSv2AppAgeLimit,a=null==(h=e.attributes)?void 0:h.createTs;w.requireIMDSv2=t&&a&&Number(a)>t}return w}))}function s(e){switch(e){case"createPipeline":return"Add";case"editPipeline":return"Done";case"clone":return"Clone";default:return"Create"}}function l(e){return!(e.onDemandAllocationStrategy||e.onDemandBaseCapacity||e.onDemandPercentageAboveBaseCapacity||e.spotAllocationStrategy||e.spotInstancePools||e.launchTemplateOverridesForInstanceType&&e.launchTemplateOverridesForInstanceType.length>0)}return{buildNewServerGroupCommand:i,buildServerGroupCommandFromExisting:function(n,i,c="clone"){var d,u,p,m;const h=o.getPreferredZonesByAccount("aws"),f=g.listSubnets(),v=re.parseServerGroupName(i.asg.autoScalingGroupName);let y;if(i.mixedInstancesPolicy){const e=null==(d=i.mixedInstancesPolicy)?void 0:d.launchTemplateOverridesForInstanceType;y=e?e.map((e=>e.instanceType)):[null==(m=null==(p=null==(u=i.mixedInstancesPolicy)?void 0:u.launchTemplates[0])?void 0:p.launchTemplateData)?void 0:m.instanceType]}else i.launchTemplate?y=[Ht.get(i,"launchTemplate.launchTemplateData.instanceType")]:i.launchConfig&&(y=[Ht.get(i,"launchConfig.instanceType")]);const b=a.getCategoryForMultipleInstanceTypes("aws",y);return t.all([h,f,b]).then((([t,a,o])=>{var d,u,p,m,g,h,f,y,b,E,w,C,S,k;const N=i.asg.availabilityZones.sort();let T=!1;const I=t[i.account];if(I){const e=I[i.region].sort();T=N.join(",")===e.join(",")}const G=["Launch","Terminate","AddToLoadBalancer"],A=(null!=(p=null==(u=null==(d=n.attributes)?void 0:d.providerSettings)?void 0:u.aws)?p:{}).useAmiBlockDeviceMappings||!1,x={},P=["spinnaker:application","spinnaker:stack","spinnaker:details"];i.asg.tags&&i.asg.tags.filter((e=>!P.includes(e.key))).forEach((e=>{x[e.key]=e.value}));const D={application:n.name,strategy:"",stack:v.stack,freeFormDetails:v.freeFormDetails,credentials:i.account,cooldown:i.asg.defaultCooldown,enabledMetrics:Ht.get(i,"asg.enabledMetrics",[]).map((e=>e.metric)),healthCheckGracePeriod:i.asg.healthCheckGracePeriod,healthCheckType:i.asg.healthCheckType,terminationPolicies:i.asg.terminationPolicies,loadBalancers:i.asg.loadBalancerNames,region:i.region,useSourceCapacity:!1,capacity:{min:i.asg.minSize,max:i.asg.maxSize,desired:i.asg.desiredCapacity},targetHealthyDeployPercentage:100,availabilityZones:N,selectedProvider:"aws",source:{account:i.account,region:i.region,asgName:i.asg.autoScalingGroupName},suspendedProcesses:(i.asg.suspendedProcesses||[]).map((e=>e.processName)).filter((e=>!G.includes(e))),tags:Object.assign({},i.tags,x),targetGroups:i.targetGroups,useAmiBlockDeviceMappings:A,copySourceCustomBlockDeviceMappings:"clone"===c,viewState:{instanceProfile:o,useAllImageSelection:!1,useSimpleCapacity:i.asg.minSize===i.asg.maxSize,usePreferredZones:T,mode:c,submitButtonLabel:s(c),isNew:!1,dirty:{}}};if((null==(m=n.attributes)?void 0:m.platformHealthOnlyShowOverride)&&(null==(g=n.attributes)?void 0:g.platformHealthOnly)&&(D.interestingHealthProviderNames=["Amazon"]),"editPipeline"===c){D.useSourceCapacity=!0,D.viewState.useSimpleCapacity=!1,D.strategy="redblack";const e=r.getStrategy("redblack");e.initializationMethod&&e.initializationMethod(D),D.suspendedProcesses=[]}const B=i.asg.vpczoneIdentifier;if(""!==B){const e=B.split(",")[0],t=a.find((t=>t.id===e));D.subnetType=t.purpose,D.vpcId=t.vpcId}else D.subnetType="",D.vpcId=null;if(i.launchConfig&&(e.extend(D,{instanceType:i.launchConfig.instanceType,iamRole:i.launchConfig.iamInstanceProfile,keyPair:i.launchConfig.keyName,associatePublicIpAddress:i.launchConfig.associatePublicIpAddress,ramdiskId:i.launchConfig.ramdiskId,instanceMonitoring:i.launchConfig.instanceMonitoring&&i.launchConfig.instanceMonitoring.enabled,ebsOptimized:i.launchConfig.ebsOptimized,spotPrice:i.launchConfig.spotPrice}),i.launchConfig.userData&&(D.base64UserData=i.launchConfig.userData),D.viewState.imageId=i.launchConfig.imageId,D.viewState.useSimpleInstanceTypeSelector=!0),i.launchTemplate||i.mixedInstancesPolicy){let t,a;if(i.launchTemplate&&(t=i.launchTemplate.launchTemplateData,a=null==(f=null==(h=t.instanceMarketOptions)?void 0:h.spotOptions)?void 0:f.maxPrice,D.instanceType=t.instanceType,D.viewState.useSimpleInstanceTypeSelector=!0,t.userData&&(D.base64UserData=t.userData)),i.mixedInstancesPolicy){const e=i.mixedInstancesPolicy;t=null==(b=null==(y=null==e?void 0:e.launchTemplates)?void 0:y[0])?void 0:b.launchTemplateData,a=null==(E=null==e?void 0:e.instancesDistribution)?void 0:E.spotMaxPrice,D.securityGroups=t.networkInterfaces?(null!=(w=t.networkInterfaces.find((e=>0===e.deviceIndex)))?w:{}).groups:t.securityGroups,D.onDemandAllocationStrategy=e.instancesDistribution.onDemandAllocationStrategy,D.onDemandBaseCapacity=e.instancesDistribution.onDemandBaseCapacity,D.onDemandPercentageAboveBaseCapacity=e.instancesDistribution.onDemandPercentageAboveBaseCapacity,D.spotAllocationStrategy=e.instancesDistribution.spotAllocationStrategy,D.spotInstancePools=e.instancesDistribution.spotInstancePools,e.launchTemplateOverridesForInstanceType?D.launchTemplateOverridesForInstanceType=function(e){let t=1;return Ht.sortBy(e,["priority"]).map((e=>{const{instanceType:a,weightedCapacity:n}=e;let r;return e.priority?(r=e.priority,t=e.priority+1):r=t++,{instanceType:a,weightedCapacity:n,priority:r}}))}(e.launchTemplateOverridesForInstanceType):D.instanceType=t.instanceType,D.viewState.useSimpleInstanceTypeSelector=l(D)}const n=Ht.get(t,"networkInterfaces[0]"),r=null!=(C=null==n?void 0:n.ipv6AddressCount)?C:0,s=kn.serverGroups,o=i.accountDetails&&"test"===i.accountDetails.environment,c=s&&s.enableIPv6&&s.setIPv6InTest&&o;e.extend(D,{iamRole:t.iamInstanceProfile.name,keyPair:t.keyName,associateIPv6Address:c||Boolean(r),ramdiskId:t.ramdiskId,instanceMonitoring:t.monitoring&&t.monitoring.enabled,ebsOptimized:t.ebsOptimized,spotPrice:a||void 0,requireIMDSv2:Boolean("required"===(null==(S=t.metadataOptions)?void 0:S.httpTokens)),unlimitedCpuCredits:t.creditSpecification?"unlimited"===t.creditSpecification.cpuCredits:void 0}),D.viewState.imageId=t.imageId}if("clone"===c&&i.image&&i.image.name&&(D.amiName=i.image.name),i.launchConfig&&i.launchConfig.securityGroups.length&&(D.securityGroups=i.launchConfig.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.securityGroups.length&&(D.securityGroups=i.launchTemplate.launchTemplateData.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.networkInterfaces){const e=null!=(k=i.launchTemplate.launchTemplateData.networkInterfaces.find((e=>0===e.deviceIndex)))?k:{};D.securityGroups=e.groups}return D}))},buildNewServerGroupCommandForPipeline:function(){return t.when({viewState:{requiresTemplateSelection:!0}})},buildServerGroupCommandFromPipeline:function(n,r){const s=Ht.cloneDeep(r),o=Object.keys(s.availabilityZones)[0],c=s.launchTemplateOverridesForInstanceType?s.launchTemplateOverridesForInstanceType.map((e=>e.instanceType)):[s.instanceType],d=a.getCategoryForMultipleInstanceTypes("aws",c),u={account:s.account,region:o};return t.all([i(n,u),d]).then((function([t,a]){const n=s.availabilityZones[o].join(",")===t.availabilityZones.join(","),r={instanceProfile:a,disableImageSelection:!0,useSimpleCapacity:s.capacity.min===s.capacity.max&&!0!==s.useSourceCapacity,usePreferredZones:n,mode:"editPipeline",submitButtonLabel:"Done",templatingEnabled:!0,existingPipelineCluster:!0,dirty:{},useSimpleInstanceTypeSelector:l(s)},i={region:o,credentials:s.account,availabilityZones:s.availabilityZones[o],iamRole:s.iamRole,viewState:r};return s.strategy=s.strategy||"",e.extend({},t,s,i)}))},buildUpdateServerGroupCommand:function(t){var a,r;const i={type:"modifyAsg",asgs:[{asgName:t.name,region:t.region}],cooldown:t.asg.defaultCooldown,enabledMetrics:(null!=(r=null==(a=t.asg)?void 0:a.enabledMetrics)?r:[]).map((e=>e.metric)),healthCheckGracePeriod:t.asg.healthCheckGracePeriod,healthCheckType:t.asg.healthCheckType,terminationPolicies:e.copy(t.asg.terminationPolicies),credentials:t.account,capacityRebalance:t.asg.capacityRebalance};return n.configureUpdateCommand(i),i}}}]);const Ec="spinnaker.amazon.serverGroup.editAsgAdvancedSettings.modal.controller";t(Ec,[bc]).controller("EditAsgAdvancedSettingsCtrl",["$scope","$uibModalInstance","application","serverGroup","awsServerGroupCommandBuilder",function(e,t,a,n,r){e.command=r.buildUpdateServerGroupCommand(n),e.serverGroup=n,e.taskMonitor=new v({application:a,title:"Update Advanced Settings for "+n.name,modalInstance:t,onTaskComplete:()=>a.serverGroups.refresh()}),this.submit=()=>{const t=[e.command];e.taskMonitor.submit((function(){return O.executeTask({job:t,application:a,description:"Update Advanced Settings for "+n.name})}))},this.cancel=t.dismiss}]);const wc="spinnaker.amazon.serverGroup.details.rollback.controller";t(wc,[Lt]).controller("awsRollbackServerGroupCtrl",["$scope","$uibModalInstance","serverGroupWriter","application","serverGroup","previousServerGroup","disabledServerGroups","allServerGroups",function(e,t,a,n,r,i,s,l){e.serverGroup=r,e.disabledServerGroups=s.sort(((e,t)=>t.name.localeCompare(e.name))),e.allServerGroups=l.sort(((e,t)=>t.name.localeCompare(e.name))),e.verification={};const o=r.capacity.desired;let c,d="EXPLICIT";if(0===l.length&&r.entityTags){const t=ia(r,"entityTags.creationMetadata.value.previousServerGroup");if(t){d="PREVIOUS_IMAGE",e.previousServerGroup={name:t.name,imageName:t.imageName},t.imageId&&t.imageId!==t.imageName&&(e.previousServerGroup.imageId=t.imageId);const a=ia(t,"buildInfo.jenkins.number");a&&(e.previousServerGroup.buildNumber=a)}}c=o<10?100:o<20?90:95,e.command={rollbackType:d,rollbackContext:{rollbackServerGroupName:r.name,restoreServerGroupName:i?i.name:void 0,targetHealthyRollbackPercentage:c,delayBeforeDisableSeconds:0}},e.minHealthy=function(e){return Math.ceil(o*e/100)},n&&n.attributes&&(n.attributes.platformHealthOnlyShowOverride&&n.attributes.platformHealthOnly&&(e.command.interestingHealthProviderNames=["Amazon"]),e.command.platformHealthOnlyShowOverride=n.attributes.platformHealthOnlyShowOverride),this.isValid=function(){const t=e.command;return!!e.verification.verified&&("PREVIOUS_IMAGE"===d||void 0!==t.rollbackContext.restoreServerGroupName)},e.taskMonitor=new v({application:n,title:"Rollback "+r.name,modalInstance:t}),this.rollback=function(){if(!this.isValid())return;e.taskMonitor.submit((function(){return a.rollbackServerGroup(r,n,e.command)}))},this.cancel=function(){t.dismiss()},this.label=function(e){return e?e.buildInfo&&e.buildInfo.jenkins&&e.buildInfo.jenkins.number?e.name+" (build #"+e.buildInfo.jenkins.number+")":e.name:""},this.group=function(e){return e.isDisabled?"Disabled Server Groups":"Enabled Server Groups"}}]);const Cc="spinnaker.amazon.scalingPolicy.scalingPolicySummary.component";t(Cc,[]).component("scalingPolicySummary",Ja(L(_o,"scalingPolicySummary"),["application","policy","serverGroup"]));const Sc="spinnaker.amazon.scalingPolicy.module";t(Sc,[Cc]);const kc="spinnaker.amazon.serverGroup.details.autoscaling.process.controller";e.module(kc,[]).controller("ModifyScalingProcessesCtrl",["$scope","$uibModalInstance","application","serverGroup","processes",function(t,a,n,r,i){t.command=e.copy(i),t.serverGroup=r,t.verification={},this.isValid=function(){return!!t.verification.verified&&this.isDirty()};const s=Ht.chain(t.command).filter({enabled:!0}).map("name").value(),l=Ht.chain(t.command).filter({enabled:!1}).map("name").value();this.isDirty=function(){const e=Ht.chain(t.command).filter({enabled:!0}).map("name").value(),a=Ht.chain(t.command).filter({enabled:!1}).map("name").value(),n=Ht.intersection(l,e),r=Ht.intersection(s,a);return!(!n.length&&!r.length)},t.taskMonitor=new v({application:n,title:"Update Auto Scaling Processes for "+r.name,modalInstance:a,onTaskComplete:()=>n.serverGroups.refresh()}),this.submit=function(){const e=Ht.chain(t.command).filter({enabled:!0}).map("name").value(),a=Ht.chain(t.command).filter({enabled:!1}).map("name").value(),i=Ht.intersection(l,e),o=Ht.intersection(s,a),c=[];i.length&&c.push({type:"modifyScalingProcess",action:"resume",processes:i,asgName:r.name,regions:[r.region],credentials:r.account,cloudProvider:"aws",reason:t.command.reason}),o.length&&c.push({type:"modifyScalingProcess",action:"suspend",processes:o,asgName:r.name,regions:[r.region],credentials:r.account,cloudProvider:"aws",reason:t.command.reason});t.taskMonitor.submit((function(){return O.executeTask({job:c,application:n,description:"Update Auto Scaling Processes for "+r.name})}))},this.cancel=a.dismiss}]);const Nc="spinnaker.amazon.serverGroup.details.scheduledActions.editScheduledActions.modal.controller";t(Nc,[]).controller("EditScheduledActionsCtrl",["$scope","$uibModalInstance","application","serverGroup",function(e,t,a,n){e.command={scheduledActions:n.scheduledActions.map((e=>({recurrence:e.recurrence,minSize:e.minSize,maxSize:e.maxSize,desiredCapacity:e.desiredCapacity})))},e.serverGroup=n,this.addScheduledAction=()=>{e.command.scheduledActions.push({})},this.removeScheduledAction=t=>{e.command.scheduledActions.splice(t,1)},e.taskMonitor=new v({application:a,title:"Update Scheduled Actions for "+n.name,modalInstance:t,onTaskComplete:()=>a.serverGroups.refresh()}),this.submit=()=>{const t=[{type:"upsertAsgScheduledActions",asgs:[{asgName:n.name,region:n.region}],scheduledActions:e.command.scheduledActions,credentials:n.account}];e.taskMonitor.submit((function(){return O.executeTask({job:t,application:a,description:"Update Scheduled Actions for "+n.name})}))},this.cancel=t.dismiss}]);const Tc="spinnaker.amazon.serverGroup.details.securityGroup.editSecurityGroups.modal.controller";t(Tc,[Lt,Ge]).controller("EditSecurityGroupsCtrl",["$scope","$uibModalInstance","serverGroupWriter","securityGroupReader","application","serverGroup","securityGroups",function(e,t,a,n,r,i,s){this.command={securityGroups:(s||[]).slice(0).sort(((e,t)=>e.name.localeCompare(t.name)))},this.state={securityGroupsLoaded:!1,submitting:!1,verification:{}},this.infiniteScroll={currentItems:20},this.addMoreItems=()=>this.infiniteScroll.currentItems+=20,this.resetCurrentItems=()=>this.infiniteScroll.currentItems=20,this.isValid=()=>this.state.verification.verified,n.getAllSecurityGroups().then((e=>{const t=i.account,a=i.region,n=i.vpcId;this.availableSecurityGroups=Ht.get(e,[t,"aws",a].join("."),[]).filter((e=>e.vpcId===n)).sort(((e,t)=>this.command.securityGroups.some((t=>t.id===e.id))?-1:this.command.securityGroups.some((e=>e.id===t.id))?1:e.name.localeCompare(t.name))),this.state.securityGroupsLoaded=!0})),this.serverGroup=i,this.taskMonitor=new v({application:r,title:`Update ${U.get("Firewalls")} for ${i.name}`,modalInstance:t,onTaskComplete:()=>r.serverGroups.refresh()}),this.submit=()=>{this.taskMonitor.submit((()=>{this.state.submitting=!0;const e=Boolean(i.launchTemplate);return a.updateSecurityGroups(i,this.command.securityGroups,r,e)}))},this.cancel=t.dismiss}]);const Ic="spinnaker.amazon.serverGroup.details";t(Ic,[Sc,Tc,kc,Nc,Ec,wc]);const Gc="spinnaker.amazon.serverGroup.transformer";t(Gc,[]).service("awsServerGroupTransformer",class{addComparator(e){if(e.comparisonOperator)switch(e.comparisonOperator){case"LessThanThreshold":e.comparator="<";break;case"GreaterThanThreshold":e.comparator=">";break;case"LessThanOrEqualToThreshold":e.comparator="≤";break;case"GreaterThanOrEqualToThreshold":e.comparator="≥"}}addAdjustmentAttributes(e){e.operator=e.scalingAdjustment<0?"decrease":"increase",e.absAdjustment=Math.abs(e.scalingAdjustment)}transformScalingPolicy(e){const t={...e},a=(e,t)=>t.metricIntervalUpperBound-e.metricIntervalUpperBound,n=(e,t)=>e.metricIntervalLowerBound-t.metricIntervalLowerBound;if(t.alarms=e.alarms||[],t.alarms.forEach((e=>this.addComparator(e))),this.addAdjustmentAttributes(t),t.stepAdjustments&&t.stepAdjustments.length){t.stepAdjustments.forEach((e=>this.addAdjustmentAttributes(e)));const r=e.stepAdjustments.every((e=>void 0!==e.metricIntervalUpperBound))?a:n;t.stepAdjustments.sort(((e,t)=>r(e,t)))}return t}normalizeServerGroupDetails(e){const t={...e};return e.scalingPolicies&&(t.scalingPolicies=e.scalingPolicies.map((e=>this.transformScalingPolicy(e)))),t}normalizeServerGroup(e){return e.instances.forEach((t=>{t.vpcId=e.vpcId})),Wn.listVpcs().then((t=>this.addVpcNameToServerGroup(e)(t)))}addVpcNameToServerGroup(e){return t=>{const a=t.find((t=>t.id===e.vpcId));return e.vpcName=a?a.name:"",e}}convertServerGroupCommandToDeployConfiguration(e){const t={...e};t.cloudProvider="aws",t.availabilityZones={[t.region]:e.availabilityZones},t.loadBalancers=(e.loadBalancers||[]).concat(e.vpcLoadBalancers||[]),t.targetGroups=e.targetGroups||[],t.account=t.credentials,t.subnetType=t.subnetType||"",t.instanceType=t.instanceType||t.launchTemplateOverridesForInstanceType&&t.launchTemplateOverridesForInstanceType[0].instanceType,"clone"!==e.viewState.mode&&delete t.source,t.ramdiskId||delete t.ramdiskId;return["region","viewState","backingData","selectedProvider","instanceProfile","vpcId"].forEach((e=>{delete t[e]})),t}constructNewStepScalingPolicyTemplate(e){return{alarms:[{namespace:"AWS/EC2",metricName:"CPUUtilization",threshold:50,statistic:"Average",comparisonOperator:"GreaterThanThreshold",evaluationPeriods:1,dimensions:[{name:"AutoScalingGroupName",value:e.name}],period:60}],adjustmentType:"ChangeInCapacity",stepAdjustments:[{scalingAdjustment:1,metricIntervalLowerBound:0}],estimatedInstanceWarmup:600}}constructNewTargetTrackingPolicyTemplate(){return{alarms:[],estimatedInstanceWarmup:300,targetTrackingConfiguration:{targetValue:null,predefinedMetricSpecification:{predefinedMetricType:"ASGAverageCPUUtilization"}}}}});const Ac="spinnaker.amazon.subnet.renderer";t(Ac,[]).service("awsSubnetRenderer",class{render(e){return e.subnetType}});Rt.registerValidator("aws",new class{validateSpecialCharacters(e,t){/^[a-zA-Z_0-9.]*$/g.test(e)||t.push("Only dot(.) and underscore(_) special characters are allowed.")}validateClassicLock(e){const t=kn.classicLaunchLockout;t&&t<(new Date).getTime()&&e.push(`New applications deployed to AWS are restricted to VPC; you cannot create server groups,\n load balancers, or ${U.get("firewalls")} in EC2 Classic.`)}validateLoadBalancerCharacters(e,t){(e.includes(".")||e.includes("_"))&&t.push("If the application's name contains an underscore(_) or dot(.),\n you will not be able to create a load balancer,\n preventing it from being used as a front end service.\n Any hostname constructed with this application name may have issues.")}validateLength(e,t,a){if(e.length>250)a.push("The maximum length for an application in Amazon is 250 characters.");else{if(e.length>240)if(e.length>=248)t.push(`You will not be able to include a stack or detail field for clusters or ${U.get("firewalls")}.`);else{const a=248-e.length;t.push(`If you plan to include a stack or detail field for clusters, you will only\n have ~${a} characters to do so.`)}if(e.length>20)if(e.length>32)t.push(`You will not be able to create an Amazon load balancer for this application if the\n application's name is longer than 32 characters (currently: ${e.length} characters)`);else if(e.length>=30)t.push(`If you plan to create load balancers for this application, be aware that the character limit\n for load balancer names is 32 (currently: ${e.length} characters). With separators ("-"), you will not\n be able to add a stack and detail field to any load balancer.`);else{const a=30-e.length;t.push(`If you plan to create load balancers for this application, be aware that the character limit\n for load balancer names is 32. You will only have ~${a} characters to add a stack or detail\n field to any load balancer.`)}}}validate(e=""){const t=[],a=[];return e.length&&(this.validateClassicLock(t),this.validateSpecialCharacters(e,a),this.validateLoadBalancerCharacters(e,t),this.validateLength(e,t,a)),{warnings:t,errors:a}}});const xc="spinnaker.amazon.vpc";t(xc,[]).component("vpcTag",Ja(L(yr,"vpcTag"),["vpcId"]));xr('.cloud-provider-logo .icon-aws {\n -webkit-mask-image: url("data:image/svg+xml,%3C%3Fxml version%3D%221.0%22 encoding%3D%22utf-8%22%3F%3E%3C!DOCTYPE svg PUBLIC %22-%2F%2FW3C%2F%2FDTD SVG 1.1%2F%2FEN%22 %22http%3A%2F%2Fwww.w3.org%2FGraphics%2FSVG%2F1.1%2FDTD%2Fsvg11.dtd%22%3E%3Csvg version%3D%221.1%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22 x%3D%220px%22 y%3D%220px%22%09 width%3D%22130px%22 height%3D%22130px%22 viewBox%3D%220 0 27 27%22%3E%3Cg%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2213.2%2C27 2.4%2C23.1 2.4%2C8.5 13.2%2C12.5 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2226.5%2C23.1 15.2%2C27 15.2%2C12.5 26.5%2C8 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2214.2%2C3.4 25.5%2C7 14.2%2C11.0 2.9%2C7 %22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");\n mask-image: url("data:image/svg+xml,%3C%3Fxml version%3D%221.0%22 encoding%3D%22utf-8%22%3F%3E%3C!DOCTYPE svg PUBLIC %22-%2F%2FW3C%2F%2FDTD SVG 1.1%2F%2FEN%22 %22http%3A%2F%2Fwww.w3.org%2FGraphics%2FSVG%2F1.1%2FDTD%2Fsvg11.dtd%22%3E%3Csvg version%3D%221.1%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22 x%3D%220px%22 y%3D%220px%22%09 width%3D%22130px%22 height%3D%22130px%22 viewBox%3D%220 0 27 27%22%3E%3Cg%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2213.2%2C27 2.4%2C23.1 2.4%2C8.5 13.2%2C12.5 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2226.5%2C23.1 15.2%2C27 15.2%2C12.5 26.5%2C8 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2214.2%2C3.4 25.5%2C7 14.2%2C11.0 2.9%2C7 %22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");\n}\n');const Pc="spinnaker.amazon";t(Pc,[al,$i,Li,vs,ys,bs,Ps,Es,ws,Cs,As,xs,_s,Ks,Ys,Ic,In,Gc,hr,Fi,tr,Sr,Cl,Ac,xc,nl,as,Ki,ji,rs,Gr,Ar,Tr,Nr,br,Wi,fs,Gs,tl,Zs]).config((()=>{V.registerProvider("aws",{name:"Amazon",adHocInfrastructureWritesEnabled:kn.adHocInfraWritesEnabled,logo:{path:"amazon.logo352d4e042476837f.svg"},image:{reader:nr},serverGroup:{transformer:"awsServerGroupTransformer",detailsActions:vo,detailsGetter:bo,detailsSections:[Yo,Qo,ec,tc,nc,ic,gc,uc,dc,mc,hc,lc,Ko,sc],CloneServerGroupModal:co,commandBuilder:"awsServerGroupCommandBuilder",configurationService:"awsServerGroupConfigurationService",scalingActivitiesEnabled:!0,TargetTrackingChart:ko,UpsertStepPolicyModal:Oo,UpsertTargetTrackingModal:Po},instance:{instanceTypeService:"awsInstanceTypeService",detailsTemplateUrl:"amazon/src/instance/details/instanceDetails.html",detailsController:"awsInstanceDetailsCtrl"},loadBalancer:{transformer:$r,detailsTemplateUrl:"amazon/src/loadBalancer/details/loadBalancerDetails.html",detailsController:"awsLoadBalancerDetailsCtrl",CreateLoadBalancerModal:Ii,targetGroupDetailsTemplateUrl:"amazon/src/loadBalancer/details/targetGroupDetails.html",targetGroupDetailsController:"awsTargetGroupDetailsCtrl",ClusterContainer:Dr,LoadBalancersTag:Mr},function:{details:er,CreateFunctionModal:_n,transformer:xn},securityGroup:{transformer:"awsSecurityGroupTransformer",reader:"awsSecurityGroupReader",detailsTemplateUrl:"amazon/src/securityGroup/details/securityGroupDetail.html",detailsController:"awsSecurityGroupDetailsCtrl",createSecurityGroupTemplateUrl:"amazon/src/securityGroup/configure/createSecurityGroup.html",createSecurityGroupController:"awsCreateSecurityGroupCtrl"},subnet:{renderer:"awsSubnetRenderer"},search:{resultFormatter:"awsSearchResultFormatter"},applicationProviderFields:{templateUrl:"amazon/src/applicationProviderFields/awsFields.html"}})})),r.registerProvider("aws",["custom","redblack","rollingpush","rollingredblack","monitored"]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/instance/details/instanceDetails.html",'<div class="text-center" ng-if="state.notFoundStandalone">\n <h3>Could not find instance {{instanceIdNotFound}}.</h3>\n <a ui-sref="home.infrastructure">Back to search results</a>\n</div>\n<div class="details-panel" ng-if="!state.notFoundStandalone">\n <div class="header">\n <instance-details-header\n health-state="instance.healthState"\n instance-id="instance.instanceId || instanceIdNotFound"\n loading="state.loading"\n standalone="state.standalone"\n ></instance-details-header>\n <div ng-if="!state.loading" ng-hide="isDisabled">\n <div class="actions" ng-class="{ insights: instance.insightActions.length > 0 }" ng-if="instance.placement">\n <instance-actions actions="instanceActions"></instance-actions>\n <instance-insights insights="instance.insightActions" instance="instance"></instance-insights>\n </div>\n </div>\n </div>\n <div class="content" ng-if="!state.loading && instance">\n <amazon-instance-information instance="instance"></amazon-instance-information>\n <instance-status\n health-metrics="healthMetrics"\n health-state="instance.healthState"\n metric-types="[\'LoadBalancer\', \'TargetGroup\']"\n private-ip-address="instance.privateIpAddress"\n >\n </instance-status>\n <collapsible-section heading="DNS">\n <instance-dns\n instance-port="state.instancePort"\n ipv6-addresses="instance.ipv6Addresses"\n permanent-ips="instance.permanentIps"\n private-dns-name="instance.privateDnsName"\n private-ip-address="instance.privateIpAddress"\n public-dns-name="instance.publicDnsName"\n public-ip-address="instance.publicIpAddress"\n >\n </instance-dns>\n </collapsible-section>\n <instance-security-groups instance="instance"></instance-security-groups>\n <instance-tags tags="instance.tags"></instance-tags>\n <collapsible-section heading="Console Output" ng-if="baseIpAddress">\n <ul>\n <li>\n <console-output-link instance="instance"></console-output-link>\n </li>\n </ul>\n </collapsible-section>\n <instance-links\n address="baseIpAddress"\n application="application"\n instance="instance"\n moniker="moniker"\n environment="environment"\n ></instance-links>\n </div>\n <div class="content" ng-if="!state.loading && !instance">\n <div class="content-section">\n <div class="content-body text-center">\n <h3>Instance not found.</h3>\n </div>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/loadBalancer/details/loadBalancerDetails.html",'<div class="details-panel">\n <div ng-if="ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="horizontal center middle spinner-container">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n </div>\n\n <div ng-if="!ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="header-text horizontal middle">\n <i class="fa icon-sitemap"></i>\n <h3 class="horizontal middle space-between flex-1" select-on-dbl-click>\n {{ctrl.loadBalancer.name}}\n <render-if-feature feature="entityTags">\n <entity-notifications\n entity="ctrl.loadBalancer"\n application="ctrl.application"\n placement="bottom"\n h-offset-percent="90%"\n entity-type="loadBalancer"\n page-location="details"\n on-update="ctrl.application.loadBalancers.refresh()"\n ></entity-notifications>\n </render-if-feature>\n </h3>\n </div>\n <div>\n <div class="actions">\n <load-balancer-actions\n app="ctrl.application"\n load-balancer="ctrl.loadBalancer"\n load-balancer-from-params="ctrl.loadBalancerFromParams"\n ></load-balancer-actions>\n <div\n class="dropdown"\n ng-if="ctrl.loadBalancer.elb.insightActions.length > 0"\n uib-dropdown\n dropdown-append-to-body\n >\n <button type="button" class="btn btn-sm btn-default dropdown-toggle" uib-dropdown-toggle>\n Insight <span class="caret"></span>\n </button>\n <ul class="dropdown-menu" uib-dropdown-menu role="menu">\n <li ng-repeat="action in ctrl.loadBalancer.elb.insightActions">\n <a target="_blank" href="{{action.url}}">{{action.label}}</a>\n </li>\n </ul>\n </div>\n </div>\n </div>\n </div>\n <managed-resource-details-indicator\n ng-if="!ctrl.state.loading && ctrl.loadBalancer.isManaged"\n resource-summary="ctrl.loadBalancer.managedResourceSummary"\n application="ctrl.application"\n >\n </managed-resource-details-indicator>\n <div ng-if="!ctrl.state.loading" class="content">\n <collapsible-section heading="Load Balancer Details" expanded="true">\n <dl class="dl-horizontal dl-narrow">\n <dt>Created</dt>\n <dd>{{ctrl.loadBalancer.elb.createdTime | timestamp}}</dd>\n <dt>In</dt>\n <dd>\n <account-tag account="ctrl.loadBalancer.account" pad="right"></account-tag> {{ctrl.loadBalancer.region}}\n </dd>\n <dt>VPC</dt>\n <dd>\n <vpc-tag vpc-id="ctrl.loadBalancer.elb.vpcId"></vpc-tag>\n </dd>\n <dt>Subnet</dt>\n <dd>{{ctrl.getFirstSubnetPurpose(ctrl.loadBalancer.subnetDetails)}}</dd>\n <dt>Scheme</dt>\n <dd>{{ ctrl.loadBalancer.scheme }}</dd>\n <dt ng-if="ctrl.loadBalancer.loadBalancerType">Type</dt>\n <dd ng-if="ctrl.loadBalancer.loadBalancerType">{{ctrl.loadBalancer.loadBalancerType}}</dd>\n <dt ng-if="ctrl.ipAddressTypeDescription">IP Type</dt>\n <dd ng-if="ctrl.ipAddressTypeDescription">{{ctrl.ipAddressTypeDescription}}</dd>\n </dl>\n <dl class="horizontal-when-filters-collapsed">\n <dt>Availability Zones</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="availabilityZone in ctrl.loadBalancer.elb.availabilityZones">{{availabilityZone}}</li>\n </ul>\n </dd>\n </dl>\n <dl\n ng-if="ctrl.loadBalancer.serverGroups && ctrl.loadBalancer.serverGroups.length"\n class="horizontal-when-filters-collapsed"\n >\n <dt>Server Groups</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="serverGroup in ctrl.loadBalancer.serverGroups | orderBy: [\'isDisabled\', \'-name\']">\n <a\n ui-sref="^.serverGroup({region: serverGroup.region,\n accountId: serverGroup.account,\n serverGroup: serverGroup.name,\n provider: \'aws\'})"\n >\n {{serverGroup.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n <dl\n ng-if="ctrl.loadBalancer.targetGroups && ctrl.loadBalancer.targetGroups.length"\n class="horizontal-when-filters-collapsed"\n >\n <dt>Target Groups</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="targetGroup in ctrl.loadBalancer.targetGroups | orderBy: [\'isDisabled\', \'-name\']">\n <a\n ui-sref="^.targetGroupDetails({region: targetGroup.region,\n loadBalancerName: ctrl.loadBalancer.name,\n accountId: targetGroup.account,\n name: targetGroup.name,\n vpcId: targetGroup.vpcId,\n provider: \'aws\'})"\n >\n {{targetGroup.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n <dl class="horizontal-when-filters-collapsed">\n <dt ng-if="ctrl.loadBalancer.elb.dnsname">DNS Name</dt>\n <dd>\n <a target="_blank" href="{{ctrl.elbProtocol}}//{{ctrl.loadBalancer.elb.dnsname}}"\n >{{ctrl.loadBalancer.elb.dnsname}}</a\n >\n <copy-to-clipboard\n class="copy-to-clipboard copy-to-clipboard-sm"\n text="ctrl.loadBalancer.elb.dnsname"\n tool-tip="\'Copy DNS Name to clipboard\'"\n >\n </copy-to-clipboard>\n </dd>\n </dl>\n </collapsible-section>\n <collapsible-section heading="Status" expanded="true" ng-if="ctrl.loadBalancer.loadBalancerType === \'classic\'">\n <health-counts class="pull-left" container="ctrl.loadBalancer.instanceCounts"></health-counts>\n </collapsible-section>\n <collapsible-section heading="Status" expanded="false" ng-if="ctrl.loadBalancer.loadBalancerType !== \'classic\'">\n Select a target group to check the instance health status from the view of the target group.\n </collapsible-section>\n <collapsible-section ng-if="ctrl.loadBalancer.loadBalancerType === \'classic\'" heading="Listeners">\n <dl>\n <dt>Load Balancer → Instance</dt>\n <dd ng-repeat="listener in ctrl.loadBalancer.elb.listenerDescriptions">\n {{listener.listener.protocol}}:{{listener.listener.loadBalancerPort}} →\n {{listener.listener.instanceProtocol}}:{{listener.listener.instancePort}}\n </dd>\n </dl>\n </collapsible-section>\n <collapsible-section ng-if="ctrl.loadBalancer.loadBalancerType !== \'classic\'" heading="Listeners">\n <div ng-repeat="listener in ctrl.listeners">\n <div class="listener-targets">{{listener.in}} →</div>\n <div class="listener-targets">\n <div ng-repeat="action in listener.actions">\n \x3c!-- redirect --\x3e\n <span ng-if="action.type === \'redirect\'">\n <span ng-if="action.redirectConfig.protocol !== listener.protocol">\n {{action.redirectConfig.protocol}}:\n </span>\n <span ng-if="action.redirectConfig.host !== \'#{host}\'"> {{action.redirectConfig.host}} </span>\n <span ng-if="action.redirectConfig.port !== \'#{port}\'"> {{action.redirectConfig.port}} </span>\n <span ng-if="action.redirectConfig.path !== \'/#{path}\'"> {{action.redirectConfig.path}} </span>\n <span ng-if="action.redirectConfig.query !== \'#{query}\'"> ?{{action.redirectConfig.query}} </span>\n ({{action.redirectConfig.statusCode}})\n </span>\n \x3c!-- authenticate-oidc --\x3e\n <span ng-if="action.type === \'authenticate-oidc\'">\n <i class="fas fa-fw fa-user-lock"></i>\n <a\n ng-if="ctrl.oidcConfigPath"\n href="{{ctrl.oidcConfigPath}}{{action.authenticateOidcConfig.clientId}}"\n target="_blank"\n >\n {{action.authenticateOidcConfig.clientId}}\n </a>\n <span ng-if="!ctrl.oidcConfigPath"> {{action.authenticateOidcConfig.clientId}} </span>\n </span>\n \x3c!-- forward --\x3e\n <span ng-if="action.targetGroupName && action.targetGroup">\n <i class="fa fa-fw fa-crosshairs icon" aria-hidden="true"></i>\n <a\n ui-sref="^.targetGroupDetails({region: action.targetGroup.region,\n loadBalancerName: ctrl.loadBalancer.name,\n accountId: action.targetGroup.account,\n name: action.targetGroup.name,\n vpcId: action.targetGroup.vpcId,\n provider: \'aws\'})"\n >\n {{action.targetGroupName}}\n </a>\n </span>\n <span ng-if="action.targetGroupName && !action.targetGroup">\n <i class="fa fa-fw fa-crosshairs icon" aria-hidden="true"></i>\n {{action.targetGroupName}}\n </span>\n </div>\n </div>\n </div>\n </collapsible-section>\n <collapsible-section\n heading="{{ctrl.firewallsLabel}}"\n ng-if="ctrl.loadBalancer.loadBalancerType !== \'network\' || (ctrl.loadBalancer.loadBalancerType === \'network\' && ctrl.securityGroups && ctrl.securityGroups.length > 0)"\n >\n <ul>\n <li ng-repeat="securityGroup in ctrl.securityGroups | orderBy:\'name\'">\n <a\n ui-sref="^.firewallDetails({name:securityGroup.name, accountId: ctrl.loadBalancer.account, region: ctrl.loadBalancer.region, vpcId: ctrl.loadBalancer.vpcId, provider: ctrl.loadBalancer.provider})"\n >\n {{securityGroup.name}} ({{securityGroup.id}})\n </a>\n </li>\n </ul>\n </collapsible-section>\n <collapsible-section heading="Subnets">\n <div ng-if="ctrl.loadBalancer.subnetDetails.length === 0">\n <h5>No subnets</h5>\n </div>\n <div ng-repeat="subnet in ctrl.loadBalancer.subnetDetails" ng-class="{\'bottom-border\': !$last}">\n <h5><strong>{{subnet.id}}</strong></h5>\n <dl class="dl-horizontal dl-narrow">\n <dt>Purpose</dt>\n <dd>{{subnet.purpose}}</dd>\n\n <dt>State</dt>\n <dd>{{subnet.state}}</dd>\n\n <dt>Cidr Block</dt>\n <dd>{{subnet.cidrBlock}}</dd>\n </dl>\n </div>\n </collapsible-section>\n <collapsible-section ng-if="ctrl.loadBalancer.loadBalancerType === \'classic\'" heading="Health Checks">\n <dl class="horizontal-when-filters-collapsed">\n <dt>Target</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.target}}</dd>\n <dt>Timeout</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.timeout}} seconds</dd>\n <dt>Interval</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.interval}} seconds</dd>\n <dt>Healthy Threshold</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.healthyThreshold}}</dd>\n <dt>Unhealthy Threshold</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.unhealthyThreshold}}</dd>\n </dl>\n </collapsible-section>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/loadBalancer/details/targetGroupDetails.html",'<div class="details-panel">\n <div ng-if="ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n </div>\n\n <div ng-if="!ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="header-text horizontal middle">\n <i class="fa fa-crosshairs icon" aria-hidden="true"></i>\n <h3 class="horizontal middle space-between flex-1" select-on-dbl-click>{{ctrl.targetGroup.name}}</h3>\n </div>\n </div>\n <managed-resource-details-indicator\n ng-if="!ctrl.state.loading && ctrl.loadBalancer.isManaged"\n resource-summary="ctrl.loadBalancer.managedResourceSummary"\n application="ctrl.application"\n >\n </managed-resource-details-indicator>\n <div ng-if="!ctrl.state.loading" class="content">\n <collapsible-section heading="Target Group Details" expanded="true">\n <dl class="dl-horizontal dl-narrow">\n <dt>In</dt>\n <dd><account-tag account="ctrl.targetGroup.account" pad="right"></account-tag> {{ctrl.targetGroup.region}}</dd>\n <dt>VPC</dt>\n <dd>\n <vpc-tag vpc-id="ctrl.targetGroup.vpcId"></vpc-tag>\n </dd>\n <dt>Protocol</dt>\n <dd>{{ctrl.targetGroup.protocol}}</dd>\n <dt>Port</dt>\n <dd>{{ctrl.targetGroup.port}}</dd>\n <dt>Target Type</dt>\n <dd>{{ctrl.targetGroup.targetType}}</dd>\n </dl>\n <dl ng-if="ctrl.loadBalancer" class="horizontal-when-filters-collapsed">\n <dt>Load Balancer</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li>\n <a\n ui-sref="^.loadBalancerDetails({ name: ctrl.loadBalancer.name,\n region: ctrl.loadBalancer.region,\n accountId: ctrl.loadBalancer.account,\n vpcId: ctrl.loadBalancer.vpcId,\n provider: \'aws\'})"\n >\n {{ctrl.loadBalancer.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n <dl class="horizontal-when-filters-collapsed">\n <dt ng-if="ctrl.loadBalancer.dnsname">Load Balancer DNS Name</dt>\n <dd ng-if="ctrl.loadBalancer.dnsname">\n <a target="_blank" href="{{ctrl.elbProtocol}}//{{ctrl.loadBalancer.dnsname}}"\n >{{ctrl.loadBalancer.dnsname}}</a\n >\n <copy-to-clipboard\n class="copy-to-clipboard copy-to-clipboard-sm"\n text="ctrl.loadBalancer.dnsname"\n tool-tip="\'Copy DNS Name to clipboard\'"\n >\n </copy-to-clipboard>\n </dd>\n </dl>\n <dl\n ng-if="ctrl.targetGroup.serverGroups && ctrl.targetGroup.serverGroups.length"\n class="horizontal-when-filters-collapsed"\n >\n <dt>Server Groups</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="serverGroup in ctrl.targetGroup.serverGroups | orderBy: [\'isDisabled\', \'-name\']">\n <a\n ui-sref="^.serverGroup({region: serverGroup.region,\n accountId: serverGroup.account,\n serverGroup: serverGroup.name,\n provider: serverGroup.cloudProvider})"\n >\n {{serverGroup.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n </collapsible-section>\n <collapsible-section heading="Status" expanded="true">\n <health-counts class="pull-left" container="ctrl.targetGroup.instanceCounts"></health-counts>\n </collapsible-section>\n <collapsible-section heading="Health Checks">\n <dl class="horizontal-when-filters-collapsed">\n <dt>Target</dt>\n <dd>\n {{ctrl.targetGroup.healthCheckProtocol}}:{{ctrl.targetGroup.healthCheckPort}}\n {{ctrl.targetGroup.healthCheckPath}}\n </dd>\n <dt>Timeout</dt>\n <dd>{{ctrl.targetGroup.healthCheckTimeoutSeconds}} seconds</dd>\n <dt>Interval</dt>\n <dd>{{ctrl.targetGroup.healthCheckIntervalSeconds}} seconds</dd>\n <dt>Healthy Threshold</dt>\n <dd>{{ctrl.targetGroup.healthyThresholdCount}}</dd>\n <dt>Unhealthy Threshold</dt>\n <dd>{{ctrl.targetGroup.unhealthyThresholdCount}}</dd>\n <dt>Matcher</dt>\n <dd>HTTP Code(s): {{ctrl.targetGroup.matcher.httpCode}}</dd>\n </dl>\n </collapsible-section>\n <collapsible-section heading="Attributes" expanded="true">\n <dl class="horizontal-when-filters-collapsed">\n <dt>Deregistration Delay Timeout</dt>\n <dd>{{ctrl.targetGroup.attributes[\'deregistration_delay.timeout_seconds\']}} seconds</dd>\n <dt>Stickiness Enabled</dt>\n <dd>{{ctrl.targetGroup.attributes[\'stickiness.enabled\']}}</dd>\n <dt ng-if-start="ctrl.targetGroup.attributes[\'stickiness.enabled\'] === \'true\'">\n Stickiness Load Balancer Cookie Duration\n </dt>\n <dd>{{ctrl.targetGroup.attributes[\'stickiness.lb_cookie.duration_seconds\']}} seconds</dd>\n <dt>Stickiness Type</dt>\n <dd ng-if-end>{{ctrl.targetGroup.attributes[\'stickiness.type\']}}</dd>\n <dt ng-if-start="ctrl.loadBalancer.loadBalancerType === \'network\'">Preserve Client IP</dt>\n <dd ng-if-end>{{ctrl.targetGroup.attributes[\'preserve_client_ip.enabled\']}}</dd>\n </dl>\n </collapsible-section>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/details/securityGroupDetail.html",'<div class="text-center" ng-if="state.notFound">\n <h3>Could not find <firewall-label label="firewall"></firewall-label> {{group}}.</h3>\n <a ui-sref="home.infrastructure">Back to search results</a>\n</div>\n<div class="details-panel" ng-if="!state.notFound">\n <div class="header">\n <div class="close-button" ng-if="!state.standalone">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div ng-if="state.loading" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div class="header-text horizontal middle" ng-if="!state.loading">\n <span class="glyphicon glyphicon-transfer"></span>\n <h3 class="horizontal middle space-between flex-1" select-on-dbl-click>\n {{securityGroup.name || \'(not found)\'}}\n <render-if-feature feature="entityTags">\n <entity-notifications\n entity="securityGroup"\n application="ctrl.application"\n placement="bottom"\n h-offset-percent="90%"\n entity-type="securityGroup"\n page-location="details"\n on-update="ctrl.application.securityGroups.refresh()"\n ></entity-notifications>\n </render-if-feature>\n </h3>\n </div>\n <div class="actions" ng-hide="isDisabled">\n <div class="dropdown" uib-dropdown dropdown-append-to-body>\n <button type="button" class="btn btn-sm btn-primary dropdown-toggle" ng-disabled="disabled" uib-dropdown-toggle>\n <firewall-label label="Firewall"></firewall-label> Actions <span class="caret"></span>\n </button>\n <ul class="dropdown-menu" uib-dropdown-menu role="menu">\n <li><a href ng-click="ctrl.editInboundRules()">Edit Inbound Rules</a></li>\n <li>\n <a href ng-click="ctrl.deleteSecurityGroup()">Delete <firewall-label label="Firewall"></firewall-label></a>\n </li>\n <li>\n <a href ng-click="ctrl.cloneSecurityGroup()">Clone <firewall-label label="Firewall"></firewall-label></a>\n </li>\n <render-if-feature feature="entityTags">\n <add-entity-tag-links\n component="securityGroup"\n application="ctrl.application"\n entity-type="securityGroup"\n on-update="ctrl.application.securityGroups.refresh"\n ></add-entity-tag-links>\n </render-if-feature>\n </ul>\n </div>\n </div>\n </div>\n <managed-resource-details-indicator\n ng-if="!state.loading && securityGroup.isManaged"\n resource-summary="securityGroup.managedResourceSummary"\n application="ctrl.application"\n >\n </managed-resource-details-indicator>\n <div class="content" ng-if="!state.loading">\n <collapsible-section heading="{{ctrl.firewallLabel}} Details" expanded="true">\n <dl class="dl-horizontal dl-medium">\n <dt>ID</dt>\n <dd>{{securityGroup.id}}</dd>\n <dt>Account</dt>\n <dd>\n <account-tag account="securityGroup.accountName"></account-tag>\n </dd>\n <dt>Region</dt>\n <dd>{{securityGroup.region}}</dd>\n <dt>VPC</dt>\n <dd>\n <vpc-tag vpc-id="securityGroup.vpcId"></vpc-tag>\n </dd>\n <dt>Description</dt>\n <dd>{{securityGroup.description}}</dd>\n </dl>\n </collapsible-section>\n <ip-range-rules ip-rules="ipRules"></ip-range-rules>\n <collapsible-section\n heading="{{ctrl.firewallLabel}} Rules ({{securityGroupRules.length || 0}})"\n expanded="{{securityGroupRules.length > 0}}"\n >\n <div ng-if="!securityGroupRules.length">None</div>\n\n <dl\n ng-class="insightCtrl.vm.filtersExpanded ? \'\' : \'dl-horizontal dl-medium\'"\n ng-repeat="rule in securityGroupRules | orderBy: \'securityGroup.name\' "\n >\n <dt>\n <firewall-label label="Firewall"></firewall-label>\n </dt>\n <dd ng-if="rule.securityGroup.name">\n <a\n ui-sref="^.firewallDetails({name: rule.securityGroup.name, accountId: rule.securityGroup.accountName, region: rule.securityGroup.region, vpcId: rule.securityGroup.vpcId, provider: \'aws\'})"\n >\n <account-tag\n account="rule.securityGroup.accountName || rule.securityGroup.accountId"\n ng-if="rule.securityGroup.accountName !== securityGroup.accountName"\n ></account-tag>\n {{rule.securityGroup.name}} ({{rule.securityGroup.id}})\n </a>\n </dd>\n <dt>Port Ranges</dt>\n <dd ng-repeat="portRange in rule.rules">\n {{portRange.protocol}}: {{portRange.startPort}} → {{portRange.endPort}}\n </dd>\n </dl>\n </collapsible-section>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroup.html",'<ng-form role="form" name="form" novalidate>\n <v2-modal-wizard heading="Create New {{ctrl.translate(\'Firewall\')}}" task-monitor="taskMonitor" dismiss="$dismiss()">\n <v2-wizard-page key="Location" label="Location">\n <ng-include src="pages.location"></ng-include>\n </v2-wizard-page>\n <v2-wizard-page key="Ingress" label="Ingress" done="true">\n <ng-include src="pages.ingress"></ng-include>\n </v2-wizard-page>\n </v2-modal-wizard>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <submit-button\n is-disabled="form.$invalid || !wizard.isComplete() || state.submitting || !customComponentIsvalid"\n submitting="state.submitting"\n on-click="ctrl.upsert()"\n is-new="state.isNew"\n ></submit-button>\n </div>\n</ng-form>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/applicationProviderFields/awsFields.html",'<div class="form-group row">\n <div class="col-sm-3 sm-label-right">AWS Settings</div>\n <div class="col-sm-9 checkbox" style="margin-bottom: 0; margin-top: 5px">\n <label>\n <input\n type="checkbox"\n ng-init="$ctrl.initializeApplicationField(\'aws.useAmiBlockDeviceMappings\')"\n ng-model="$ctrl.application.providerSettings.aws.useAmiBlockDeviceMappings"\n />\n Prefer AMI Block Device Mappings\n </label>\n </div>\n</div>\n')}]);export{Pc as AMAZON_MODULE,kn as AWSProviderSettings,yc as AWS_SERVER_GROUP_CONFIGURATION_SERVICE,Ko as AdvancedSettingsDetailsSection,$o as AlarmConfigurer,Qo as AmazonCapacityDetailsSection,Yr as AmazonCertificateReader,qr as AmazonCertificateSelectField,er as AmazonFunctionDetails,kl as AmazonImageSelectInput,Yo as AmazonInfoDetailsSection,Er as AmazonInstanceWriter,Ii as AmazonLoadBalancerChoiceModal,Dr as AmazonLoadBalancerClusterContainer,Br as AmazonLoadBalancerDataUtils,Mr as AmazonLoadBalancersTag,mo as AmazonResizeServerGroupModal,Oo as AmazonUpsertScalingPolicyModal,Po as AmazonUpsertTargetTrackingModal,xn as AwsFunctionTransformer,$r as AwsLoadBalancerTransformer,uo as AwsModalFooter,Yn as AwsReactInject,Xn as AwsReactInjector,vc as AwsServerGroupConfigurationService,Fo as COMPARATORS,_n as CreateLambdaFunction,Vo as CreateScalingPolicyButton,Eo as DateLineChart,No as DimensionsEditor,Kn as FunctionActions,On as FunctionBasicInformation,ec as HealthDetailsSection,vl as IPRangeRules,kr as InstanceDns,fr as InstanceInformation,Ir as InstanceStatus,tc as InstancesDistributionDetailsSection,fc as KeyPairsReader,nc as LaunchConfigDetailsSection,ic as LaunchTemplateDetailsSection,Ni as LoadBalancerTypes,sc as LogsDetailsSection,wo as MetricAlarmChart,Io as MetricSelector,lc as PackageDetailsSection,Do as PolicyTypeSelectionModal,dc as ScalingPoliciesDetailsSection,Bo as ScalingPolicyAdditionalSettings,_o as ScalingPolicySummary,Uo as ScalingPolicyWriter,uc as ScalingProcessesDetailsSection,mc as ScheduledActionsDetailsSection,eo as SecurityGroupSelector,gc as SecurityGroupsDetailsSection,lo as ServerGroupAdvancedSettings,no as ServerGroupAdvancedSettingsCommon,Tl as ServerGroupBasicSettings,Al as ServerGroupCapacity,Yl as ServerGroupInstanceType,Ql as ServerGroupLoadBalancers,ao as ServerGroupSecurityGroups,to as ServerGroupSecurityGroupsRemoved,Xl as ServerGroupZones,Ro as StepPolicyAction,jo as StepPolicySummary,ci as SubnetSelectField,oi as SubnetSelectInput,hc as TagsDetailsSection,Pr as TargetGroup,Or as TargetGroupDetails,Go as TargetMetricFields,Ao as TargetTrackingAdditionalSettings,ko as TargetTrackingChart,Zo as TargetTrackingSummary,Wn as VpcReader,Cr as applyHealthCheckInfoToTargetGroups,wr as getAllTargetGroups,ac as getBaseImageName};
|
|
1
|
+
import*as e from"angular";import{module as t}from"angular";import{SETTINGS as a,HelpField as n,DeploymentStrategyRegistry as r,FormValidator as i,FormikFormField as s,TextInput as l,AccountService as o,ReactSelectInput as c,CheckboxInput as d,MapEditorInput as u,NumberInput as p,NetworkReader as m,SubnetReader as g,ReactInjector as h,TetheredSelect as f,TaskMonitor as v,FunctionWriter as y,ReactModal as b,WizardModal as E,WizardPage as w,noop as C,ConfirmationModalService as S,ApplicationReader as k,AddEntityTagLinks as N,ReactInject as T,Details as I,AccountTag as G,Overrides as A,CollapsibleSection as x,HelpContentsRegistry as P,REST as D,LabeledValue as B,timestamp as z,useData as F,SubnetTag as M,withErrorBoundary as L,InstanceWriter as R,TaskExecutor as O,CloudProviderRegistry as V,FirewallLabels as U,RecentHistoryService as q,InstanceReader as H,LabeledValueList as W,LinkWithClipboard as j,robotToHuman as Z,Tooltip as _,InstanceLoadBalancerHealth as K,LoadBalancerServerGroup as Y,HealthCounts as X,LoadBalancerInstances as J,LoadBalancerClusterContainer as Q,logger as ee,LoadBalancerDataUtils as te,Spinner as ae,HoverablePopover as ne,NameUtils as re,Overridable as ie,relativeTime as se,SpinFormik as le,ModalClose as oe,SubmitButton as ce,SelectInput as de,CertificateReader as ue,ValidationMessage as pe,CustomLabels as me,Validators as ge,spelNumberCheck as he,SpInput as fe,SpelNumberInput as ve,ChecklistInput as ye,useDeepObjectDiff as be,useMountStatusRef as Ee,createFakeReactSyntheticEvent as we,Markdown as Ce,AccountSelectInput as Se,RegionSelectField as ke,InfrastructureCaches as Ne,LoadBalancerWriter as Te,ManagedMenuItem as Ie,SECURITY_GROUP_READER as Ge,LOAD_BALANCER_READ_SERVICE as Ae,MANAGED_RESOURCE_DETAILS_INDICATOR as xe,APPLICATION_STATE_PROVIDER as Pe,Registry as De,BakeExecutionLabel as Be,AuthenticationService as ze,PipelineTemplates as Fe,BakeryReader as Me,StageConstants as $e,AppListExtractor as Le,ExecutionDetailsSection as Re,StageFailureMessage as Oe,ExecutionDetailsTasks as Ve,FormikStageConfig as Ue,StageConfigField as qe,yamlDocumentsToString as He,ExecutionStepDetails as We,NgGenericArtifactDelegate as je,ExpectedArtifactSelectorViewController as Ze,ExecutionBarLabel as _e,ArtifactReferenceService as Ke,ExpectedArtifactService as Ye,EXECUTION_SERVICE as Xe,TetheredCreatable as Je,excludeAllTypesExcept as Qe,ArtifactTypePatterns as et,StageArtifactSelectorDelegate as tt,PipelineConfigService as at,ModalWizard as nt,SecurityGroupWriter as rt,filterObjectValues as it,CACHE_INITIALIZER_SERVICE as st,confirmNotManaged as lt,DeployInitializer as ot,DeployingIntoManagedClusterWarning as ct,ServerGroupDetailsField as dt,DeploymentStrategySelector as ut,ServerGroupNamePreview as pt,TaskReason as mt,parseNum as gt,ToggleButtonGroup as ht,ToggleSize as ft,usePrevious as vt,NgReact as yt,PlatformHealthOverride as bt,MapEditor as Et,UserVerification as wt,TaskMonitorWrapper as Ct,MinMaxDesiredChanges as St,ServerGroupWarningMessageService as kt,ModalInjector as Nt,ClusterTargetBuilder as Tt,ServerGroupReader as It,CloudMetricsReader as Gt,TaskMonitorModal as At,EntitySource as xt,ViewChangesLink as Pt,CapacityDetailsSection as Dt,ViewScalingActivitiesLink as Bt,ShowUserData as zt,SERVER_GROUP_COMMAND_REGISTRY_PROVIDER as Ft,setMatchingResourceSummary as Mt,INSTANCE_TYPE_SERVICE as $t,SERVER_GROUP_WRITER as Lt,ApplicationNameValidator as Rt}from"@spinnaker/core";import*as Ot from"react";import Vt,{useState as Ut,useEffect as qt}from"react";import Ht,{isEmpty as Wt,forOwn as jt,uniqBy as Zt,cloneDeep as _t,flatten as Kt,isNil as Yt,orderBy as Xt,isEqual as Jt,sortBy as Qt,filter as ea,chain as ta,map as aa,pickBy as na,groupBy as ra,get as ia,uniq as sa,difference as la,some as oa,isNumber as ca,set as da,partition as ua,every as pa,values as ma,head as ga,extend as ha,isString as fa,intersection as va,keyBy as ya,find as ba,flatMap as Ea,has as wa,clone as Ca,keys as Sa,xor as ka}from"lodash";import Na from"classnames";import{Subject as Ta,from as Ia,combineLatest as Ga,BehaviorSubject as Aa,of as xa,Observable as Pa}from"rxjs";import{map as Da,distinctUntilChanged as Ba,shareReplay as za,switchMap as Fa,withLatestFrom as Ma,takeUntil as $a,tap as La,mergeMap as Ra,catchError as Oa,debounceTime as Va,take as Ua}from"rxjs/operators";import{Dropdown as qa,Modal as Ha,Button as Wa,Tooltip as ja,OverlayTrigger as Za,Checkbox as _a,ModalFooter as Ka,MenuItem as Ya}from"react-bootstrap";import{$q as Xa}from"ngimport";import{react2angular as Ja}from"react2angular";import{UISref as Qa,UISrefActive as en}from"@uirouter/react";import{UIRouterContextComponent as tn}from"@uirouter/react-hybrid";import an from"@uirouter/angularjs";import nn from"angular-ui-bootstrap";import rn from"react-select";import{SortableHandle as sn,arrayMove as ln,SortableElement as on,SortableContainer as cn}from"react-sortable-hoc";import{Form as dn,Field as un}from"formik";import pn from"react-virtualized-select";import{Chart as mn,LineController as gn,LineElement as hn,PointElement as fn,LinearScale as vn,Title as yn,TimeScale as bn,Tooltip as En,Legend as wn,Filler as Cn}from"chart.js";import"chartjs-adapter-luxon";var Sn;const kn=a.providers.aws||{defaults:{}};kn&&(kn.adHocInfraWritesEnabled=null==(Sn=kn.adHocInfraWritesEnabled)||Sn,kn.resetToOriginal=a.resetProvider("aws"));const Nn={bindings:{action:"&",isValid:"&",cancel:"&",account:"=?",verification:"=?"},template:'\n <div class="modal-footer">\n <user-verification account="$ctrl.account" verification="$ctrl.verification"></user-verification>\n <button type="submit" ng-click="$ctrl.action()" style="display:none"></button> \x3c!-- Allows form submission via enter keypress--\x3e\n <button class="btn btn-default" ng-click="$ctrl.cancel()">Cancel</button>\n <button type="submit"\n class="btn btn-primary"\n ng-click="$ctrl.action()"\n ng-disabled="!$ctrl.isValid()">\n Submit\n </button>\n </div>\n ',controller:()=>{}},Tn="spinnaker.amazon.footer";t(Tn,[]).component("awsFooter",Nn);const In="spinnaker.amazon.common";t(In,[Tn]);class Gn extends Vt.Component{constructor(){super(...arguments),this.handleChange=(e,t)=>{this.props.command.termination[e]=t,this.forceUpdate()}}render(){var e;const{command:t}=this.props;return Vt.createElement("div",{className:"form-group",style:{marginTop:"20px"}},Vt.createElement("div",{className:"well-compact alert alert-warning"},Vt.createElement("strong",null,"Note:")," a rolling push only updates the"," ",Vt.createElement("em",null,"launch ",Boolean(null==(e=kn.serverGroups)?void 0:e.enableLaunchTemplates)?"template":"configuration")," ","for the auto scaling group.",Vt.createElement("br",null)," Changes to the following fields will be ignored:",Vt.createElement("ul",null,Vt.createElement("li",null,"Account, Region, Subnet Type"),Vt.createElement("li",null,"Capacity"),Vt.createElement("li",null,"Load Balancers"),Vt.createElement("li",null,"Health Check Configuration"),Vt.createElement("li",null,"Termination Policies, Enable Traffic flag"))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:t.termination.relaunchAllInstances,onChange:e=>this.handleChange("relaunchAllInstances",e.target.checked)}),Vt.createElement("b",null,"Relaunch all instances"),Vt.createElement(n,{id:"strategy.rollingPush.relaunchAll"})))),!t.termination.relaunchAllInstances&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},"Total relaunches",Vt.createElement(n,{id:"strategy.rollingPush.totalRelaunches"})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{className:"form-control input-sm",type:"number",value:t.termination.totalRelaunches,onChange:e=>this.handleChange("totalRelaunches",e.target.value),min:"0"}))),(t.termination.totalRelaunches>0||t.termination.relaunchAllInstances)&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},"Concurrent relaunches",Vt.createElement(n,{id:"strategy.rollingPush.concurrentRelaunches"})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{className:"form-control input-sm",type:"number",value:t.termination.concurrentRelaunches,onChange:e=>this.handleChange("concurrentRelaunches",e.target.value),min:"1"}))),(t.termination.totalRelaunches>0||t.termination.relaunchAllInstances)&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},"Order",Vt.createElement(n,{id:"strategy.rollingPush.order"})),Vt.createElement("div",{className:"col-md-3"},Vt.createElement("select",{className:"input input-sm",style:{width:"100px"},value:t.termination.order,onChange:e=>this.handleChange("order",e.target.value)},Vt.createElement("option",{value:"oldest"},"oldest first"),Vt.createElement("option",{value:"newest"},"newest first")))))}}var An;r.registerStrategy({label:"Rolling Push (not recommended)",description:`Updates the launch ${(null==(An=kn.serverGroups)?void 0:An.enableLaunchTemplates)?"template":"configuration"} for this server group, then terminates instances incrementally,\n replacing them with instances launched with the updated configuration. This is not a best practice - it goes against\n the principles of immutable infrastructure - but may be necessary in some cases.`,key:"rollingpush",providerRestricted:!0,additionalFields:["termination.totalRelaunches","termination.concurrentRelaunches","termination.order","termination.relaunchAllInstances"],AdditionalFieldsComponent:Gn,initializationMethod:e=>{var t,a;e.termination=e.termination||{order:"oldest",relaunchAllInstances:!0,concurrentRelaunches:1,totalRelaunches:Number(null!=(a=null==(t=null==e?void 0:e.capacity)?void 0:t.max)?a:1)}}});class xn{constructor(){this.convertFunctionForEditing=e=>({...e,envVariables:e.environment?e.environment.variables:{},credentials:e.account,tracingConfig:{mode:e.tracingConfig?e.tracingConfig.mode:""},deadLetterConfig:{targetArn:e.deadLetterConfig?e.deadLetterConfig.targetArn:""},KMSKeyArn:e.kmskeyArn?e.kmskeyArn:"",subnetIds:e.vpcConfig?e.vpcConfig.subnetIds:[],securityGroupIds:e.vpcConfig?e.vpcConfig.securityGroupIds:[],vpcId:e.vpcConfig?e.vpcConfig.vpcId:"",operation:"",cloudProvider:e.cloudProvider,region:e.region,targetGroups:Wt(e.targetGroups)?"":e.targetGroups})}normalizeFunction(e){const t=e;return t.credentials=e.account,t}constructNewAwsFunctionTemplate(e){return{role:"",runtime:"",s3bucket:"",s3key:"",handler:"",functionName:"",publish:!1,tags:{},memorySize:128,description:"",credentials:e.defaultCredentials.aws||kn.defaults.account,cloudProvider:"aws",detail:"",region:e.defaultRegions.aws||kn.defaults.region,envVariables:{},tracingConfig:{mode:"PassThrough"},kmskeyArn:"",vpcId:"",subnetIds:[],securityGroupIds:[],timeout:3,deadLetterConfig:{targetArn:""},operation:"",targetGroups:""}}}const Pn=(e,t)=>e.match(/^arn:aws:iam::\d{12}:role\/?\/[a-zA-Z_0-9+=,.@\-/]+/)?void 0:`Invalid role. ${t} must match regular expression: arn:aws:iam::d{12}:role/?[a-zA-Z_0-9+=,.@-_/]+`,Dn=(e,t)=>e.match(/^[0-9A-Za-z.-]*[^.]$/)?void 0:`Invalid S3 Bucket name. ${t} must match regular expression: [0-9A-Za-z.-]*[^.]$`,Bn=(e,t)=>e.match(/arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./)?void 0:`Invalid ARN. ${t} must match regular expression: /arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./`,zn=(e,t)=>Wt(e)?`At least one ${t} is required`:void 0,Fn=(e,t)=>e.match(/^[0-9A-Za-z]*$/)?void 0:`Invalid String Value. ${t} must match regular expression: [0-9A-Za-z]`;class Mn extends Vt.Component{constructor(e){super(e)}validate(e){const t=new i(e);return t.field("role","Role ARN").required().withValidators(Pn),t.validateForm()}render(){return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-11"},Vt.createElement("div",{className:"sp-margin-m-bottom"},Vt.createElement(s,{name:"role",label:"Role ARN",input:e=>Vt.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"}),required:!0}))))}}const $n=["nodejs24.x","nodejs22.x","java25","java21","java17","java11","java8.al2","python3.14","python3.13","python3.12","python3.11","python3.10","dotnet10","dotnet9","dotnet8","ruby4.0","ruby3.4","ruby3.3","provided.al2023","provided.al2"],Ln="(Optional) Stack is naming components of a function, used to create vertical stacks of dependent services for integration testing.",Rn="(Optional) Detail is a string of free-form alphanumeric characters to describe any other variables in naming a function.";class On extends Vt.Component{constructor(){super(...arguments),this.state={accounts:[],existingFunctionNames:[],regions:[]},this.props$=new Ta,this.destroy$=new Ta}validate(e){const t=new i(e);t.field("s3bucket","S3 Bucket Name").optional().withValidators(Dn);const a=t.validateForm();return this.props.isNew&&this.state.existingFunctionNames.includes(this.props.app.name.concat("-").concat(e.functionName))&&(a.functionName=`There is already a function in ${e.credentials}:${e.region} with that name.`),a}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}componentDidMount(){const e=this.props$.pipe(Da(e=>e.formik.values)),t={account$:e.pipe(Da(e=>e.credentials),Ba()),region$:e.pipe(Da(e=>e.region),Ba()),functionName$:e.pipe(Da(e=>e.functionName),Ba()),runtime$:e.pipe(Da(e=>e.runtime),Ba()),s3bucket$:e.pipe(Da(e=>e.s3bucket),Ba()),s3key$:e.pipe(Da(e=>e.s3key),Ba()),handler$:e.pipe(Da(e=>e.handler),Ba())},a=Ia(o.listAccounts("aws")).pipe(za(1)),n=Ga([t.account$,a]).pipe(Fa(([e,t])=>o.getRegionsForAccount(e)),za(1)),r=this.props.app.getDataSource("functions").data$,i=Ga([r,t.account$,t.region$]).pipe(Da(([e,t,a])=>e.filter(e=>e.account===t&&e.region===a).map(e=>e.functionName)),za(1));n.pipe(Ma(t.region$),$a(this.destroy$)).subscribe(([e,t])=>{e.some(e=>e.name===t)||this.props.formik.setFieldValue("region",e[0]&&e[0].name)}),Ga([a,n,i]).pipe($a(this.destroy$)).subscribe(([e,t,a])=>this.setState({accounts:e,regions:t,existingFunctionNames:a}))}render(){const{isNew:e}=this.props,{errors:t,values:a}=this.props.formik,{accounts:r,regions:i}=this.state,o=Na({well:!0,"alert-danger":!!t.functionName,"alert-info":!t.functionName});return Vt.createElement("div",{className:"container-fluid form-horizontal "},e&&Vt.createElement("div",{className:o},Vt.createElement("strong",null,"Your function will be named: "),Vt.createElement(n,{id:"aws.function.name"}),Vt.createElement("span",null,this.props.app.name,"-",a.functionName),Vt.createElement(s,{name:"functionName",input:()=>null})),Vt.createElement(s,{name:"credentials",label:"Account",input:e=>Vt.createElement(c,{...e,stringOptions:r.map(e=>e.name),clearable:!0})}),Vt.createElement(s,{name:"region",label:"Region",input:e=>Vt.createElement(c,{...e,stringOptions:i.map(e=>e.name),clearable:!0})}),Vt.createElement(s,{name:"functionName",label:"Function Name",help:Vt.createElement(n,{id:"aws.function.name"}),input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"runtime",label:"Runtime",help:Vt.createElement(n,{id:"aws.function.runtime"}),input:e=>Vt.createElement(c,{...e,stringOptions:$n,clearable:!0})}),Vt.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Vt.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Vt.createElement(l,{...e,placeholder:"S3 bucket name"})}),Vt.createElement(s,{name:"s3key",label:"S3 Key",help:Vt.createElement(n,{id:"aws.function.s3key"}),input:e=>Vt.createElement(l,{...e,placeholder:"object.zip"})}),Vt.createElement(s,{name:"handler",label:"Handler",help:Vt.createElement(n,{id:"aws.function.handler"}),input:e=>Vt.createElement(l,{...e,placeholder:"filename.method"})}),Vt.createElement(s,{name:"publish",label:"Publish",input:e=>Vt.createElement(d,{...e})}))}}class Vn extends Vt.Component{constructor(e){super(e),this.validate=e=>{const t=new i(e);return t.field("deadLetterConfig.targetArn","Target ARN").optional().withValidators(Bn),t.validateForm()}}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},"Dead Letter Config",Vt.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Vt.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Vt.createElement(l,{...e})}),"X-Ray Tracing",Vt.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Vt.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Vt.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}}class Un extends Vt.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("kmskeyArn","KMS Key ARN").optional().withValidators(Bn),t.validateForm()}}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},Vt.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Vt.createElement(s,{name:"kmskeyArn",label:"Key ARN",help:Vt.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Vt.createElement(l,{...e})}))}}class qn extends Vt.Component{constructor(){super(...arguments),this.validate=()=>({})}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},Vt.createElement(s,{name:"description",label:"Description",input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Vt.createElement(p,{...e,min:128,max:3008})}),Vt.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Vt.createElement(p,{...e,min:1,max:900})}),Vt.createElement(s,{name:"targetGroups",label:"Target Group Name",input:e=>Vt.createElement(l,{...e})}))}}class Hn extends Vt.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("tags","Tag").required().withValidators(zn),t.validateForm()}}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal "},Vt.createElement(s,{name:"tags",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}))}}class Wn{static listVpcs(){return this.cache||(this.cache=m.listNetworksByProvider("aws").then(e=>e.map(e=>(e.label=e.name,e.deprecated=!!e.deprecated,e.deprecated&&(e.label+=" (deprecated)"),e)))),this.cache}static resetCache(){this.cache=null}static getVpcName(e){return this.listVpcs().then(t=>{const a=t.find(t=>t.id===e);return a?a.name:null})}}class jn extends Vt.Component{constructor(e){super(e),this.state={vpcOptions:[],accounts:null,regions:[],subnets:[],availableSubnets:[],securityGroups:null},this.props$=new Ta,this.destroy$=new Ta,this.handleSubnetUpdate=e=>{const t=e.map(e=>e.value);this.props.formik.setFieldValue("subnetIds",t)},this.handleSecurityGroupsUpdate=e=>{const t=e.map(e=>e.value);this.props.formik.setFieldValue("securityGroupIds",t)},this.setVpc=e=>{this.props.formik.setFieldValue("vpcId",e),this.props.formik.setFieldValue("subnetIds",[]);const{availableSubnets:t}=this.state,a=t.filter(function(t){return t.vpcId.includes(e)});this.setState({subnets:a})},this.toSubnetOption=e=>({value:e.subnetId,label:e.subnetId}),this.getSecurityGroupsByVpc=e=>{const{values:t}=this.props.formik,a=[];return jt(e,function(e,n){n===t.credentials&&jt(e,function(e,n){"aws"===n&&jt(e,function(e,n){n===t.region&&e.forEach(function(e){e.vpcId===t.vpcId&&a.push({value:e.id,label:e.name})})})})}),a},this.getSubnetOptions=()=>{const{subnets:e,availableSubnets:t}=this.state,{values:a}=this.props.formik;return!this.props.isNew&&a.vpcId?t.filter(function(e){return e.vpcId.includes(a.vpcId)}).map(this.toSubnetOption):e.map(this.toSubnetOption)},this.getAllVpcs()}getAllVpcs(){Ia(Wn.listVpcs()).pipe($a(this.destroy$)).subscribe(e=>{this.setState({vpcOptions:e})})}validate(){return{}}getAvailableSubnets(){return g.listSubnetsByProvider("aws")}getAvailableSecurityGroups(){return h.securityGroupReader.getAllSecurityGroups()}makeSubnetOptions(e){const t=e.map(e=>({subnetId:e.id,vpcId:e.vpcId}));return Zt(t,"subnetId")}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}componentDidMount(){const e=Promise.resolve(this.getAvailableSubnets()).then(e=>(e.forEach(e=>{e.label=e.id,e.deprecated=!!e.deprecated,e.deprecated&&(e.label+=" (deprecated)")}),e.filter(e=>e.label))).then(e=>this.makeSubnetOptions(e)),t=Promise.resolve(this.getAvailableSecurityGroups());Ga([e,t]).pipe($a(this.destroy$)).subscribe(([e,t])=>this.setState({availableSubnets:e,securityGroups:t}))}render(){const{vpcOptions:e,securityGroups:t}=this.state,{values:a}=this.props.formik,r=this.getSubnetOptions(),i=t?this.getSecurityGroupsByVpc(t):[];return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-11"},Vt.createElement("div",{className:"sp-margin-m-bottom"},a.credentials&&Vt.createElement(s,{name:"vpcId",label:"VPC Id",help:Vt.createElement(n,{id:"aws.function.vpc.id"}),input:t=>Vt.createElement(c,{...t,stringOptions:e.filter(e=>e.account===a.credentials).map(e=>e.id),clearable:!0}),onChange:this.setVpc,required:!1})),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Subnets "),Vt.createElement(n,{id:"aws.function.subnet"})),Vt.createElement("div",{className:"col-md-7"},0===r.length&&Vt.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC"),a.vpcId?Vt.createElement(f,{multi:!0,options:r,value:a.subnetIds,onChange:this.handleSubnetUpdate}):null)),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Security Groups "),Vt.createElement(n,{id:"aws.function.subnet"})),Vt.createElement("div",{className:"col-md-7"},0===i.length&&Vt.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC"),a.credentials&&a.vpcId?Vt.createElement(f,{multi:!0,options:i,value:a.securityGroupIds,onChange:this.handleSecurityGroupsUpdate}):null))))}}const Zn=class e extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.submit=e=>{const{app:t}=this.props,{isNew:a}=this.state,n=_t(e),r=a?"Create":"Update",i=new v({application:t,title:(a?"Creating":"Updating")+" your function",modalInstance:v.modalInstanceEmulation(()=>this.props.dismissModal()),onTaskComplete:()=>{this.checkForS3Update(n,r)}});i.submit(()=>(n.type="lambdaFunction",n.operation=a?"createLambdaFunction":"updateLambdaFunctionConfiguration",y.upsertFunction(n,t,r))),this.setState({taskMonitor:i})};const t=new xn,a=e.functionDef?t.convertFunctionForEditing(e.functionDef):t.constructNewAwsFunctionTemplate(e.app);this.state={isNew:!e.functionDef,functionCommand:a,taskMonitor:null}}static show(t){return b.show(e,t,{dialogClassName:"wizard-modal modal-lg"})}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.functionDetails")?h.$state.go("^.functionDetails",t):h.$state.go(".functionDetails",t)}onTaskComplete(e){this.props.app.functions.refresh(),this.refreshUnsubscribe=this.props.app.functions.onNextRefresh(null,()=>this.onApplicationRefresh(e))}checkForS3Update(e,t){const{isNew:a}=this.state;if(!a&&(e.s3bucket||e.s3key)){e.operation="updateLambdaFunctionCode";const{app:a}=this.props;y.upsertFunction(e,a,t)}this.onTaskComplete(e)}render(){const{app:e,dismissModal:t,forPipelineConfig:a,functionDef:n}=this.props,{isNew:r,functionCommand:i,taskMonitor:s}=this.state;let l=a?"Configure Existing Function":"Create New Function";return r||(l=`Edit ${i.functionName}: ${i.region}: ${i.credentials}`),Vt.createElement(E,{heading:l,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",render:({formik:t,nextIdx:a,wizard:i})=>Vt.createElement(Vt.Fragment,null,Vt.createElement(w,{label:"Basic information",wizard:i,order:a(),render:({innerRef:a})=>Vt.createElement(On,{ref:a,app:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Execution Role",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Mn,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Environment",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Un,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Tags",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Hn,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Settings",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(qn,{ref:e,formik:t,isNew:r,functionDef:n})}),Vt.createElement(w,{label:"Network",wizard:i,order:a(),render:({innerRef:a})=>Vt.createElement(jn,{ref:a,app:e,formik:t,isNew:r})}),Vt.createElement(w,{label:"Debugging and Error Handling",wizard:i,order:a(),render:({innerRef:e})=>Vt.createElement(Vn,{ref:e,formik:t,isNew:r,functionDef:n})}))})}};Zn.defaultProps={closeModal:C,dismissModal:C};let _n=Zn;class Kn extends Vt.Component{constructor(e){super(e),this.editFunction=()=>{const{functionDef:e}=this.props,{application:t}=this.state;_n.show({app:t,functionDef:e})},this.deleteFunction=()=>{const{app:e,functionDef:t,functionFromParams:a}=this.props,n={application:e,title:"Deleting "+a.functionName},r={cloudProvider:t.cloudProvider,functionName:t.functionName,region:t.region,credentials:t.credentials};S.confirm({header:`Really delete ${a.functionName} in ${a.region}: ${a.account}?`,buttonText:`Delete ${a.functionName}`,account:a.account,taskMonitorConfig:n,submitMethod:()=>y.deleteFunction(r,e)})},this.entityTagUpdate=()=>{this.props.app.functions.refresh()},this.state={application:e.app}}componentDidMount(){const{app:e,functionDef:t}=this.props;let a;const n=t.functionName.split("-")[0];n===e.name?a=e:k.getApplication(n).then(e=>{this.setState({application:e})}).catch(()=>{this.setState({application:this.props.app})}),this.setState({application:a})}render(){const{app:e,functionDef:t}=this.props,{application:n}=this.state;return Vt.createElement("div",{style:{display:"inline-block"}},kn.adHocInfraWritesEnabled&&Vt.createElement(qa,{className:"dropdown",id:"function-actions-dropdown"},Vt.createElement(qa.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Vt.createElement("span",null,"Function Actions")),Vt.createElement(qa.Menu,{className:"dropdown-menu"},Vt.createElement("li",{className:n?"":"disabled"},Vt.createElement("a",{className:"clickable",onClick:this.editFunction},"Edit Function")),t.functionName&&Vt.createElement("li",null,Vt.createElement("a",{className:"clickable",onClick:this.deleteFunction},"Delete Function")),a&&a.feature.entityTags&&Vt.createElement(N,{component:t,application:e,entityType:"function",onUpdate:this.entityTagUpdate}))))}}class Yn extends T{get awsInstanceTypeService(){return this.$injector.get("awsInstanceTypeService")}get awsServerGroupCommandBuilder(){return this.$injector.get("awsServerGroupCommandBuilder")}get awsServerGroupConfigurationService(){return this.$injector.get("awsServerGroupConfigurationService")}get awsServerGroupTransformer(){return this.$injector.get("awsServerGroupTransformer")}get functionReader(){return this.$injector.get("functionReader")}get evaluateCloudFormationChangeSetExecutionService(){return this.$injector.get("evaluateCloudFormationChangeSetExecutionService")}initialize(e){this.$injector=e}}const Xn=new Yn;var Jn=Object.getOwnPropertyDescriptor;let Qn=class extends Vt.Component{constructor(e){super(e),this.destroy$=new Ta,this.state={loading:!0}}extractFunction(){const{app:e,functionObj:t}=this.props;e.functions.data.find(e=>e.functionName===t.functionName&&e.region===t.region&&e.account===t.account)?Ia(Xn.functionReader.getFunctionDetails("aws",t.account,t.region,t.functionName)).pipe($a(this.destroy$)).subscribe(e=>{e.length&&this.setState({functionDef:e[0],loading:!1})}):this.setState({functionDef:{},loading:!1})}componentDidMount(){const{app:e}=this.props,t=e.functions;Ia(t.ready()).pipe($a(this.destroy$)).subscribe(()=>{const e=t.onRefresh(null,()=>this.extractFunction());this.setState({dataSourceUnsubscribe:e}),this.extractFunction()})}componentWillUnmount(){this.state.dataSourceUnsubscribe&&this.state.dataSourceUnsubscribe(),this.destroy$.next()}render(){const{app:e}=this.props,{loading:t,functionDef:a}=this.state;if(t)return Vt.createElement(I,{loading:t});const n=Vt.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Last Modified "),Vt.createElement("dd",null,a.lastModified),Vt.createElement("dt",null,"In"),Vt.createElement("dd",null,Vt.createElement(G,{account:a.account})," ",a.region),Vt.createElement("dt",null,"VPC"),Vt.createElement("dd",null,a.vpcConfig?a.vpcConfig.vpcId:"Default"),Vt.createElement("dt",null,"Function ARN"),Vt.createElement("dd",null,a.functionArn),Vt.createElement("dt",null,"Revision ID"),Vt.createElement("dd",null,a.revisionId),Vt.createElement("dt",null,"Version"),Vt.createElement("dd",null,a.version)),r=Vt.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.eventSourceMappings&&0!==a.eventSourceMappings.length?a.eventSourceMappings.map(e=>Vt.createElement(Vt.Fragment,null,Vt.createElement("h5",null,Vt.createElement("strong",null,"Event Source")),Vt.createElement("dl",null,Vt.createElement("dt",null,"ARN"),Vt.createElement("dd",null,e.eventSourceArn),Vt.createElement("dt",null,"State"),Vt.createElement("dd",null,e.state)))):"None"),i=Vt.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.aliasConfigurations&&0!==a.aliasConfigurations.length?a.aliasConfigurations.map(e=>Vt.createElement(Vt.Fragment,null,Vt.createElement("h5",null,Vt.createElement("strong",null,"Alias Details")),Vt.createElement("dl",null,Vt.createElement("dt",null,"Name"),Vt.createElement("dd",null,e.name),Vt.createElement("dt",null,"ARN"),Vt.createElement("dd",null,e.aliasArn)))):"None"),s=Vt.createElement(x,{heading:"Function Details"},n),l=Vt.createElement(x,{heading:"Event Source Details"},r),o=Vt.createElement(x,{heading:"Alias Configuration Details"},i);return Vt.createElement(I,{loading:this.state.loading},Wt(this.state.functionDef)?"Function not found.":Vt.createElement(I.Header,{icon:Vt.createElement("i",{className:"fa fa-xs fa-fw fa-asterisk"}),name:this.state.functionDef.functionName},Vt.createElement("div",{className:"actions"},Vt.createElement(Kn,{app:e,functionDef:a,functionFromParams:{account:this.state.functionDef.account,region:this.state.functionDef.region,functionName:this.state.functionDef.functionName}}))),Wt(this.state.functionDef)?"":s,Wt(this.state.functionDef)||Wt(this.state.functionDef.eventSourceMappings)?"":l,Wt(this.state.functionDef)||Wt(this.state.functionDef.aliasConfigurations)?"":o)}};Qn=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Jn(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([A("function.details","aws")],Qn);const er="spinnaker.amazon.function";t(er,[]);const tr={"aws.associateElasticIp.elasticIp":"<p>(Optional) <b>Elastic IP</b> is an IP address that Spinnaker will associate with this cluster.</p>\n <p>If specified, this elastic IP must exist and not already be attached to an instance or cluster.</p>\n <p>If left blank, Spinnaker will make a selection from the list of available elastic IPs in the provided account and region.</p>","aws.associateElasticIp.type":"<p><b>Type</b> of elastic IP to associate:'\n <ul>\n <li><b>standard</b> is usable in EC2 Classic</li>\n <li><b>vpc</b> is usable in VPC</li>\n </ul>","aws.serverGroup.subnet":"The subnet selection determines the VPC in which your server group will run. Options vary by account and region; the most common ones are:\n <ul>\n <li><b>None (EC2 Classic)</b>: instances will not run in a VPC</li>\n <li><b>internal</b> instances will be restricted to internal clients (i.e. require VPN access)</li>\n <li><b>external</b> instances will be publicly accessible and running in VPC</li>\n </ul>","aws.loadBalancer.subnet":"The subnet selection determines the VPC in which your load balancer will run.<br/>\n This also restricts the server groups which can be serviced by the load balancer.\n Options vary by account and region; the most common ones are:\n <ul>\n <li><b>None (EC2 Classic)</b>: the load balancer will not run in a VPC</li>\n <li><b>internal</b> access to the load balancer will be restricted to internal clients (i.e. require VPN access)</li>\n <li><b>external</b> the load balancer will be publicly accessible and running in VPC</li>\n </ul>","aws.loadBalancer.detail":'<p>(Optional) <b>Detail</b> is a string of free-form alphanumeric characters; by convention, we recommend using "frontend".</p>\n <p>However, if your stack name needs to be longer (load balancer names are limited to 32 characters), consider changing it to "elb", or omit it altogether.</p>',"aws.loadBalancer.internal":"Controls the load balancer scheme, <strong>not</strong> the subnet. By default, load balancers are created with a DNS name that resolves to public IP addresses. Specify internal to create a load balancer with a DNS name that resolves to private IP addresses.","aws.loadBalancer.stack":"(Optional) <b>Stack</b> is one of the core naming components of a cluster, used to create vertical stacks of dependent services for integration testing.","aws.loadBalancer.name":"<p>The load balancer name is formed by combining the application name, the <b>Stack</b> field, and the <b>Detail</b> field.</p>","aws.loadBalancer.targetGroups":"Add a target group if you want to associate this with an Application Load Balancer (ALB) or Network Load Balancer (NLB)","aws.loadBalancer.loadBalancers":"Add a load balancer directly if you created a Classic Load Balancer (a classic load balancer does not have target groups)","aws.loadBalancer.ruleCondition.host":"<p>You can specify a single host name (for example, <em>my.example.com</em>). A host name is case insensitive, can be up to 128 characters in length, and can contain any of the following characters. Note that you can include up to three wildcard characters.</p>\n <ul>\n <li>A-Z, a-z, 0-9</li>\n <li>- .</li>\n <li>* (matches 0 or more characters)</li>\n <li>? (matches exactly 1 character)</li>\n </ul>\n <p>Note that <strong>*.example.com</strong> will match <strong>test.example.com</strong> but won't match <strong>example.com</strong>.</p>","aws.loadBalancer.ruleCondition.path":"<p>You can specify a single path pattern (for example, <em>/img/*</em>). A path pattern is case sensitive, can be up to 128 characters in length, and can contain any of the following characters. Note that you can include up to three wildcard characters.</p>\n <ul>\n <li>A-Z, a-z, 0-9</li>\n <li>_ - . $ / ~ \" ' @ : +</li>\n <li>& (using &amp;)</li>\n <li>* (matches 0 or more characters)</li>\n <li>? (matches exactly 1 character)</li>\n </ul>\n <p>Note that the path pattern is used to route requests but does not alter them. For example, if a rule has a path pattern of <em>/img/*</em>, the rule would forward a request for <em>/img/picture.jpg</em> to the specified target group as a request for <em>/img/picture.jpg</em>.</p>","aws.loadBalancer.oidcAuthentication":"Authentication requires a configured OIDC client.","aws.serverGroup.stack":"(Optional) <b>Stack</b> is one of the core naming components of a cluster, used to create vertical stacks of dependent services for integration testing.","aws.serverGroup.detail":"(Optional) <b>Detail</b> is a string of free-form alphanumeric characters and hyphens to describe any other variables.","aws.serverGroup.imageName":"(Required) <b>Image</b> is the deployable Amazon Machine Image. Images are restricted to the account and region selected.","aws.serverGroup.storageType":"AWS offers various storage options like temporary block-level storage via instance store (SSD, HDD) and Amazon Elastic Block Store (EBS). This column lists the storage type supported for the instance type.","aws.serverGroup.instancesDistribution":'Learn more in <a target="_blank" href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/asg-purchase-options.html">AWS docs</a>.',"aws.serverGroup.spotMaxPrice":"The maximum price per unit hour to pay for a Spot instance. By <b>default (empty)</b>, Amazon EC2 Auto Scaling uses the On-Demand price as the maximum Spot price.","aws.serverGroup.spotAllocationStrategy":"<p>Indicates how to allocate instances across Spot Instance pools.</p>\n <ul>\n <li><b>capacity-optimized (recommended)</b>: Instances launched using Spot pools that are optimally chosen based on the available Spot capacity.</li>\n <li><b>capacity-optimized-prioritized</b>: Instances launched using the priority on a best-effort basis to determine which launch template override to use first, but AWS optimizes for capacity first.</li>\n <li><b>lowest-price (default)</b>: Instances launched using Spot pools with the lowest price, and evenly allocated across the number of Spot pools specified</li>\n </ul>","aws.serverGroup.spotInstancePoolCount":"Number of lowest priced Spot Instance pools to diversify across. Only applicable for strategy 'lowest-price'. <b>Default: 2.</b>","aws.serverGroup.odAllocationStrategy":"The only strategy / <b>default is 'prioritized'</b>. The order specified in the list of selected instance types is used to determine which instance type to use first when fulfilling On-Demand capacity.","aws.serverGroup.odBase":"Minimum amount of the Auto Scaling Group's capacity that must be fulfilled by On-Demand Instances. This base portion is provisioned first as the group scales. <b>Default: 0.</b>","aws.serverGroup.odPercentAboveBase":"Percentages of On-Demand and Spot instances for additional capacity beyond OnDemandBaseCapacity.<b>Default: 100.</b>","aws.serverGroup.instanceTypeWeight":'The number of capacity units gives the instance type a proportional weight to other instance types. When specified, weights count towards desired capacity.\nLearn more in <a target="_blank" href="https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates/#convert-a-server-group-with-launch-template-to-use-mixed-instances-policy-with-multiple-instance-types-and-capacity-weighting">examples and docs</a>.',"aws.serverGroup.instanceTypes":"Specify up to 20 instance types.","aws.serverGroup.instanceTypesSelect":"<p>Filter instance types on one or more criteria, comma separated:\n <ul>\n <li>Minimum vCPU e.g. 16vcpu</li>\n <li>Minimum memory e.g. 32gib</li>\n <li>Spot support</li>\n <li>EBS support</li>\n <li>GPU support</li>\n <li>Instance storage type e.g. ssd</li>\n <li>Generation with 'currentGen' / 'oldGen'</li>\n <li>Instance family / size / type e.g. c3 / large / c3.large</li>\n </ul>\n Examples:\n <ul>\n <li>16vcpu, 32gib, spot, oldGen</li>\n <li>medium, ebs</li>\n <li>ssd,ebs,gpu,currentgen</li>\n </ul>","aws.serverGroup.multipleInstanceTypes":"Instance types a server group can launch, first (highest priority) to last (lowest priority).","aws.serverGroup.unlimitedCpuCredits":"<p>CPU credits can be configured with 2 modes:</p><br/>\n <ul>\n <li><b>Unlimited (i.e. Unlimited On)</b>: Can sustain high CPU utilization for any period of time whenever required.<br/>\n If the average CPU usage over a rolling 24-hour period exceeds the baseline, charges for surplus credits will apply.</li>\n <li><b>Standard (i.e. Unlimited Off)</b>: <b>Default mode in Spinnaker.</b> Suited to workloads with an average CPU utilization that is consistently below the baseline CPU utilization of the instance.<br/>\n To burst above the baseline, the instance spends credits that it has accrued in its CPU credit balance.</li>\n </ul>","aws.serverGroup.capacityRebalance":"Enabling <b>Capacity Rebalance</b> allows EC2 Auto Scaling to proactively replace Spot Instances that have received a rebalance recommendation, <b>before</b> it is interrupted by AWS EC2.","aws.serverGroup.advancedMode":'Advanced mode allows you to configure allocation strategies, multiple instance types with weighting, instance distribution across Spot / On-Demand and their proportions in the server group. Learn more in <a target="_blank" href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/asg-purchase-options.html">AWS docs</a>.',"aws.serverGroup.legacyUdf":"<p>(Optional) <b>User Data Format</b> allows overriding of the format used when generating user data during deployment. The default format used is configured\n in the application's attributes, editable via the 'Config' tab.</p>\n <p><b>Default</b> will use the value from the application's configuration.</p>\n <p><b>Modern</b> will use the modern template.</p>\n <p><b>Legacy</b> will use the legacy (<b>deprecated</b>) template.</p>\n <p>This option is intended to allow testing migration from legacy to modern before configuring it for the entire application. If unsure, pick <b>Default</b>.</p>","aws.serverGroup.base64UserData":"(Optional) <b>UserData</b> is a base64 encoded string.","aws.serverGroup.enabledMetrics":"(Optional) <b>Enabled Metrics</b> are the Auto Scaling Group metrics to enable on this group. Existing metrics are not modified.","aws.serverGroup.imdsv2":"(Recommended) <b>IMDSv2</b> helps mitigate AWS credential theft from the exploitation of SSRF vulnerabilities in web applications. All modern AWS SDKs support IMDSv2 and it should not be disabled unless you're using a legacy SDK.","aws.serverGroup.instanceMonitoring":"(Optional) <b>Instance Monitoring</b> whether to enable detailed monitoring of instances. Group metrics must be disabled to update an ASG with Instance Monitoring set to false.","aws.serverGroup.tags":"(Optional) <b>Tags</b> are propagated to the instances in this cluster.","aws.serverGroup.allImages":"Search for an image that does not match the name of your application.","aws.serverGroup.filterImages":"Select from a pre-filtered list of images matching the name of your application.","aws.serverGroup.traffic":'<p>Enables the "AddToLoadBalancer" scaling process, which is used by Spinnaker and discovery services to determine if the server group is enabled.</p>\n <p>Will be automatically enabled when any non "custom" deployment strategy is selected.</p>',"aws.securityGroup.vpc":'\n <p>The VPC to which this {{firewall}} will apply.</p>\n <p>If you wish to use VPC but are unsure which VPC to use, the most common one is "Main".</p>\n <p>If you do not wish to use VPC, select "None".</p>',"aws.securityGroup.name":"<p>The {{firewall}} name is formed by combining the application name, the <b>Stack</b> field, and the <b>Detail</b> field.</p>","aws.securityGroup.cross.account.ingress.help":"<p>Accounts that are excluded will not show up in this list</p>","aws.scalingPolicy.search.restricted":'<p>Resets dimensions to "AutoScalingGroupName: {name of the ASG}" and provides\n a simpler, combined input for the namespace and metric name fields.</p>',"aws.scalingPolicy.search.all":"\n <p>Allows you to edit the dimensions and namespace to find a specific metric for this alarm.</p>","aws.blockDeviceMappings.useSource":'\n <p>Spinnaker will use the block device mappings of the existing server group when deploying a new server group.</p>\n <p>In the event that there is no existing server group, the\n <a target="_blank" href="https://github.com/spinnaker/clouddriver/blob/master/clouddriver-aws/src/main/groovy/com/netflix/spinnaker/clouddriver/aws/deploy/InstanceTypeUtils.java">defaults</a>\n for the selected instance type will be used.</p>',"aws.blockDeviceMappings.useAMI":"<p>Spinnaker will use the block device mappings from the selected AMI when deploying a new server group.</p>","aws.blockDeviceMappings.useDefaults":'<p>Spinnaker will use the <a target="_blank" href="https://github.com/spinnaker/clouddriver/blob/master/clouddriver-aws/src/main/groovy/com/netflix/spinnaker/clouddriver/aws/deploy/InstanceTypeUtils.java">default block device mappings</a> for the selected instance type when deploying a new server group.</p>',"aws.targetGroup.protocol":"The protocol to use for routing traffic to the targets. Cannot be edited after being saved; if you want to use a different protocol, create a new target group, save the load balancer, move your targets, and then delete this target group.","aws.targetGroup.targetType":"Determines how targets are specified. Only set to ip if you need to attach individual ips. Cannot be edited after being saved; if you want to use a different target type, create a new target group, save the load balancer, move your targets, and then delete this target group.","aws.targetGroup.port":"The port on which the targets receive traffic. Cannot be edited after being saved; if you want to use a different port, create a new target group, save the load balancer, move your targets, and then delete this target group.","aws.targetGroup.attributes.deregistrationDelay":"The amount of time for the load balancer to wait before changing the state of a deregistering target from draining to unused. The range is 0-3600 seconds. The default value is 300 seconds.","aws.targetGroup.attributes.stickinessEnabled":" Indicates whether sticky sessions are enabled.","aws.targetGroup.attributes.deregistrationDelayConnectionTermination":"If enabled, your Network Load Balancer will terminate active connections when deregistration delay is reached.","aws.targetGroup.attributes.preserveClientIp":"If enabled, your Network Load Balancer will preserve client IP addresses to the target.","aws.targetGroup.attributes.stickinessType":"The type of sticky sessions. The only current possible value is <code>lb_cookie</code>.","aws.targetGroup.attributes.stickinessDuration":"The time period, in seconds, during which requests from a client should be routed to the same target. After this time period expires, the load balancer-generated cookie is considered stale. The range is 1 second to 1 week (604800 seconds). The default value is 1 day (86400 seconds).","aws.targetGroup.attributes.healthCheckPort.trafficPort":"The port the load balancer uses when performing health checks on targets. The default is <b>traffic-port</b>, which is the port on which each target receives traffic from the load balancer.","aws.targetGroup.healthCheckProtocol":"TCP health checks only support 10s and 30s intervals","aws.targetGroup.healthCheckTimeout":"Target groups with TCP or TLS protocol must have a 6s timeout for HTTP health checks or a 10s timeout for HTTPS/TLS health checks.","aws.targetGroup.nlbHealthcheckThreshold":"The healthy and unhealthy threshold for NLBs must be equal. This represents the number of successful and failed healthchecks required for healthy and unhealthy targets, respectively.","aws.serverGroup.capacityConstraint":"\n <p>Ensures that the capacity of this server group has not changed in the background (i.e. due to autoscaling activity).</p>\n <p>If the capacity has changed, this resize operation will be rejected.</p>","aws.tagImage.consideredStages":"Limit which previous stages will be considered when locating AMI's to tag. If left unchecked, AMI's generated by any upstream stage will be tagged.","aws.loadBalancer.redirect.host":"The hostname. This component is not percent-encoded. The hostname can contain <code>#{host}</code>.","aws.loadBalancer.redirect.path":'The absolute path, starting with the leading "/". This component is not percent-encoded. The path can contain <code>#{host}</code>, <code>#{path}</code>, and <code>#{port}</code>.',"aws.loadBalancer.redirect.port":"The port. You can specify a value from 1 to 65535 or <code>#{port}</code>.","aws.loadBalancer.redirect.protocol":"The protocol. You can specify HTTP, HTTPS, or <code>#{protocol}</code>. You can redirect HTTP to HTTP, HTTP to HTTPS, and HTTPS to HTTPS. You cannot redirect HTTPS to HTTP.","aws.loadBalancer.redirect.query":'The query parameters, URL-encoded when necessary, but not percent-encoded. Do not include the leading "?", as it is automatically added. You can specify any of the reserved keywords.',"aws.loadBalancer.redirect.statusCode":"The HTTP redirect code. The redirect is either permanent (HTTP 301) or temporary (HTTP 302).","aws.loadBalancer.redirect":'<p>A URI consists of the following components: protocol://hostname:port/path?query. You must modify at least one of the following components to avoid a redirect loop: protocol, hostname, port, or path. Any components that you do not modify retain their original values.\n\n <p>You can reuse URI components using the following reserved keywords:\n\n <ul><li>#{protocol}\n <li>#{host}\n <li>#{port}\n <li>#{path} (the leading "/" is removed)\n <li>#{query}\n </ul>\n <p>For example, you can change the path to "/new/#{path}", the hostname to "example.#{host}", or the query to "#{query}&value=xyz".',"aws.cloudformation.source":"\n <p>Where the template file content is read from.</p>\n <p>\n <b>text:</b> The template is supplied statically to the pipeline from the below text-box.\n </p>\n <p>\n <b>artifact:</b> The template is read from an artifact supplied/created upstream. The expected artifact must be referenced here, and will be bound at runtime.\n </p>\n ","aws.cloudformation.expectedArtifact":"The artifact that is to be applied to this stage. The artifact should represent a valid cloudformation template.","aws.function.name":"Enter a name that describes the purpose of your function. Function name will be prefixed with the application name.","aws.function.runtime":"Choose the language to use to write your function","aws.function.s3key":"The Amazon S3 key of the deployment package","aws.function.handler":"The name of the method within your code that Lambda calls to execute your function. The format includes the file name. It can also include namespaces and other qualifiers, depending on the runtime.","aws.function.s3bucket":"An Amazon S3 bucket in the same AWS Region as your function. The bucket can be in a different AWS account.","aws.function.execution.role":"Lambda will create an execution role with permission to upload logs to Amazon CloudWatch Logs. You can also choose an existing role that defines the permissions of your function.","aws.function.env.vars":"You can define environment variables as key-value pairs that are accessible from your function code. These are useful to store configuration settings without the need to change function code","aws.function.tags":"You can use tags to group and filter your functions. A tag consists of a case-sensitive key-value pair","aws.functionBasicSettings.memorySize":"Your function is allocated CPU proportional to the memory configured.","aws.functionBasicSettings.timeout":"The amount of time that Lambda allows a function to run before stopping it. The default is 3 seconds. The maximum allowed value is 900 seconds.","aws.function.publish":"Set to true to publish the first version of the function during creation.","aws.function.deadletterqueue":"A dead letter queue configuration that specifies the queue or topic where Lambda sends asynchronous events when they fail processing. (SNS or SQS)","aws.function.tracingConfig.mode":"The function's AWS X-Ray tracing configuration.","aws.function.kmsKeyArn":"The ARN of the AWS Key Management Service (AWS KMS) key that's used to encrypt your function's environment variables. If it's not provided, AWS Lambda uses a default service key.","aws.cloudformation.changeSet.options":"<p>Action to take when the created ChangeSet contains a replacement.</p>\n <p>\n <b>ask:</b> Execution will be put on hold asking for user feedback.\n </p>\n <p>\n <b>skip it:</b> ChangeSet will not be executed and stage will continue.\n </p>\n <p>\n <b>execute it</b> ChangeSet will be executed.\n </p>\n <p>\n <b>fail stage</b> ChangeSet will not be executed and the stage will fail.\n </p>"};Object.keys(tr).forEach(e=>P.register(e,tr[e]));class ar{findImages(e){return!e.q||e.q.length<3?Xa.when([{message:"Please enter at least 3 characters...",disabled:!0}]):D("/images/find").query(e).get().catch(()=>[])}getImage(e,t,a){return D("/images").path(a,t,e).query({provider:"aws"}).get().then(e=>e&&e.length?e[0]:null).catch(()=>null)}}var nr,rr,ir,sr,lr,or;const cr={type:"m5",description:"m5 instances provide a balance of compute, memory, and network resources. They are a good choice for most applications.",instanceTypes:[{name:"m5.large",label:"Large",cpu:2,memory:8,storage:{type:"EBS"},costFactor:2},{name:"m5.xlarge",label:"XLarge",cpu:4,memory:16,storage:{type:"EBS"},costFactor:3},{name:"m5.2xlarge",label:"2XLarge",cpu:8,memory:32,storage:{type:"EBS"},costFactor:4}]},dr=[{type:"general",label:"General Purpose",families:[cr,{type:"t2",description:"t2 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t2.small",label:"Small",cpu:1,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:12},{name:"t2.medium",label:"Medium",cpu:2,memory:4,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24},{name:"t2.large",label:"Large",cpu:2,memory:8,storage:{type:"EBS"},costFactor:2,cpuCreditsPerHour:36},{name:"t2.xlarge",label:"XLarge",cpu:4,memory:16,storage:{type:"EBS"},costFactor:3,cpuCreditsPerHour:54},{name:"t2.2xlarge",label:"2XLarge",cpu:8,memory:32,storage:{type:"EBS"},costFactor:4,cpuCreditsPerHour:81}]},{type:"t3",description:"t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t3.small",label:"Small",cpu:2,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24},{name:"t3.medium",label:"Medium",cpu:2,memory:4,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24},{name:"t3.large",label:"Large",cpu:2,memory:8,storage:{type:"EBS"},costFactor:2,cpuCreditsPerHour:36},{name:"t3.xlarge",label:"XLarge",cpu:4,memory:16,storage:{type:"EBS"},costFactor:3,cpuCreditsPerHour:96},{name:"t3.2xlarge",label:"2XLarge",cpu:8,memory:32,storage:{type:"EBS"},costFactor:4,cpuCreditsPerHour:192}]}],icon:"hdd",showCpuCredits:!0,descriptionListOverride:[cr.description,"t2/t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases)."]},{type:"memory",label:"High Memory",families:[{type:"r5",description:"r5 instances are optimized for memory-intensive applications and have the lowest cost per GiB of RAM among Amazon EC2 instance types.",instanceTypes:[{name:"r5.large",label:"Large",cpu:2,memory:16,storage:{type:"EBS"},costFactor:1},{name:"r5.xlarge",label:"XLarge",cpu:4,memory:32,storage:{type:"EBS"},costFactor:2},{name:"r5.2xlarge",label:"2XLarge",cpu:8,memory:64,storage:{type:"EBS"},costFactor:2},{name:"r5.4xlarge",label:"4XLarge",cpu:16,memory:128,storage:{type:"EBS"},costFactor:3}]}],icon:"hdd"},{type:"micro",label:"Micro Utility",families:[{type:"t2",description:"t2 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t2.nano",label:"Nano",cpu:1,memory:.5,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:3},{name:"t2.micro",label:"Micro",cpu:1,memory:1,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:6},{name:"t2.small",label:"Small",cpu:1,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:12}]},{type:"t3",description:"t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases).",instanceTypes:[{name:"t3.nano",label:"Nano",cpu:2,memory:.5,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:6},{name:"t3.micro",label:"Micro",cpu:2,memory:1,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:12},{name:"t3.small",label:"Small",cpu:2,memory:2,storage:{type:"EBS"},costFactor:1,cpuCreditsPerHour:24}]}],icon:"hdd",showCpuCredits:!0,descriptionListOverride:["t2/t3 instances are a good choice for workloads that don’t use the full CPU often or consistently, but occasionally need to burst (e.g. web servers, developer environments and small databases)."]},{type:"custom",label:"Custom Type",families:[],icon:"asterisk"}],ur=null!=(ir=null==(rr=null==(nr=kn.instanceTypes)?void 0:nr.exclude)?void 0:rr.categories)?ir:[],pr=null!=(or=null==(lr=null==(sr=kn.instanceTypes)?void 0:sr.exclude)?void 0:lr.families)?or:[],mr=dr.filter(({type:e})=>!ur.includes(e)).map(e=>Object.assign({},e,{families:e.families.filter(({type:e})=>!pr.includes(e))})),gr="spinnaker.amazon.instanceType.service";t(gr,[]).factory("awsInstanceTypeService",["$q",function(e){const t=["xlarge","large","medium","small","micro","nano"];const a={ec2ClassicSupported:["m1","m3","t1","c1","c3","cc2","cr1","m2","r3","d2","hs1","i2","g2"],ebsOptimized:["c4","d2","f1","g3","i3","m4","m5","p2","r4","r5","x1"],burstablePerf:["t2","t3","t3a","t4g"]};return{getCategories:function(){return e.when(mr)},getAvailableTypesForRegions:function(e,a){let n=[];return(a=a||[])&&a.length&&(n=e[a[0]]||[]),a.forEach(function(t){e[t]&&(n=Ht.intersectionBy(n,e[t],"name"))}),null==n?void 0:n.sort((e,a)=>function(e,a){const n=e.split("."),r=a.split("."),[i,s=""]=n,[l,o=""]=r;if(i!==l)return i>l?1:i<l?-1:0;const c=t.findIndex(e=>s.endsWith(e)),d=t.findIndex(e=>o.endsWith(e));if(-1===c||-1===d)return 0;if(0===c&&0===d){const e=parseInt(s.replace("xlarge",""))||0,t=parseInt(o.replace("xlarge",""))||0;return t<e?1:t>e?-1:0}return c>d?-1:c<d?1:0}(e.name,a.name))},getAllTypesByRegion:function(){return D("/instanceTypes").get().then(function(e){return Ht.chain(e).map(function(e){return{...e,key:[e.region,e.account,e.name].join(":")}}).uniqBy("key").groupBy("region").value()})},filterInstanceTypes:function(e,t,n,r){return Ht.filter(e,function(e){return"*"===t&&"*"===r||!(!n&&!a.ec2ClassicSupported.includes(e.name.split(".")[0]))&&(!(t&&e.supportedVirtualizationTypes&&!e.supportedVirtualizationTypes.includes(t))&&!(r&&e.supportedArchitectures&&!e.supportedArchitectures.includes(r)))})},isEbsOptimized:function(e){if(!e)return!1;const t=Ht.split(e,".",1)[0];return a.ebsOptimized.includes(t)},isBurstingSupportedForAllTypes:function(e){return!(!e||!e.length)&&e.every(e=>function(e){if(!e)return!1;const t=Ht.split(e,".",1)[0];return a.burstablePerf.includes(t)}(e))},getInstanceTypesInCategory:function(e,t){var a;if(!e||!e.length||!t)return[];if("custom"===t)return e;const n=Ht.flatten(null==(a=Ht.find(dr,{type:t}))?void 0:a.families.map(e=>e.instanceTypes.map(e=>e.name)));return Ht.intersection(e,n)}}}]);const hr=({account:e,availabilityZone:t,instanceType:a,capacityType:n,launchTime:r,provider:i,region:s,serverGroup:l,showInstanceType:o})=>Vt.createElement(Vt.Fragment,null,Vt.createElement(B,{label:"Launched",value:r?z(r):"Unknown"}),Vt.createElement(B,{label:"In",value:Vt.createElement("div",null,Vt.createElement(G,{account:e}),t||"Unknown")}),o&&Vt.createElement(B,{label:"Type",value:a||"Unknown"}),o&&n&&Vt.createElement(B,{label:"Capacity Type",value:n||"Unknown"}),l&&Vt.createElement(B,{label:"Server Group",value:Vt.createElement("div",null,Vt.createElement(tn,null,Vt.createElement(Qa,{to:"^.serverGroup",params:{region:s,accountId:e,serverGroup:l,provider:i}},Vt.createElement("a",null,l))))})),fr="None (EC2 Classic)";function vr(e){const{vpcId:t}=e,a=F(async()=>{const t=await Wn.getVpcName(e.vpcId);return t?`${t} (${e.vpcId})`:`(${e.vpcId})`},fr,[t]),n=t?a.result:fr;return Vt.createElement("span",{className:"vpc-tag"},n)}const yr="spinnaker.application.amazonInstanceInformation.component";t(yr,[]).component("amazonInstanceInformation",Ja(L(({instance:e})=>{const{imageId:t,serverGroup:a,subnetId:n,vpcId:r}=e;return Vt.createElement(x,{heading:"Instance Information",defaultExpanded:!0},Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement(hr,{account:e.account,availabilityZone:e.availabilityZone,instanceType:e.instanceType,capacityType:e.capacityType,launchTime:e.launchTime,provider:e.provider,region:e.region,serverGroup:e.serverGroup,showInstanceType:!0}),a&&Vt.createElement(B,{label:"VPC",value:Vt.createElement(vr,{vpcId:r})}),n&&Vt.createElement(B,{label:"Subnet",value:Vt.createElement(M,{subnetId:n})}),t&&Vt.createElement(B,{label:"Image ID",value:t})))},"amazonInstanceInformation"),["instance"]));class br extends R{static deregisterInstancesFromTargetGroup(e,t,a){const n=super.buildMultiInstanceJob(e,"deregisterInstancesFromLoadBalancer");n.forEach(e=>e.targetGroupNames=a);const r=super.buildMultiInstanceDescriptor(n,"Deregister",`from ${a.join(" and ")}`);return O.executeTask({job:n,application:t,description:r})}static deregisterInstanceFromTargetGroup(e,t,a={}){return a.type="deregisterInstancesFromLoadBalancer",a.instanceIds=[e.id],a.targetGroupNames=e.targetGroups,a.region=e.region,a.credentials=e.account,a.cloudProvider=e.cloudProvider,O.executeTask({job:[a],application:t,description:`Deregister instance: ${e.id}`})}static registerInstancesWithTargetGroup(e,t,a){const n=super.buildMultiInstanceJob(e,"registerInstancesWithLoadBalancer");n.forEach(e=>e.targetGroupNames=a);const r=super.buildMultiInstanceDescriptor(n,"Register",`with ${a.join(" and ")}`);return O.executeTask({job:n,application:t,description:r})}static registerInstanceWithTargetGroup(e,t,a={}){return a.type="registerInstancesWithLoadBalancer",a.instanceIds=[e.id],a.targetGroupNames=e.targetGroups,a.region=e.region,a.credentials=e.account,a.cloudProvider=e.cloudProvider,O.executeTask({job:[a],application:t,description:`Register instance: ${e.id}`})}}const Er=e=>{const t=e.map(e=>e.targetGroups);return Kt(t)},wr=(e,t,a)=>{e.forEach(e=>{"TargetGroup"===e.type&&e.targetGroups.forEach(e=>{var n,r,i;const s=null!=(n=t.find(t=>t.name===e.name&&t.account===a))?n:{},l="traffic-port"===s.healthCheckPort||Yt(s.healthCheckPort)?s.port:s.healthCheckPort;e.healthCheckProtocol=null==(r=s.healthCheckProtocol)?void 0:r.toLowerCase(),e.healthCheckPath=`:${l}${null!=(i=s.healthCheckPath)?i:""}`})})},Cr="spinnaker.amazon.instance.details.controller";t(Cr,[an,nn]).controller("awsInstanceDetailsCtrl",["$scope","$state","instance","app","moniker","environment","$q","overrides",function(e,t,n,r,i,s,l,o){function c(){const t={};let a,i,s,c,u,p,m;return r.serverGroups?(r.serverGroups.data.some(function(e){return e.instances.some(function(r){if(r.id===n.instanceId)return a=r,i=e.loadBalancers,s=e.targetGroups,c=e.account,u=e.region,p=e.vpcId,m=e.isDisabled,t.serverGroup=e.name,t.vpcId=e.vpcId,!0})}),a||(r.loadBalancers.data.some(function(e){return e.instances.some(function(t){if(t.id===n.instanceId)return a=t,i=[e.name],c=e.account,u=e.region,p=e.vpcId,!0})||e.targetGroups.some(function(t){return t.instances.some(function(r){if(r.id===n.instanceId)return a=r,s=[t.name],c=e.account,u=e.region,p=e.vpcId,!0})})}),a||r.loadBalancers.data.some(function(e){return e.serverGroups.some(function(t){return!!t.isDisabled&&t.instances.some(function(t){if(t.id===n.instanceId)return a=t,i=[e.name],c=e.account,u=e.region,p=e.vpcId,!0})})||e.targetGroups.some(function(t){t.serverGroups.some(function(t){return!!t.isDisabled&&t.instances.some(function(t){if(t.id===n.instanceId)return a=t,i=[e.name],c=e.account,u=e.region,p=e.vpcId,!0})})})}))):(a={id:n.instanceId},i=[],s=[],c=n.account,u=n.region),a&&c&&u?(a.account=c,t.account=c,t.region=u,q.addExtraDataToLatest("instances",t),H.getInstanceDetails(c,u,n.instanceId).then(t=>{if(!e.$$destroyed){if(e.state.loading=!1,function(t,a){r.isStandalone&&(t.health=a.health),t.health=t.health||[];const n=t.health.filter(function(e){return"Amazon"!==e.type||"Unknown"!==e.state});if(!r.isStandalone){const e=Er(r.loadBalancers.data.filter(function(e){return"aws"===e.cloudProvider}));wr(n,e,t.account)}a.health&&n.forEach(function(e){const t=a.health.filter(function(t){return t.type===e.type});t.length&&Ht.defaults(e,t[0])}),e.healthMetrics=n}(a,t),e.instance=Ht.defaults(t,a),e.instance.account=c,e.instance.region=u,e.instance.vpcId=p,e.instance.serverGroupDisabled=m,e.instance.loadBalancers=i,e.instance.targetGroups=s,e.instance.networkInterfaces){e.instance.ipv6Addresses=Ht.flatMap(e.instance.networkInterfaces,t=>t.ipv6Addresses.map(t=>({ip:t.ipv6Address,url:`http://${t.ipv6Address}:${e.state.instancePort}`})));const t=e.instance.networkInterfaces.filter(e=>!1===e.attachment.deleteOnTermination);t.length&&(e.instance.permanentIps=t.map(e=>e.privateIpAddress))}e.baseIpAddress=t.publicDnsName||t.privateIpAddress,o.instanceDetailsLoaded&&o.instanceDetailsLoaded()}},d)):(a||(e.instanceIdNotFound=n.instanceId,e.state.loading=!1),l.when(null))}function d(){e.$$destroyed||(r.isStandalone?(e.state.loading=!1,e.instanceIdNotFound=n.instanceId,e.state.notFoundStandalone=!0,q.removeLastItem("instances")):t.go("^",{allowModalToStayOpen:!0},{location:"replace"}))}e.isDisabled=!kn.adHocInfraWritesEnabled,e.detailsTemplateUrl=V.getValue("aws","instance.detailsTemplateUrl"),e.state={loading:!0,standalone:r.isStandalone,instancePort:Ht.get(r,"attributes.instancePort")||a.defaultInstancePort||80},e.application=r,e.moniker=i,e.environment=s,e.securityGroupsLabel=U.get("Firewalls"),this.canDeregisterFromLoadBalancer=function(){return(e.instance.health||[]).some(function(e){return"LoadBalancer"===e.type})},this.canRegisterWithLoadBalancer=function(){const t=e.instance,a=t.health||[];if(!t.loadBalancers||!t.loadBalancers.length)return!1;const n=a.some(function(e){return"LoadBalancer"===e.type&&"OutOfService"===e.state}),r=a.some(function(e){return"LoadBalancer"===e.type});return n||!r},this.canDeregisterFromTargetGroup=function(){return(e.instance.health||[]).some(function(e){return"TargetGroup"===e.type&&"OutOfService"!==e.state})},this.canRegisterWithTargetGroup=function(){const t=e.instance,a=t.health||[];if(!t.targetGroups||!t.targetGroups.length)return!1;const n=a.some(function(e){return"TargetGroup"===e.type&&"OutOfService"===e.state}),r=a.some(function(e){return"TargetGroup"===e.type});return n||!r},this.canRegisterWithDiscovery=function(){const t=(e.instance.health||[]).filter(function(e){return"Discovery"===e.type});return!!t.length&&"OutOfService"===t[0].state},this.terminateInstance=function(){const a=e.instance,n={application:r,title:"Terminating "+a.instanceId,onTaskComplete:function(){t.includes("**.instanceDetails",{instanceId:a.instanceId})&&t.go("^")}};S.confirm({header:"Really terminate "+a.instanceId+"?",buttonText:"Terminate "+a.instanceId,account:a.account,taskMonitorConfig:n,submitMethod:function(){return br.terminateInstance(a,r)}})},this.terminateInstanceAndShrinkServerGroup=function(){const a=e.instance,n={application:r,title:"Terminating "+a.instanceId+" and shrinking server group",onTaskComplete:function(){t.includes("**.instanceDetails",{instanceId:a.instanceId})&&t.go("^")}};S.confirm({header:"Really terminate "+a.instanceId+" and shrink "+a.serverGroup+"?",buttonText:"Terminate "+a.instanceId+" and shrink "+a.serverGroup,account:a.account,taskMonitorConfig:n,submitMethod:function(){return br.terminateInstanceAndShrinkServerGroup(a,r)}})},this.rebootInstance=function(){const t=e.instance,a={application:r,title:"Rebooting "+t.instanceId};S.confirm({header:"Really reboot "+t.instanceId+"?",buttonText:"Reboot "+t.instanceId,account:t.account,platformHealthOnlyShowOverride:r.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon",taskMonitorConfig:a,submitMethod:(e={})=>(r.attributes&&r.attributes.platformHealthOnlyShowOverride&&r.attributes.platformHealthOnly&&(e.interestingHealthProviderNames=["Amazon"]),br.rebootInstance(t,r,e))})},this.registerInstanceWithLoadBalancer=function(){const t=e.instance,a=t.loadBalancers.join(" and "),n={application:r,title:"Registering "+t.instanceId+" with "+a};S.confirm({header:"Really register "+t.instanceId+" with "+a+"?",buttonText:"Register "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return br.registerInstanceWithLoadBalancer(t,r)}})},this.deregisterInstanceFromLoadBalancer=function(){const t=e.instance,a=t.loadBalancers.join(" and "),n={application:r,title:"Deregistering "+t.instanceId+" from "+a};S.confirm({header:"Really deregister "+t.instanceId+" from "+a+"?",buttonText:"Deregister "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return br.deregisterInstanceFromLoadBalancer(t,r)}})},this.registerInstanceWithTargetGroup=function(){const t=e.instance,a=t.targetGroups.join(" and "),n={application:r,title:"Registering "+t.instanceId+" with "+a};S.confirm({header:"Really register "+t.instanceId+" with "+a+"?",buttonText:"Register "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return br.registerInstanceWithTargetGroup(t,r)}})},this.deregisterInstanceFromTargetGroup=function(){const t=e.instance,a=t.targetGroups.join(" and "),n={application:r,title:"Deregistering "+t.instanceId+" from "+a};S.confirm({header:"Really deregister "+t.instanceId+" from "+a+"?",buttonText:"Deregister "+t.instanceId,account:t.account,taskMonitorConfig:n,submitMethod:function(){return br.deregisterInstanceFromTargetGroup(t,r)}})},this.enableInstanceInDiscovery=function(){const t=e.instance,a={application:r,title:"Enabling "+t.instanceId+" in discovery"};S.confirm({header:"Really enable "+t.instanceId+" in discovery?",buttonText:"Enable "+t.instanceId,account:t.account,taskMonitorConfig:a,submitMethod:function(){return br.enableInstanceInDiscovery(t,r)}})},this.disableInstanceInDiscovery=function(){const t=e.instance,a={application:r,title:"Disabling "+t.instanceId+" in discovery"};S.confirm({header:"Really disable "+t.instanceId+" in discovery?",buttonText:"Disable "+t.instanceId,account:t.account,taskMonitorConfig:a,submitMethod:function(){return br.disableInstanceInDiscovery(t,r)}})},this.hasHealthState=function(t,a){return(e.instance.health||[]).some(function(e){return e.type===t&&e.state===a})};const u=e=>{const t=[{label:"Reboot",triggerAction:this.rebootInstance},{label:"Terminate",triggerAction:this.terminateInstance},{label:"Terminate and Shrink Server Group",triggerAction:this.terminateInstanceAndShrinkServerGroup}],a=[];return this.canRegisterWithDiscovery()&&!e.serverGroupDisabled&&a.push({label:"Enable In Discovery",triggerAction:this.enableInstanceInDiscovery}),(this.hasHealthState("Discovery","Up")||this.hasHealthState("Discovery","Down"))&&a.push({label:"Disable in Discovery",triggerAction:this.disableInstanceInDiscovery}),this.canRegisterWithLoadBalancer()&&a.push({label:"Register with Load Balancer",triggerAction:this.registerInstanceWithLoadBalancer}),this.canDeregisterFromLoadBalancer()&&a.push({label:"Deregister from Load Balancer",triggerAction:this.deregisterInstanceFromLoadBalancer}),this.canRegisterWithTargetGroup()&&a.push({label:"Register with Target Group",triggerAction:this.registerInstanceWithTargetGroup}),this.canDeregisterFromTargetGroup()&&a.push({label:"Deregister from Target Group",triggerAction:this.deregisterInstanceFromTargetGroup}),a.concat(t)};(r.isStandalone?c():l.all([r.serverGroups.ready(),r.loadBalancers.ready()]).then(c)).then(()=>{e.instanceActions=u(e.instance),e.$$destroyed||r.isStandalone||r.serverGroups.onRefresh(e,c)}),e.account=n.account}]);const Sr=({instancePort:e,ipv6Addresses:t,permanentIps:a,privateDnsName:n,privateIpAddress:r,publicDnsName:i,publicIpAddress:s})=>{const l=e?`:${e}`:"";return Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},n&&Ot.createElement(B,{label:"Private DNS Name",value:Ot.createElement(j,{text:n,url:`http://${n}${l}`})}),i&&Ot.createElement(B,{label:"Public DNS Name",value:Ot.createElement(j,{text:i,url:`http://${i}${l}`})}),r&&Ot.createElement(B,{label:"Private IP Address",value:Ot.createElement(j,{text:r,url:`http://${r}${l}`})}),Boolean(null==a?void 0:a.length)&&Ot.createElement(B,{label:"Permanent IP Address",value:a.map(e=>Ot.createElement(j,{key:e,text:e,url:`http://${e}${l}`}))}),s&&Ot.createElement(B,{label:"Public IP Address",value:Ot.createElement(j,{text:s,url:`http://${s}${l}`})}),Boolean(null==t?void 0:t.length)&&Ot.createElement(B,{label:"IPv6 Address"+(t.length>1?"es":""),value:t.map(e=>Ot.createElement(j,{key:e.ip,text:e.ip,url:e.url}))}))},kr="spinnaker.application.instanceDns.component";t(kr,[]).component("instanceDns",Ja(L(Sr,"instanceDns"),["instancePort","ipv6Addresses","permanentIps","privateDnsName","privateIpAddress","publicDnsName","publicIpAddress"]));const Nr="spinnaker.application.instanceSecurityGroups.component";t(Nr,[]).component("instanceSecurityGroups",Ja(L(({instance:e})=>{const{account:t,region:a,provider:n,securityGroups:r,vpcId:i}=e,s=Xt(r,["groupName"],["asc"]),l=U.get("Firewalls");return Vt.createElement(x,{heading:l,defaultExpanded:!0},Vt.createElement(tn,null,Vt.createElement("ul",null,(s||[]).map(e=>Vt.createElement("li",{key:e.groupId},Vt.createElement(Qa,{to:"^.firewallDetails",params:{name:e.groupName,accountId:t,region:a,vpcId:i,provider:n}},Vt.createElement("a",null,e.groupName," (",e.groupId,")")))))))},"instanceSecurityGroups"),["instance"]));const Tr=({healthMetrics:e,healthState:t,metricTypes:a,customHealthUrl:n,privateIpAddress:r})=>{const i=a.includes("LoadBalancer"),s=a.includes("TargetGroup");return Vt.createElement(x,{heading:"Status",defaultExpanded:!0},!e.length&&Vt.createElement("p",null,"Starting"===t?"Starting":"No health metrics found for this instance"),Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},e.sort((e,t)=>e.type<t.type?-1:e.type>t.type?1:0).map(e=>Vt.createElement(Vt.Fragment,{key:`${e.type}-${e.description}`},Vt.createElement("dt",null,Z(e.type)),Vt.createElement("dd",null,!a.includes(e.type)&&Vt.createElement("div",null,Vt.createElement(_,{value:"down"===e.state.toLowerCase()?e.description:"",placement:"left"},Vt.createElement("span",null,Vt.createElement("span",{className:`glyphicon glyphicon-${e.state}-triangle`}),Vt.createElement("span",null,Z(e.state)))),Vt.createElement("span",{className:"pad-left small"},e.healthCheckUrl&&Vt.createElement("a",{target:"_blank",href:e.healthCheckUrl},"Health Check"),e.healthCheckUrl&&e.statusPageUrl&&Vt.createElement("span",null," | "),e.statusPageUrl&&Vt.createElement("a",{target:"_blank",href:e.statusPageUrl},"Status"),n&&e.type===n.type&&Vt.createElement("span",null," ","|"," ",Vt.createElement("a",{target:"_blank",href:n.href},n.text)))),i&&"LoadBalancer"===e.type&&(e.loadBalancers||[]).map(e=>Vt.createElement(K,{key:`lb-${e.name}`,loadBalancer:e})),s&&"TargetGroup"===e.type&&(e.targetGroups||[]).map(e=>Vt.createElement(K,{key:`tg-${e.name}`,loadBalancer:e,ipAddress:r})))))))},Ir="spinnaker.application.instanceStatus.component";t(Ir,[]).component("instanceStatus",Ja(L(Tr,"instanceStatus"),["healthMetrics","healthState","metricTypes","customHealthUrl","privateIpAddress"]));const Gr="spinnaker.application.instanceTags.component";function Ar(e,t){void 0===t&&(t={});var a=t.insertAt;if(e&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],r=document.createElement("style");r.type="text/css","top"===a&&n.firstChild?n.insertBefore(r,n.firstChild):n.appendChild(r),r.styleSheet?r.styleSheet.cssText=e:r.appendChild(document.createTextNode(e))}}t(Gr,[]).component("instanceTags",Ja(L(({tags:e})=>{const t=Xt(e,["key"],["asc"]);return Vt.createElement(x,{heading:"Tags",defaultExpanded:!0},!e.length&&Vt.createElement("div",null,"No tags associated with this server"),e.length&&t.map(e=>Vt.createElement(B,{key:e.key,label:e.key,value:e.value})))},"instanceTags"),["tags"]));Ar(".target-group-title {\n color: var(--color-mineshaft);\n font-weight: 600;\n font-size: 14px;\n padding-right: 15px;\n text-transform: uppercase;\n padding-left: 10px;\n}\n.cluster-container .target-group-container {\n margin-top: 3px;\n}\n.cluster-container .target-group-container:not(:first-child) {\n padding-top: 5px;\n}\n.target-group-container .target-group-header {\n padding: 4px 0;\n}\n.target-group-container .server-group-title {\n padding-top: 0;\n}\n.target-group-container .server-group-title .clickable-row {\n margin-top: -1px;\n}\n.target-group-container .no-margin-y {\n margin-top: -1px !important;\n margin-bottom: 0 !important;\n}\n.target-group-container > div > .text-right {\n padding-right: 10px;\n font-weight: 600;\n}\n.listener-targets {\n display: inline-block;\n vertical-align: top;\n}\n");class xr extends Vt.Component{render(){const{targetGroup:e,showInstances:t,showServerGroups:a,loadBalancer:n}=this.props,r=Xt(e.serverGroups,["isDisabled","name"],["asc","desc"]).map(e=>Vt.createElement(Y,{key:e.name,account:e.account,region:e.region,serverGroup:e,showInstances:t})),i={loadBalancerName:n.name,region:e.region,accountId:e.account,name:e.name,vpcId:e.vpcId,provider:e.cloudProvider};return Vt.createElement("div",{className:"target-group-container container-fluid no-padding"},Vt.createElement(en,{class:"active"},Vt.createElement(Qa,{to:".targetGroupDetails",params:i},Vt.createElement("div",{className:"clickable clickable-row row no-margin-y target-group-header"},Vt.createElement("div",{className:"col-md-8 target-group-title"},e.name),Vt.createElement("div",{className:"col-md-4 text-right"},Vt.createElement(X,{container:e.instanceCounts}))))),a&&r,!a&&t&&Vt.createElement(J,{serverGroups:e.serverGroups,instances:e.instances}))}}class Pr extends Vt.Component{shouldComponentUpdate(e){return e.showInstances!==this.props.showInstances||e.showServerGroups!==this.props.showServerGroups||e.loadBalancer!==this.props.loadBalancer||(()=>!Jt((e.serverGroups||[]).map(e=>e.name),(this.props.serverGroups||[]).map(e=>e.name)))()||(()=>!Jt((e.loadBalancer.targetGroups||[]).map(e=>e.name),(this.props.loadBalancer.targetGroups||[]).map(e=>e.name)))()}render(){const{loadBalancer:e,showInstances:t,showServerGroups:a}=this.props;if("classic"!==e.loadBalancerType){const n=e.targetGroups.map(n=>Vt.createElement(xr,{key:n.name,loadBalancer:e,targetGroup:n,showInstances:t,showServerGroups:a}));return Vt.createElement("div",{className:"cluster-container"},n)}return Vt.createElement(Q,{...this.props})}}class Dr{static buildTargetGroup(e,t){if(!e)return null;const a={name:e.name,vpcId:e.vpcId,cloudProvider:e.cloudProvider,account:e.account,region:e.region,loadBalancerNames:e.loadBalancerNames,instanceCounts:{up:0,down:0,succeeded:0,failed:0,outOfService:0,unknown:0,starting:0}};return t.instances.forEach(t=>{const n=t.health.find(e=>"TargetGroup"===e.type);if(n){const t=n.targetGroups.find(t=>t.name===e.name);if(void 0!==t&&void 0!==t.healthState){const e=t.healthState.toLowerCase();void 0!==a.instanceCounts[e]&&a.instanceCounts[e]++}}}),a}static populateTargetGroups(e,t){return Xa.all([o.getAccountDetails(t.account),e.getDataSource("loadBalancers").ready()]).then(a=>{const n=a[0]&&a[0].awsAccount||t.account,r=e.loadBalancers.data.filter(e=>"application"===e.loadBalancerType||"network"===e.loadBalancerType);return t.targetGroups.map(e=>{const a=Kt(r.map(e=>e.targetGroups||[])).find(a=>a.name===e&&a.region===t.region&&a.account===n);return this.buildTargetGroup(a,t)}).filter(e=>e)})}}class Br extends Vt.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Vt.createElement("a",{onClick:this.onClick},Vt.createElement("span",{className:"name"},this.props.loadBalancer.name),Vt.createElement(X,{container:this.props.loadBalancer.instanceCounts}))}}class zr extends Vt.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Vt.createElement(_,{value:`${this.props.label||"Load Balancer"}: ${this.props.loadBalancer.name}`},Vt.createElement("button",{className:"btn btn-link no-padding",onClick:this.onClick},Vt.createElement("span",{className:"badge badge-counter"},Vt.createElement("span",{className:"icon"},Vt.createElement("i",{className:"fa icon-sitemap"})))))}}class Fr extends Vt.Component{constructor(e){super(e),this.mounted=!1,this.showLoadBalancerDetails=e=>{const{$state:t}=h,a=this.props.serverGroup;ee.log({category:"Cluster Pod",action:"Load Load Balancer Details (multiple menu)"});const n=t.current.name.endsWith(".clusters")?".loadBalancerDetails":"^.loadBalancerDetails";t.go(n,{region:a.region,accountId:a.account,name:e.name,provider:a.type})},this.showTargetGroupDetails=e=>{const{$state:t}=h;ee.log({category:"Cluster Pod",action:"Load Target Group Details (multiple menu)"});const a=t.current.name.endsWith(".clusters")?".targetGroupDetails":"^.targetGroupDetails";t.go(a,{region:e.region,accountId:e.account,name:e.name,provider:"aws",loadBalancerName:e.loadBalancerNames[0]})},this.handleShowPopover=()=>{ee.log({category:"Cluster Pod",action:"Show Load Balancers Menu"})},this.handleClick=e=>{e.preventDefault(),e.stopPropagation()},this.state={loadBalancers:[],targetGroups:[],isLoading:!0}}componentDidMount(){this.mounted=!0,this.loadBalancersRefreshUnsubscribe=this.props.application.getDataSource("loadBalancers").onRefresh(null,()=>{this.forceUpdate()}),te.populateLoadBalancers(this.props.application,this.props.serverGroup).then(e=>{this.mounted&&this.setState({loadBalancers:e,isLoading:!1})}),Dr.populateTargetGroups(this.props.application,this.props.serverGroup).then(e=>{this.mounted&&this.setState({targetGroups:e})})}componentWillUnmount(){this.mounted=!1,this.loadBalancersRefreshUnsubscribe()}render(){const{loadBalancers:e,targetGroups:t,isLoading:a}=this.state,n=t&&t.length||0,r=e&&e.length||0,i=n+r;if(!i)return a?Vt.createElement(ae,{size:"nano"}):null;const s="load-balancers-tag "+(i>1?"overflowing":""),l=Vt.createElement("div",{className:"menu-load-balancers"},r>0&&Vt.createElement("div",{className:"menu-load-balancers-header"},"Load Balancers"),Qt(e,"name").map(e=>Vt.createElement(Br,{key:e.name,loadBalancer:e,onItemClick:this.showLoadBalancerDetails})),n>0&&Vt.createElement("div",{className:"menu-load-balancers-header"},"Target Groups"),Qt(t,"name").map(e=>Vt.createElement(Br,{key:e.name,loadBalancer:e,onItemClick:this.showTargetGroupDetails})));return Vt.createElement("span",{className:s},i>1&&Vt.createElement(ne,{delayShow:100,delayHide:150,onShow:this.handleShowPopover,placement:"bottom",template:l,hOffsetPercent:"80%",container:this.props.container,className:"no-padding menu-load-balancers"},Vt.createElement("button",{onClick:this.handleClick,className:"btn btn-link btn-multiple-load-balancers clearfix no-padding"},Vt.createElement("span",{className:"badge badge-counter"},Vt.createElement("span",{className:"icon"},Vt.createElement("i",{className:"fa icon-sitemap"}))," ",i))),1===e.length&&0===t.length&&Vt.createElement("span",{className:"btn-load-balancer"},Vt.createElement(zr,{key:e[0].name,label:"Load Balancer",loadBalancer:e[0],onItemClick:this.showLoadBalancerDetails})),1===t.length&&0===e.length&&Vt.createElement("span",{className:"btn-load-balancer"},Vt.createElement(zr,{key:t[0].name,label:"Target Group",loadBalancer:t[0],onItemClick:this.showTargetGroupDetails})))}}class Mr{updateHealthCounts(e){const t=e.instances;if(e.instanceCounts={up:t.filter(e=>"InService"===e.health[0].state).length,down:t.filter(e=>"Down"===e.healthState).length,outOfService:t.filter(e=>"OutOfService"===e.healthState).length,starting:void 0,succeeded:void 0,failed:void 0,unknown:void 0},e.serverGroups){const t=Kt(e.serverGroups.map(e=>e.instances));e.instanceCounts.up=t.filter(e=>"InService"===e.health[0].state).length,e.instanceCounts.down=t.filter(e=>"Down"===e.healthState).length,e.instanceCounts.outOfService=t.filter(e=>"OutOfService"===e.healthState).length}}transformInstance(e,t,a,n){const r=e.health||{};"healthy"===r.state&&(r.state="InService"),e.provider=t,e.account=a,e.region=n,e.healthState=r.state?"InService"===r.state?"Up":"Down":"OutOfService",e.health=[r]}addVpcNameToContainer(e){return t=>{const a=t.find(t=>t.id===e.vpcId);return e.vpcName=a?a.name:"",e}}normalizeServerGroups(e,t,a,n){e.forEach(e=>{e.account=e.account||t.account,e.region=e.region||t.region,e.cloudProvider=e.cloudProvider||t.cloudProvider,e.detachedInstances?(e.detachedInstances=e.detachedInstances.map(e=>({id:e})),e.instances=e.instances.concat(e.detachedInstances)):e.detachedInstances=[],e.instances.forEach(e=>{this.transformInstance(e,t.type,t.account,t.region),e[a]=[t.name],e.health.type=n}),this.updateHealthCounts(e)})}normalizeTargetGroup(e){this.normalizeServerGroups(e.serverGroups,e,"targetGroups","TargetGroup");const t=ea(e.serverGroups,{isDisabled:!1});return e.provider=e.type,e.instances=ta(t).map("instances").flatten().value(),e.detachedInstances=ta(t).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Xa.all([Wn.listVpcs(),o.listAllAccounts()]).then(([t,a])=>{const n=this.addVpcNameToContainer(e)(t);return n.serverGroups=n.serverGroups.map(e=>{const t=a.find(t=>t.name===e.account),n=t&&t.cloudProvider||e.cloudProvider;return e.cloudProvider=n,e.instances.forEach(e=>{e.cloudProvider=n,e.provider=n}),{...e,cloudProvider:n}}),n})}normalizeActions(e){if("application"===e.loadBalancerType){e.listeners.forEach(e=>{e.defaultActions.sort((e,t)=>e.order-t.order),e.rules.forEach(e=>e.actions.sort((e,t)=>e.order-t.order))})}}normalizeLoadBalancer(e){this.normalizeServerGroups(e.serverGroups,e,"loadBalancers","LoadBalancer");let t=e.serverGroups;if(e.targetGroups){const a=e;a.targetGroups.forEach(e=>this.normalizeTargetGroup(e)),t=Kt(aa(a.targetGroups,"serverGroups"))}e.loadBalancerType=e.loadBalancerType||"classic",e.provider=e.type,this.normalizeActions(e);const a=ea(t,{isDisabled:!1});return e.instances=ta(a).map("instances").flatten().value(),e.detachedInstances=ta(a).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Wn.listVpcs().then(t=>this.addVpcNameToContainer(e)(t))}static convertClassicLoadBalancerForEditing(e){const t={availabilityZones:void 0,isInternal:e.isInternal,region:e.region,cloudProvider:e.cloudProvider,credentials:e.credentials||e.account,listeners:e.listeners,loadBalancerType:"classic",name:e.name,regionZones:e.availabilityZones,securityGroups:e.securityGroups,vpcId:e.vpcId,healthCheck:void 0,healthTimeout:e.healthTimeout,healthInterval:e.healthInterval,healthyThreshold:e.healthyThreshold,unhealthyThreshold:e.unhealthyThreshold,healthCheckProtocol:e.healthCheckProtocol,healthCheckPort:e.healthCheckPort,healthCheckPath:e.healthCheckPath,idleTimeout:e.idleTimeout||60,subnetType:e.subnetType};if(e.elb){const a=e.elb;if(t.securityGroups=a.securityGroups,t.vpcId=a.vpcid||a.vpcId,a.listenerDescriptions&&(t.listeners=a.listenerDescriptions.map(e=>{const t=e.listener;if(t.sslcertificateId){const e=t.sslcertificateId.split("/");t.sslcertificateId=e[1],t.sslCertificateType=e[0].split(":")[2]}return{internalProtocol:t.instanceProtocol,internalPort:t.instancePort,externalProtocol:t.protocol,externalPort:t.loadBalancerPort,sslCertificateId:t.sslcertificateId,sslCertificateName:t.sslcertificateId,sslCertificateType:t.sslCertificateType,policyNames:e.policyNames}})),a.healthCheck&&a.healthCheck.target){t.healthTimeout=a.healthCheck.timeout,t.healthInterval=a.healthCheck.interval,t.healthyThreshold=a.healthCheck.healthyThreshold,t.unhealthyThreshold=a.healthCheck.unhealthyThreshold;const e=a.healthCheck.target,n=e.indexOf(":");let r=e.indexOf("/");if(-1===r&&(r=e.length),-1!==n){t.healthCheckProtocol=e.substring(0,n);const a=Number(e.substring(n+1,r));t.healthCheckPath=e.substring(r),isNaN(a)||(t.healthCheckPort=a)}}}return t}static convertApplicationLoadBalancerForEditing(e){const t=re.parseLoadBalancerName(e.name).application,a={availabilityZones:void 0,isInternal:e.isInternal,region:e.region,loadBalancerType:"application",cloudProvider:e.cloudProvider,credentials:e.account||e.credentials,listeners:[],targetGroups:[],name:e.name,regionZones:e.availabilityZones,securityGroups:[],subnetType:e.subnetType,vpcId:void 0,idleTimeout:e.idleTimeout||60,deletionProtection:e.deletionProtection||!1,ipAddressType:e.ipAddressType||"ipv4",dualstack:"dualstack"===e.ipAddressType};if(e.elb){const n=e.elb;a.securityGroups=n.securityGroups,a.vpcId=n.vpcid||n.vpcId,n.listeners&&(a.listeners=n.listeners.map(e=>{const a=[];return e.certificates&&e.certificates.forEach(e=>{const t=e.certificateArn.split(":"),n=t[5].split("/");a.push({certificateArn:e.certificateArn,type:t[2],name:n[1]})}),(e.defaultActions||[]).forEach(e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,"")),e.redirectActionConfig=e.redirectConfig}),e.rules=(e.rules||[]).filter(e=>!e.default),e.rules.forEach(e=>{(e.actions||[]).forEach(e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,"")),e.redirectActionConfig=e.redirectConfig}),(e.conditions||[]).forEach(e=>{"http-request-method"===e.field&&(e.values=e.httpRequestMethodConfig.values)}),e.conditions=e.conditions||[]}),e.rules.sort((e,t)=>e.priority-t.priority),{protocol:e.protocol,port:e.port,defaultActions:e.defaultActions,certificates:a,rules:e.rules||[],sslPolicy:e.sslPolicy}})),n.targetGroups&&(a.targetGroups=n.targetGroups.map(e=>({name:e.targetGroupName.replace(`${t}-`,""),protocol:e.protocol,port:e.port,targetType:e.targetType,healthCheckProtocol:e.healthCheckProtocol,healthCheckPort:e.healthCheckPort,healthCheckPath:e.healthCheckPath,healthCheckTimeout:e.healthCheckTimeoutSeconds,healthCheckInterval:e.healthCheckIntervalSeconds,healthyThreshold:e.healthyThresholdCount,unhealthyThreshold:e.unhealthyThresholdCount,attributes:{deregistrationDelay:Number(e.attributes["deregistration_delay.timeout_seconds"]),stickinessEnabled:"true"===e.attributes["stickiness.enabled"],stickinessType:e.attributes["stickiness.type"],stickinessDuration:Number(e.attributes["stickiness.lb_cookie.duration_seconds"]),multiValueHeadersEnabled:"true"===e.attributes["lambda.multi_value_headers.enabled"]}})))}return a}static convertNetworkLoadBalancerForEditing(e){const t=re.parseLoadBalancerName(e.name).application,a={availabilityZones:void 0,isInternal:e.isInternal,region:e.region,loadBalancerType:"network",cloudProvider:e.cloudProvider,credentials:e.account||e.credentials,listeners:[],targetGroups:[],name:e.name,regionZones:e.availabilityZones,securityGroups:[],subnetType:e.subnetType,vpcId:void 0,deletionProtection:e.deletionProtection,loadBalancingCrossZone:e.loadBalancingCrossZone,ipAddressType:e.ipAddressType||"ipv4",dualstack:"dualstack"===e.ipAddressType};if(e.elb){const n=e.elb;a.securityGroups=n.securityGroups,a.vpcId=n.vpcid||n.vpcId,n.listeners&&(a.listeners=n.listeners.map(e=>{const a=[];return e.certificates&&e.certificates.forEach(e=>{const t=e.certificateArn.split(":"),n=t[5].split("/");a.push({certificateArn:e.certificateArn,type:t[2],name:n[1]})}),(e.defaultActions||[]).forEach(e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,""))}),e.rules=(e.rules||[]).filter(e=>!e.default),e.rules.forEach(e=>{(e.actions||[]).forEach(e=>{e.targetGroupName&&(e.targetGroupName=e.targetGroupName.replace(`${t}-`,""))}),e.conditions=e.conditions||[]}),e.rules.sort((e,t)=>e.priority-t.priority),{protocol:e.protocol,port:e.port,defaultActions:e.defaultActions,certificates:a,rules:e.rules||[],sslPolicy:e.sslPolicy}})),n.targetGroups&&(a.targetGroups=n.targetGroups.map(e=>({name:e.targetGroupName.replace(`${t}-`,""),protocol:e.protocol,port:e.port,targetType:e.targetType,healthCheckProtocol:e.healthCheckProtocol,healthCheckPort:e.healthCheckPort,healthCheckTimeout:e.healthCheckTimeoutSeconds,healthCheckInterval:e.healthCheckIntervalSeconds,healthyThreshold:e.healthyThresholdCount,unhealthyThreshold:e.unhealthyThresholdCount,healthCheckPath:e.healthCheckPath,attributes:{deregistrationDelay:Number(e.attributes["deregistration_delay.timeout_seconds"]),deregistrationDelayConnectionTermination:Boolean("true"===e.attributes["deregistration_delay.connection_termination.enabled"]),preserveClientIp:Boolean("true"===e.attributes["preserve_client_ip.enabled"])}})))}return a}static constructNewClassicLoadBalancerTemplate(e){return{availabilityZones:void 0,name:"",stack:"",detail:"",loadBalancerType:"classic",isInternal:!1,cloudProvider:"aws",credentials:e.defaultCredentials.aws||kn.defaults.account,region:e.defaultRegions.aws||kn.defaults.region,vpcId:null,subnetType:kn.defaults.subnetType,healthCheck:void 0,healthCheckProtocol:"HTTP",healthCheckPort:7001,healthCheckPath:"/healthcheck",healthTimeout:5,healthInterval:10,healthyThreshold:10,unhealthyThreshold:2,idleTimeout:60,regionZones:[],securityGroups:[],listeners:[{externalPort:80,externalProtocol:"HTTP",internalPort:7001,internalProtocol:"HTTP"}]}}static constructNewApplicationLoadBalancerTemplate(e){const t="targetgroup";return{name:"",availabilityZones:void 0,stack:"",detail:"",loadBalancerType:"application",ipAddressType:"ipv4",dualstack:!1,isInternal:!1,cloudProvider:"aws",credentials:e.defaultCredentials.aws||kn.defaults.account,region:e.defaultRegions.aws||kn.defaults.region,vpcId:null,subnetType:kn.defaults.subnetType,idleTimeout:60,deletionProtection:!1,targetGroups:[{name:t,protocol:"HTTP",port:e.attributes.instancePort||a.defaultInstancePort,targetType:"instance",healthCheckProtocol:"HTTP",healthCheckPort:"traffic-port",healthCheckPath:"/healthcheck",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:2,attributes:{deregistrationDelay:300,stickinessEnabled:!1,stickinessType:"lb_cookie",stickinessDuration:8400,multiValueHeadersEnabled:!1}}],regionZones:[],securityGroups:[],listeners:[{certificates:[],protocol:"HTTP",port:80,defaultActions:[{type:"forward",targetGroupName:t}],rules:[]}]}}static constructNewNetworkLoadBalancerTemplate(e){const t="targetgroup";return{name:"",availabilityZones:void 0,stack:"",detail:"",loadBalancerType:"network",isInternal:!1,ipAddressType:"ipv4",dualstack:!1,cloudProvider:"aws",credentials:e.defaultCredentials.aws||kn.defaults.account,region:e.defaultRegions.aws||kn.defaults.region,vpcId:null,subnetType:kn.defaults.subnetType,deletionProtection:!1,loadBalancingCrossZone:!0,securityGroups:[],targetGroups:[{name:t,protocol:"TCP",port:7001,targetType:"instance",healthCheckProtocol:"TCP",healthCheckPath:"/healthcheck",healthCheckPort:"traffic-port",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:10,attributes:{deregistrationDelay:300}}],regionZones:[],listeners:[{certificates:[],protocol:"TCP",port:80,defaultActions:[{type:"forward",targetGroupName:t}],rules:[]}]}}}var $r=Object.getOwnPropertyDescriptor;let Lr=class extends Vt.Component{render(){return Vt.createElement("h3",null,"Target Group Details")}};Lr=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?$r(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("loadBalancer.targetGroupDetails")],Lr);var Rr=Object.getOwnPropertyDescriptor;let Or=class extends Vt.Component{render(){const{certificates:e,accountName:t,onCertificateSelect:a,currentValue:n}=this.props,r=e[t]||[],i=r.map(e=>({label:e.serverCertificateName,value:e.serverCertificateName})),s=r.find(e=>e.serverCertificateName===n);return Vt.createElement("div",{style:{width:"100%"}},Vt.createElement(rn,{className:"input-sm",wrapperStyle:{width:"100%"},clearable:!0,required:!0,options:i,onChange:e=>a(e.value),value:n}),s&&Vt.createElement("div",{className:"small sp-margin-xs-top sp-margin-m-bottom sp-margin-m-left"},Vt.createElement("div",null,"Uploaded ",se(s.uploadDate)," (",z(s.uploadDate),")"),Vt.createElement("b",null,"Expires ",se(s.expiration))," (",z(s.expiration),")"))}};Or=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Rr(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("amazon.certificateSelectField")],Or);const Vr=Vt.forwardRef((e,t)=>Vt.createElement("div",{ref:t},Vt.createElement(s,{name:"idleTimeout",label:"Idle Timeout",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"deletionProtection",label:"Protection",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Vt.createElement(d,{...e,text:"Enable delete protection"})}),Vt.createElement(s,{name:"dualstack",label:"Dualstack",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.albIpAddressType"}),input:e=>Vt.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})})));Ar(".configure-config-modal .StandardFieldLayout .sm-label-right {\n min-width: 160px;\n}\n");const Ur=class e extends Vt.Component{constructor(e){super(e),this.close=e=>{this.props.dismissModal(e)},this.submit=e=>{this.props.closeModal(e)},this.validate=()=>({});const t=e.config||{};this.state={initialValues:{authorizationEndpoint:t.authorizationEndpoint||"",clientId:t.clientId||"",clientSecret:t.clientSecret||"",issuer:t.issuer||"",scope:t.scope||"openid",sessionCookieName:t.sessionCookieName||"AWSELBAuthSessionCookie",tokenEndpoint:t.tokenEndpoint||"",userInfoEndpoint:t.userInfoEndpoint||""}}}static show(t){return b.show(e,t)}render(){const{initialValues:e}=this.state;return Vt.createElement("div",{className:"configure-config-modal"},Vt.createElement(le,{initialValues:e,onSubmit:this.submit,validate:this.validate,render:({isValid:e})=>Vt.createElement(dn,{className:"form-horizontal"},Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Configure OIDC Client")),Vt.createElement(Ha.Body,null,Vt.createElement(s,{name:"issuer",label:"Issuer",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter the OpenId Provider"})}),Vt.createElement(s,{name:"authorizationEndpoint",label:"Authorization Endpoint",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter OpenID provider server endpoint"})}),Vt.createElement(s,{name:"tokenEndpoint",label:"Token Endpoint",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter a URI for your token endpoint"})}),Vt.createElement(s,{name:"userInfoEndpoint",label:"User info Endpoint",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter a URI for your user info endpoint"})}),Vt.createElement(s,{name:"clientId",label:"Client ID",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter the client ID"})}),Vt.createElement(s,{name:"clientSecret",label:"Client secret",required:!0,input:e=>Vt.createElement(l,{...e,placeholder:"Enter the client secret"})})),Vt.createElement(Ha.Footer,null,Vt.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Vt.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Client"})))}))}};Ur.defaultProps={closeModal:C,dismissModal:C};let qr=Ur;const Hr=class e extends Vt.Component{constructor(e){super(e),this.close=e=>{this.props.dismissModal(e)},this.submit=e=>{const t=na(e,e=>e&&""!==e);this.props.closeModal(t)};const t=e.config||{};this.initialValues={host:t.host||"",path:t.path||"",port:t.port||"",protocol:t.protocol||void 0,query:t.query||"",statusCode:t.statusCode||"HTTP_301"}}static show(t){return b.show(e,t)}render(){return Vt.createElement("div",{className:"configure-config-modal"},Vt.createElement(le,{initialValues:this.initialValues,onSubmit:this.submit,render:({isValid:e})=>Vt.createElement(dn,{className:"form-horizontal"},Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Configure Redirect ",Vt.createElement(n,{id:"aws.loadBalancer.redirect"}))),Vt.createElement(Ha.Body,null,Vt.createElement(s,{name:"host",label:"Host",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.host"})}),Vt.createElement(s,{name:"path",label:"Path",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.path"})}),Vt.createElement(s,{name:"port",label:"Port",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.port"})}),Vt.createElement(s,{name:"protocol",label:"Protocol",required:!1,input:e=>Vt.createElement(c,{...e,stringOptions:["HTTP","HTTPS","#{protocol}"],placeholder:"Select Protocol",clearable:!1,style:{width:"130px"}}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.protocol"})}),Vt.createElement(s,{name:"query",label:"Query",required:!1,input:e=>Vt.createElement(l,{...e}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.query"})}),Vt.createElement(s,{name:"statusCode",label:"Status Code",required:!0,input:e=>Vt.createElement(de,{...e,options:["HTTP_301","HTTP_302"]}),help:Vt.createElement(n,{id:"aws.loadBalancer.redirect.statusCode"})})),Vt.createElement(Ha.Footer,null,Vt.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Vt.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Config"})))}))}};Hr.defaultProps={closeModal:C,dismissModal:C};let Wr=Hr;class jr{static getOidcConfigsByApp(e){return D("/oidcConfigs").query({app:e}).get()}}class Zr{static listCertificates(){return ue.listCertificatesByProvider("aws").then(e=>o.listAllAccounts("aws").then(t=>{const a=t.reduce((e,t)=>(e[t.accountId]=t.name,e),{}),n=Qt(e,"serverCertificateName");return ra(n,e=>{const[,,,,t]=e.arn.split(":");return a[t]||"unknown"})}))}}const _r=sn(()=>Vt.createElement("span",{className:"pipeline-drag-handle clickable glyphicon glyphicon-resize-vertical"})),Kr={authenticateOidcConfig:{authorizationEndpoint:"",clientId:"",issuer:"",scope:"openid",sessionCookieName:"AWSELBAuthSessionCookie",tokenEndpoint:"",userInfoEndpoint:""},type:"authenticate-oidc"};class Yr extends Vt.Component{constructor(e){super(e),this.protocols=["HTTP","HTTPS"],this.initialActionsWithAuth=new Set,this.initialListenersWithDefaultAuth=new Set,this.removedAuthActions=new Map,this.attachClientSecret=(e,t)=>{if("authenticate-oidc"===e.type){const a=t.find(t=>t.clientId===e.authenticateOidcConfig.clientId);a&&(e.authenticateOidcConfig.clientSecret=a.clientSecret)}},this.addListener=()=>{this.props.formik.values.listeners.push({certificates:[],protocol:"HTTP",port:80,defaultActions:[{type:"forward",targetGroupName:""}],rules:[]}),this.updateListeners()},this.addRule=e=>{e.rules.push({priority:null,actions:[{type:"forward",targetGroupName:""}],conditions:[{field:"path-pattern",values:[""]}]}),this.updateListeners()},this.removeRule=(e,t)=>{e.rules.splice(t,1),this.updateListeners()},this.handleConditionFieldChanged=(e,t)=>{e.field=t,"http-request-method"===t&&(e.values=[]),this.updateListeners()},this.handleConditionValueChanged=(e,t)=>{e.values[0]=t,this.updateListeners()},this.handleHttpRequestMethodChanged=(e,t,a)=>{let n=e.values||[];a?n.push(t):n=n.filter(e=>e!==t),e.values=n,e.httpRequestMethodConfig={values:n},this.updateListeners()},this.addCondition=e=>{if(1===e.conditions.length){const t="path-pattern"===e.conditions[0].field?"host-header":"path-pattern";e.conditions.push({field:t,values:[""]})}this.updateListeners()},this.removeCondition=(e,t)=>{e.conditions.splice(t,1),this.updateListeners()},this.handleRuleActionTargetChanged=(e,t)=>{e.targetGroupName=t,this.updateListeners()},this.handleRuleActionTypeChanged=(e,t)=>{e.type=t,"forward"===e.type?delete e.redirectActionConfig:"redirect"===e.type&&(e.redirectActionConfig={statusCode:"HTTP_301"},delete e.targetGroupName),this.updateListeners()},this.handleSortEnd=(e,t)=>{t.rules=ln(t.rules,e.oldIndex,e.newIndex),this.updateListeners()},this.configureOidcClient=e=>{qr.show({config:e.authenticateOidcConfig}).then(t=>{e.authenticateOidcConfig=t,this.updateListeners()}).catch(()=>{})},this.configureRedirect=e=>{Wr.show({config:e.redirectActionConfig}).then(t=>{e.redirectActionConfig=t,this.updateListeners()}).catch(()=>{})},this.authenticateRuleToggle=(e,t)=>{const a=e.rules[t],n=a&&a.actions||e.defaultActions;if(n){const a=n.findIndex(e=>"authenticate-oidc"===e.type);if(-1!==a)this.removeAuthAction(e,n,a,t);else{const a=(this.removedAuthActions.has(e)?this.removedAuthActions.get(e)[t||-1]:void 0)||{...Kr};n.unshift({...a})}this.updateListeners()}},this.oidcConfigChanged=(e,t)=>{e.authenticateOidcConfig={...t},this.updateListeners()},this.redirectConfigChanged=(e,t)=>{e.redirectActionConfig={...t},this.updateListeners()},this.state={certificates:[],certificateTypes:ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),oidcConfigs:void 0},this.props.formik.initialValues.listeners.forEach(e=>{"authenticate-oidc"===e.defaultActions[0].type&&this.initialListenersWithDefaultAuth.add(e),e.rules.forEach(e=>{"authenticate-oidc"===e.actions[0].type&&this.initialActionsWithAuth.add(e.actions)})})}getAllTargetGroupsFromListeners(e){const t=Kt(e.map(e=>e.defaultActions)),a=Kt(e.map(e=>e.rules));return t.push(...Kt(a.map(e=>e.actions))),sa(t.map(e=>e.targetGroupName))}validate(e){const t={},a=e.targetGroups.map(e=>e.name),n=this.getAllTargetGroupsFromListeners(e.listeners),r=la(a,n);1===r.length?t.listeners=`Target group ${r[0]} is unused.`:r.length>1&&(t.listeners=`Target groups ${r.join(", ")} are unused.`);const{listeners:i}=e;Zt(i,"port").length<i.length&&(t.listenerPorts="Multiple listeners cannot use the same port.");return e.listeners.find(e=>{const t=!!e.defaultActions.find(e=>"forward"===e.type&&!e.targetGroupName||"authenticate-oidc"===e.type&&!e.authenticateOidcConfig.clientId||"redirect"===e.type&&(!e.redirectActionConfig||!oa(e.redirectActionConfig,e=>e&&""!==e))),a=!!e.rules.find(e=>{const t=!!e.actions.find(e=>"forward"===e.type&&!e.targetGroupName),a=!!e.actions.find(e=>"authenticate-oidc"===e.type&&!e.authenticateOidcConfig.clientId),n=!!e.conditions.find(e=>"http-request-method"===e.field?!e.values.length:e.values.includes(""));return t||a||n});return t||a})&&(t.listeners="Missing fields in rule configuration."),t}componentDidMount(){this.loadCertificates(),this.loadOidcClients()}loadCertificates(){Zr.listCertificates().then(e=>{this.setState({certificates:e})})}loadOidcClients(){jr.getOidcConfigsByApp(this.props.app.name).then(e=>{e&&e.length&&this.props.formik.values.listeners.forEach(t=>{t.defaultActions.forEach(t=>this.attachClientSecret(t,e)),t.rules.forEach(t=>t.actions.forEach(t=>this.attachClientSecret(t,e)))}),this.setState({oidcConfigs:e}),this.updateListeners()}).catch(()=>{})}updateListeners(){this.props.formik.setFieldValue("listeners",this.props.formik.values.listeners)}needsCert(e){return"HTTPS"===e.protocol}showCertificateSelect(e){return"iam"===e.type&&this.state.certificates&&Object.keys(this.state.certificates).length>0}addListenerCertificate(e){e.certificates=e.certificates||[],e.certificates.push({certificateArn:void 0,type:"iam",name:void 0})}removeAuthActions(e){const t=e.defaultActions.findIndex(e=>"authenticate-oidc"===e.type);-1!==t&&this.removeAuthAction(e,e.defaultActions,t,-1),e.rules.forEach((t,a)=>{const n=t.actions.findIndex(e=>"authenticate-oidc"===e.type);-1!==n&&this.removeAuthAction(e,t.actions,n,a)}),this.updateListeners()}reenableAuthActions(e){const t=this.removedAuthActions.has(e)?this.removedAuthActions.get(e):[],a=t[-1];a&&(t[-1]=void 0,e.defaultActions.unshift({...a})),e.rules.forEach((e,a)=>{const n=t[a];t[a]=void 0,n&&e.actions.unshift({...n})})}listenerProtocolChanged(e,t){e.protocol=t,"HTTPS"===e.protocol&&(e.port=443,e.certificates&&0!==e.certificates.length||this.addListenerCertificate(e),this.reenableAuthActions(e)),"HTTP"===e.protocol&&(e.port=80,e.certificates.length=0,this.removeAuthActions(e)),this.updateListeners()}listenerPortChanged(e,t){e.port=Number.parseInt(t,10),this.updateListeners()}certificateTypeChanged(e,t){e.type=t,this.updateListeners()}handleCertificateChanged(e,t){e.name=t,this.updateListeners()}removeListener(e){this.props.formik.values.listeners.splice(e,1),this.updateListeners()}removeAuthActionInternal(e,t,a,n=-1){const r=t.splice(a,1)[0];this.removedAuthActions.has(e)||this.removedAuthActions.set(e,[]),this.removedAuthActions.get(e)[n||-1]=r,this.updateListeners()}removeAuthAction(e,t,a,n=-1){const r=-1===n&&this.initialListenersWithDefaultAuth.has(e),i=n>-1&&this.initialActionsWithAuth.has(t);r||i?S.confirm({header:"Really remove authentication?",buttonText:"Remove Auth",submitMethod:()=>(this.removeAuthActionInternal(e,t,a,n),r&&this.initialListenersWithDefaultAuth.delete(e),i&&this.initialActionsWithAuth.delete(t),Xa.resolve())}):this.removeAuthActionInternal(e,t,a,n)}render(){const{errors:e,values:t}=this.props.formik,{certificates:a,certificateTypes:n,oidcConfigs:r}=this.state;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},t.listeners.map((e,i)=>Vt.createElement("div",{key:i,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Vt.createElement("div",{className:"wizard-pod-row-contents spread"},Vt.createElement("div",null,Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol"),Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"80px"},value:e.protocol,onChange:t=>this.listenerProtocolChanged(e,t.target.value)},this.protocols.map(e=>Vt.createElement("option",{key:e},e)))),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port"),Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",min:0,value:e.port||"",onChange:t=>this.listenerPortChanged(e,t.target.value),style:{width:"80px"},required:!0}))),Vt.createElement("div",null,Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(i)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))))),this.needsCert(e)&&Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Vt.createElement("div",{className:"wizard-pod-row-contents"},e.certificates.map((e,r)=>Vt.createElement("div",{key:r,style:{width:"100%",display:"flex",flexDirection:"row"}},Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"45px"},value:e.type,onChange:t=>this.certificateTypeChanged(e,t.target.value)},n.map(e=>Vt.createElement("option",{key:e},e))),this.showCertificateSelect(e)&&Vt.createElement(Or,{certificates:a,accountName:t.credentials,currentValue:e.name,app:this.props.app,onCertificateSelect:t=>this.handleCertificateChanged(e,t)}),!this.showCertificateSelect(e)&&Vt.createElement("input",{className:"form-control input-sm no-spel",style:{display:"inline-block"},type:"text",value:e.name,onChange:t=>this.handleCertificateChanged(e,t.target.value),required:!0}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Vt.createElement("table",{className:"table table-condensed packed rules-table"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{style:{width:"15px",padding:"0"}}),Vt.createElement("th",null,"If"),Vt.createElement("th",{style:{width:"315px"}},"Then"),Vt.createElement("th",{style:{width:"45px"}}))),Vt.createElement(ei,{addCondition:this.addCondition,addRule:this.addRule,authenticateRuleToggle:this.authenticateRuleToggle,distance:10,handleConditionFieldChanged:this.handleConditionFieldChanged,handleConditionValueChanged:this.handleConditionValueChanged,handleHttpRequestMethodChanged:this.handleHttpRequestMethodChanged,handleRuleActionTargetChanged:this.handleRuleActionTargetChanged,handleRuleActionTypeChanged:this.handleRuleActionTypeChanged,listener:e,helperClass:"rule-sortable-helper",removeRule:this.removeRule,removeCondition:this.removeCondition,targetGroups:t.targetGroups,oidcConfigs:r,oidcConfigChanged:this.oidcConfigChanged,redirectConfigChanged:this.redirectConfigChanged,onSortEnd:t=>this.handleSortEnd(t,e),configureOidcClient:this.configureOidcClient,configureRedirect:this.configureRedirect}))))))),e.listenerPorts&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listenerPorts})),e.listeners&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listeners})),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}const Xr=on(e=>Vt.createElement("tr",{className:"listener-rule"},Vt.createElement("td",{className:"handle"},Vt.createElement(_r,null)),Vt.createElement("td",null,e.rule.conditions.map((t,a)=>Vt.createElement("div",{key:a,className:"listener-rule-condition"},Vt.createElement("select",{className:"form-control input-sm inline-number",value:t.field,onChange:a=>e.handleConditionFieldChanged(t,a.target.value),style:{width:"40%"},required:!0},(1===e.rule.conditions.length||"host-header"===t.field)&&Vt.createElement("option",{value:"host-header"},"Host"),(1===e.rule.conditions.length||"path-pattern"===t.field)&&Vt.createElement("option",{value:"path-pattern"},"Path"),(1===e.rule.conditions.length||"http-request-method"===t.field)&&Vt.createElement("option",{value:"http-request-method"},"Method(s)")),"path-pattern"===t.field&&Vt.createElement(n,{id:"aws.loadBalancer.ruleCondition.path"}),"host-header"===t.field&&Vt.createElement(n,{id:"aws.loadBalancer.ruleCondition.host"}),"http-request-method"!==t.field&&Vt.createElement("input",{className:"form-control input-sm",type:"text",value:t.values[0],onChange:a=>e.handleConditionValueChanged(t,a.target.value),maxLength:128,required:!0,style:{width:"63%"}}),"http-request-method"===t.field&&Vt.createElement("div",{className:"col-md-6 checkbox"},["DELETE","GET","PATCH","POST","PUT"].map(a=>Vt.createElement("label",{key:`${a}-checkbox`},Vt.createElement("input",{type:"checkbox",checked:t.values.includes(a),onChange:n=>e.handleHttpRequestMethodChanged(t,a,n.target.checked)}),a))),Vt.createElement("span",{className:"remove-condition"},1===a&&Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeCondition(e.rule,a),style:{padding:"0"}},Vt.createElement(_,{value:"Remove Condition"},Vt.createElement("span",{className:"glyphicon glyphicon-trash"})))))),1===e.rule.conditions.length&&Vt.createElement("div",{className:"add-new-container"},Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addCondition(e.rule)},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new condition")),Vt.createElement("span",{style:{minWidth:"15px"}}))),Vt.createElement("td",null,e.rule.actions.map((t,a)=>Vt.createElement(Jr,{key:a,action:t,actionTypeChanged:a=>e.handleRuleActionTypeChanged(t,a),oidcConfigChanged:a=>e.oidcConfigChanged(t,a),redirectConfigChanged:a=>e.redirectConfigChanged(t,a),targetChanged:a=>e.handleRuleActionTargetChanged(t,a),targetGroups:e.targetGroups,oidcConfigs:e.oidcConfigs,configureOidcClient:e.configureOidcClient,configureRedirect:e.configureRedirect}))),Vt.createElement("td",null,Vt.createElement(Qr,{ruleIndex:e.ruleIndex,listener:e.listener,authenticateRuleToggle:e.authenticateRuleToggle,removeRule:e.removeRule,actions:e.rule.actions})))),Jr=e=>{var t;if("authenticate-oidc"!==e.action.type){const t=e.action.redirectActionConfig||e.action.redirectConfig;return Vt.createElement("div",{className:"horizontal top"},Vt.createElement("select",{className:"form-control input-sm",style:{width:"80px"},value:e.action.type,onChange:t=>e.actionTypeChanged(t.target.value)},Vt.createElement("option",{value:"forward"},"forward to"),Vt.createElement("option",{value:"redirect"},"redirect to")),"forward"===e.action.type&&Vt.createElement("select",{className:"form-control input-sm",value:e.action.targetGroupName,onChange:t=>e.targetChanged(t.target.value),required:!0},Vt.createElement("option",{value:""}),sa(e.targetGroups.map(e=>e.name)).map(e=>Vt.createElement("option",{key:e},e))),"redirect"===e.action.type&&Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Host"),Vt.createElement("dd",null,t.host),Vt.createElement("dt",null,"Path"),Vt.createElement("dd",null,t.path),Vt.createElement("dt",null,"Port"),Vt.createElement("dd",null,t.port),Vt.createElement("dt",null,"Protocol"),Vt.createElement("dd",null,t.protocol),Vt.createElement("dt",null,"Query"),Vt.createElement("dd",null,t.query),Vt.createElement("dt",null,"Status Code"),Vt.createElement("dd",null,t.statusCode),Vt.createElement("dt",null,Vt.createElement("button",{className:"btn btn-link no-padding",type:"button",onClick:()=>e.configureRedirect(e.action)},"Configure..."))))}if("authenticate-oidc"===e.action.type){const a=e.action.authenticateOidcConfig.clientId,n=ia(kn,"loadBalancers.disableManualOidcDialog",!1)||e.oidcConfigs&&e.oidcConfigs.length>0&&(!a||e.oidcConfigs.find(e=>e.clientId===a)),r=(null==(t=e.oidcConfigs)?void 0:t.length)?e.oidcConfigs.map(e=>Vt.createElement("option",{key:e.clientId},e.clientId)):Vt.createElement("option",{disabled:!0},"No ",me.get("OIDC client")," config found");return Vt.createElement("div",{className:"horizontal middle",style:{height:"30px"}},Vt.createElement("span",{style:{whiteSpace:"pre"}},"auth with ",me.get("OIDC client")," "),n&&Vt.createElement("select",{className:"form-control input-sm",value:a,onChange:t=>e.oidcConfigChanged(e.oidcConfigs.find(e=>e.clientId===t.target.value)),required:!0},Vt.createElement("option",{value:""}),r),!n&&Vt.createElement("a",{onClick:()=>e.configureOidcClient(e.action),className:"clickable"},a||"Configure..."),Vt.createElement("span",{style:{whiteSpace:"pre"}},Vt.createElement("em",null," and then")))}return null},Qr=e=>{const t=Boolean(e.actions.find(e=>"authenticate-oidc"===e.type)),a="HTTPS"===e.listener.protocol,r=t?"Remove authentication from rule":"Authenticate rule",i=t?"fas fa-fw fa-lock-open":"fas fa-fw fa-user-lock";return Vt.createElement("span",null,a&&Vt.createElement(Vt.Fragment,null,Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.authenticateRuleToggle(e.listener,e.ruleIndex),style:{padding:"0"}},Vt.createElement(_,{value:r},Vt.createElement("i",{className:i}))),Vt.createElement(n,{id:"aws.loadBalancer.oidcAuthentication"})),void 0!==e.ruleIndex&&e.ruleIndex>=0&&e.removeRule&&Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeRule(e.listener,e.ruleIndex),style:{padding:"0"}},Vt.createElement(_,{value:"Remove Rule"},Vt.createElement("i",{className:"far fa-fw fa-trash-alt"}))))},ei=cn(e=>Vt.createElement("tbody",null,Vt.createElement("tr",{className:"not-sortable"},Vt.createElement("td",null),Vt.createElement("td",null,"Default"),Vt.createElement("td",null,e.listener.defaultActions.map((t,a)=>Vt.createElement(Jr,{key:a,action:t,actionTypeChanged:a=>e.handleRuleActionTypeChanged(t,a),targetChanged:a=>e.handleRuleActionTargetChanged(t,a),targetGroups:e.targetGroups,oidcConfigs:e.oidcConfigs,oidcConfigChanged:a=>e.oidcConfigChanged(t,a),redirectConfigChanged:a=>e.redirectConfigChanged(t,a),configureOidcClient:e.configureOidcClient,configureRedirect:e.configureRedirect}))),Vt.createElement("td",null,Vt.createElement(Qr,{listener:e.listener,actions:e.listener.defaultActions,authenticateRuleToggle:e.authenticateRuleToggle}))),e.listener.rules.sort((e,t)=>e.priority-t.priority).map((t,a)=>Vt.createElement(Xr,{key:a,rule:t,addCondition:e.addCondition,handleConditionFieldChanged:e.handleConditionFieldChanged,handleConditionValueChanged:e.handleConditionValueChanged,handleHttpRequestMethodChanged:e.handleHttpRequestMethodChanged,handleRuleActionTargetChanged:e.handleRuleActionTargetChanged,handleRuleActionTypeChanged:e.handleRuleActionTypeChanged,oidcConfigChanged:e.oidcConfigChanged,redirectConfigChanged:e.redirectConfigChanged,removeCondition:e.removeCondition,authenticateRuleToggle:e.authenticateRuleToggle,removeRule:e.removeRule,targetGroups:e.targetGroups,oidcConfigs:e.oidcConfigs,listener:e.listener,index:a,ruleIndex:a,configureOidcClient:e.configureOidcClient,configureRedirect:e.configureRedirect})),Vt.createElement("tr",{className:"not-sortable"},Vt.createElement("td",{colSpan:5},Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addRule(e.listener)},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new rule")))))),ti=(e,t,a)=>n=>ia(e,[t,a],[]).includes(n.toLowerCase())?`There is already a target group in ${t}:${a} with that name.`:null,ai=e=>t=>t.length<32-e?null:"Target group names are automatically prefixed with their application name and cannot exceed 32 characters in length.";let ni=class extends Vt.Component{constructor(e){super(e),this.protocols=["HTTP","HTTPS"],this.targetTypes=["instance","ip","lambda"],this.destroy$=new Ta,this.addTargetGroup=()=>{const{setFieldValue:e,values:t}=this.props.formik,a=t.targetGroups.length;t.targetGroups.push({name:"targetgroup"+(a?`${a}`:""),protocol:"HTTP",port:7001,targetType:"instance",healthCheckProtocol:"HTTP",healthCheckPort:"7001",healthCheckPath:"/healthcheck",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:2,attributes:{deregistrationDelay:300,stickinessEnabled:!1,stickinessType:"lb_cookie",stickinessDuration:8400}}),e("targetGroups",t.targetGroups)};const t=e.isNew?0:e.formik.initialValues.targetGroups.length;this.state={existingTargetGroupNames:{},oldTargetGroupCount:t}}validate(e){const t=sa(Kt(ea(ra(e.targetGroups,"name"),e=>e.length>1)).map(e=>e.name)),a=new i(e),{arrayForEach:n}=a;return a.field("targetGroups").withValidators(n((a,n)=>{var r;a.field("name","Name").withValidators(ti(this.state.existingTargetGroupNames,e.credentials,e.region),ai(this.props.app.name.length),ge.valueUnique(t,"There is already a target group in this load balancer with the same name.")),a.field("healthCheckInterval","Health Check Interval").withValidators((r=n,e=>"TCP"!==r.healthCheckProtocol||"TCP"===r.healthCheckProtocol&&(10===Number.parseInt(e,10)||30===Number.parseInt(e,10))?null:"TCP health checks only support 10s and 30s intervals"),ge.checkBetween("healthCheckInterval",5,300)),a.field("healthyThreshold","Healthy Threshold").withValidators(ge.checkBetween("healthyThreshold",2,10)),a.field("unhealthyThreshold","Unhealthy Threshold").spelAware().withValidators(ge.checkBetween("unhealthyThreshold",2,10)),a.field("healthCheckTimeout","Timeout").withValidators((e=>t=>{const a=ca(t)?t:Number.parseInt(t,10),{protocol:n,healthCheckProtocol:r}=e;if("TCP"===n||"TLS"===n){if("HTTP"===r&&6!==a)return"HTTP health check timeouts for TCP/TLS target groups must be 6s";if(("HTTPS"===r||"TLS"===r)&&10!==a)return"HTTPS/TLS health check timeouts for TCP/TLS target groups must be 10s"}return null})(n),ge.checkBetween("healthCheckTimeout",2,120)),"lambda"!==n.targetType&&(a.field("protocol","Protocol").required(),a.field("healthCheckPath","Health Check Path").required(),a.field("healthCheckProtocol","Health Check Protocol").required(),a.field("name","Name").required(),a.field("healthyThreshold","Healthy Threshold").required().spelAware().withValidators(e=>he(e)),a.field("unhealthyThreshold","Unhealthy Threshold").required().spelAware().withValidators(e=>he(e)),a.field("healthCheckInterval","Health Check Interval").required().spelAware().withValidators(e=>he(e)),a.field("healthCheckPort","Health Check Port").required().spelAware().withValidators(e=>"traffic-port"===e?null:he(e)),a.field("port","Port").required().spelAware().withValidators(e=>he(e)),a.field("healthyThreshold","Healthy Threshold").required().spelAware().withValidators(e=>he(e),ge.checkBetween("healthyThreshold",2,10)),a.field("unhealthyThreshold","Unhealthy Threshold").required().spelAware().withValidators(e=>he(e),ge.checkBetween("unhealthyThreshold",2,10)))})),a.validateForm()}removeAppName(e){return e.replace(`${this.props.app.name}-`,"")}updateLoadBalancerNames(e){const{app:t,loadBalancer:a}=e,n={};Ia(t.getDataSource("loadBalancers").refresh(!0)).pipe($a(this.destroy$)).subscribe(()=>{t.getDataSource("loadBalancers").data.forEach(e=>{"classic"!==e.loadBalancerType&&(a&&e.name===a.name||e.targetGroups.forEach(t=>{n[e.account]=n[e.account]||{},n[e.account][e.region]=n[e.account][e.region]||[],n[e.account][e.region].push(this.removeAppName(t.name))}))}),this.setState({existingTargetGroupNames:n},()=>this.props.formik.validateForm())})}targetGroupFieldChanged(e,t,a){const{setFieldValue:n,values:r}=this.props.formik,i=r.targetGroups[e];"targetType"===t&&"lambda"===a&&delete i.port,da(i,t,a),n("targetGroups",r.targetGroups)}removeTargetGroup(e){const{setFieldValue:t,values:a}=this.props.formik,{oldTargetGroupCount:n}=this.state;a.targetGroups.splice(e,1),e<n&&this.setState({oldTargetGroupCount:n-1}),t("targetGroups",a.targetGroups)}componentDidMount(){this.updateLoadBalancerNames(this.props)}componentWillUnmount(){this.destroy$.next(),this.destroy$.complete()}render(){const{app:e}=this.props,{errors:t,values:a}=this.props.formik,{oldTargetGroupCount:r}=this.state,i=this.protocols.map(e=>Vt.createElement("option",{key:e},e)),s=this.targetTypes.map(e=>Vt.createElement("option",{key:e},e));return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},a.targetGroups.map((a,l)=>{const o=t.targetGroups&&t.targetGroups[l]||{},c=("TCP"===a.protocol||"TLS"===a.protocol)&&"HTTP"===a.healthCheckProtocol,d=("TCP"===a.protocol||"TLS"===a.protocol)&&"HTTPS"===a.healthCheckProtocol;return Vt.createElement("div",{key:l,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"group-name-prefix"},e.name,"-"),Vt.createElement("input",{className:"form-control input-sm target-group-name",type:"text",value:a.name,onChange:e=>this.targetGroupFieldChanged(l,"name",e.target.value),required:!0,disabled:l<r}),Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(l)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))),o.name&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:o.name})))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},Vt.createElement(n,{id:"aws.targetGroup.targetType"})," ",Vt.createElement("span",null,"Target Type ")),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("select",{className:"form-control input-sm",value:a.targetType,onChange:e=>this.targetGroupFieldChanged(l,"targetType",e.target.value),disabled:l<r},s))))),"lambda"!==a.targetType&&Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),Vt.createElement(n,{id:"aws.targetGroup.protocol"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",value:a.protocol,onChange:e=>this.targetGroupFieldChanged(l,"protocol",e.target.value),disabled:l<r},i)),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(n,{id:"aws.targetGroup.port"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",value:a.port,onChange:e=>this.targetGroupFieldChanged(l,"port",e.target.value),type:"text",required:!0,disabled:l<r}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},"lambda"!==a.targetType&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),"TCP"===a.healthCheckProtocol&&Vt.createElement(n,{id:"aws.targetGroup.healthCheckProtocol"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",value:a.healthCheckProtocol,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckProtocol",e.target.value)},i)),"lambda"!==a.targetType&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(n,{id:"aws.targetGroup.attributes.healthCheckPort.trafficPort"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"90px"},value:"traffic-port"===a.healthCheckPort?"traffic-port":"manual",onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPort","traffic-port"===e.target.value?"traffic-port":"")},Vt.createElement("option",{value:"traffic-port"},"Traffic Port"),Vt.createElement("option",{value:"manual"},"Manual"))," ",Vt.createElement(fe,{className:"form-control input-sm inline-number",error:o.healthCheckPort,style:{visibility:"traffic-port"===a.healthCheckPort?"hidden":"inherit"},name:"healthCheckPort",required:!0,value:a.healthCheckPort,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPort",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Path "),Vt.createElement(fe,{error:o.healthCheckPath,name:"healthCheckPath",required:!0,value:a.healthCheckPath,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPath",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Timeout "),(c||d)&&Vt.createElement(n,{id:"aws.targetGroup.healthCheckTimeout"}),Vt.createElement(ve,{error:o.healthCheckTimeout,disabled:c||d,required:!0,value:c?6:d?10:a.healthCheckTimeout,min:2,max:120,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckTimeout",e)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Interval "),Vt.createElement(ve,{error:o.healthCheckInterval,required:!0,value:a.healthCheckInterval,min:5,max:300,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckInterval",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck Threshold"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Healthy "),Vt.createElement(ve,{error:o.healthyThreshold,value:a.healthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"healthyThreshold",e)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Unhealthy "),Vt.createElement(ve,{error:o.unhealthyThreshold,required:!0,value:a.unhealthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"unhealthyThreshold",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),"lambda"!==a.targetType?Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Dereg. Delay"),Vt.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",value:a.attributes.deregistrationDelay,onChange:e=>this.targetGroupFieldChanged(l,"attributes.deregistrationDelay",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Vt.createElement("input",{type:"checkbox",checked:a.attributes.stickinessEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.stickinessEnabled",e.target.checked)})," ",Vt.createElement("label",null,"Sticky"),Vt.createElement(n,{id:"aws.targetGroup.attributes.stickinessEnabled"}))),a.attributes.stickinessEnabled&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Duration "),Vt.createElement(n,{id:"aws.targetGroup.attributes.stickinessDuration"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",value:a.attributes.stickinessDuration,onChange:e=>this.targetGroupFieldChanged(l,"attributes.stickinessDuration",e.target.value),type:"text"})))):Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Vt.createElement("input",{type:"checkbox",checked:a.attributes.multiValueHeadersEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.multiValueHeadersEnabled",e.target.checked)})," ",Vt.createElement("label",null,"Enable Multi Value Headers"))))))}),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}};class ri extends Vt.Component{constructor(e){super(e),this.handleUsePreferredZonesChanged=e=>{const t="true"===e.target.value;this.setState({usePreferredZones:t}),t&&this.setDefaultZones(t,this.props)},this.handleSelectedZonesChanged=e=>{this.props.onChange([...e])},this.state={defaultZones:[],usePreferredZones:e.usePreferredZones||!e.selectedZones||0===e.selectedZones.length},this.setDefaultZones(this.state.usePreferredZones,e)}componentWillReceiveProps(e){e.region===this.props.region&&e.credentials===this.props.credentials||this.setDefaultZones(this.state.usePreferredZones,e)}setDefaultZones(e,t){const{credentials:a,region:n}=t;o.getAvailabilityZonesForAccountAndRegion("aws",a,n).then(a=>{this.setState({defaultZones:a}),e&&a&&t.onChange(a.slice())})}render(){const{region:e,allZones:t,selectedZones:a}=this.props,{defaultZones:n,usePreferredZones:r}=this.state;return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Availability Zones"),e&&Vt.createElement("div",{className:"col-md-7"},Vt.createElement("p",{className:"form-control-static"},"Automatic Availability Zone Balancing:"),Vt.createElement("select",{className:"form-control input-sm",value:r?"true":"false",onChange:this.handleUsePreferredZonesChanged},Vt.createElement("option",{value:"true"},"Enabled"),Vt.createElement("option",{value:"false"},"Manual")),Vt.createElement("br",null),r&&Vt.createElement("div",null,Vt.createElement("p",{className:"form-control-static"},"Server group will be available in:"),Vt.createElement("ul",null,n.map(e=>Vt.createElement("li",{key:e},e)))),!r&&Vt.createElement("div",null,"Restrict server group instances to:",Vt.createElement(ye,{stringOptions:t,value:a,onChange:e=>this.handleSelectedZonesChanged(e.target.value)}))))}}function ii(e){const{application:t,credentials:a,defaultSubnetTypes:n,hideClassic:r,name:i,onChange:s,readOnly:l,region:o,subnets:c,value:d,...u}=e,p=be(c),m=Vt.useMemo(()=>{const e=r||function(e,t,a){const{classicLaunchLockout:n,classicLaunchAllowlist:r}=kn,i=Number(ia(a,"attributes.createTs",0))>(n||0),s=!!r&&r.some(a=>a.region===e&&a.credentials===t);return i||!s}(o,a,t);return function(e,t){const a=(e,t)=>e.label.localeCompare(t.label),n=e=>({value:e.purpose,label:e.label}),r=t?[]:[{label:"None (EC2 Classic)",value:""}],i=e.filter(e=>!e.deprecated).sort(a).map(n),s=e.filter(e=>e.deprecated).sort(a).map(n);return s.length&&s.unshift({label:"-----------",value:"",disabled:!0}),r.concat(i).concat(s)}(c,e)},[r,o,a,t,p]),g=function(e,t=[]){for(const a of t){const t=e.find(e=>a===e.purpose);if(t)return t}}(c,n)||c[0],h=Ee().current;return Vt.useEffect(()=>{const e=m.some(e=>e.value===d);g&&(!e||"FIRST_RENDER"!==h)&&s(we({name:i,value:g.purpose}))},[m]),l?Vt.createElement("p",{className:"form-control-static"},e.value||"None (EC2 Classic)"):Vt.createElement(de,{options:m,value:d,onChange:s,...u})}class si extends Ot.Component{constructor(){super(...arguments),this.handleChange=e=>{const{component:t,onChange:a,field:n}=this.props;t[n]=e.target.value,a()}}render(){var e,t,a;const{component:r,defaultSubnetTypes:i,field:s,helpKey:l,labelColumns:o,recommendedSubnetTypes:c,region:d,showSubnetWarning:u,...p}=this.props,m=r[s],g=null!=(t=null!=c?c:null==(e=kn.serverGroups)?void 0:e.recommendedSubnets)?t:[],h=null!=i?i:[kn.defaults.subnetType],f=g.some(e=>m&&m.includes(e)),v=null==(a=kn.serverGroups)?void 0:a.subnetWarning;return Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:`col-md-${o} sm-label-right`},"VPC Subnet ",Ot.createElement(n,{id:l})),Ot.createElement("div",{className:"col-md-7"},d?Ot.createElement(ii,{...p,inputClassName:"form-control input-sm",credentials:r.credentials,defaultSubnetTypes:h,region:d,value:m,onChange:this.handleChange}):"(Select an account)",u&&!f&&Boolean(v)&&Ot.createElement("div",{className:"alert alert-warning sp-margin-s-top horizontal center"},Ot.createElement("i",{className:"fa fa-exclamation-triangle sp-margin-s-top"}),Ot.createElement("div",{className:"sp-margin-s-left"},Ot.createElement(Ce,{message:v,style:{display:"inline-block",marginLeft:"2px"}})))))}}class li extends Vt.Component{constructor(){super(...arguments),this.state={accounts:void 0,availabilityZones:[],existingLoadBalancerNames:[],hideInternalFlag:!1,internalFlagToggled:!1,regions:[],subnets:[]},this.props$=new Ta,this.destroy$=new Ta,this.internalFlagChanged=e=>{this.setState({internalFlagToggled:!0}),this.props.formik.handleChange(e)},this.handleSubnetUpdated=e=>{this.props.formik.setFieldValue("subnetType",e)},this.accountUpdated=e=>{this.props.formik.setFieldValue("credentials",e)},this.regionUpdated=e=>{this.props.formik.setFieldValue("region",e)},this.stackChanged=e=>{this.props.formik.setFieldValue("stack",e.target.value)},this.detailChanged=e=>{this.props.formik.setFieldValue("detail",e.target.value)},this.handleAvailabilityZonesChanged=e=>{this.props.formik.setFieldValue("regionZones",e)}}validate(e){const t={};return this.state.existingLoadBalancerNames.includes(e.name)&&(t.name=`There is already a load balancer in ${e.credentials}:${e.region} with that name.`),e.name&&e.name.length>32&&(t.name="Load balancer names cannot exceed 32 characters in length"),e.stack&&!e.stack.match(/^[a-zA-Z0-9]*$/)&&(t.stack="Stack can only contain letters and numbers."),e.detail&&!e.detail.match(/^[a-zA-Z0-9-]*$/)&&(t.detail="Detail can only contain letters, numbers, and dashes."),t}buildName(){const{values:e}=this.props.formik;if(Yt(e.moniker)){const t=re.parseLoadBalancerName(e.name);e.stack=t.stack,e.detail=t.freeFormDetails}else e.stack=e.moniker.stack,e.detail=e.moniker.detail;delete e.name}shouldHideInternalFlag(){return!!(kn&&kn.loadBalancers&&kn.loadBalancers.inferInternalFlagFromSubnet)&&(delete this.props.formik.values.isInternal,!0)}componentDidMount(){this.setState({hideInternalFlag:this.shouldHideInternalFlag()}),this.props.loadBalancer&&this.props.isNew&&this.buildName();const e=this.props$.pipe(Da(e=>e.formik.values)),t=this.props$.pipe(Da(e=>e.app.name),Ba()),a={account$:e.pipe(Da(e=>e.credentials),Ba()),region$:e.pipe(Da(e=>e.region),Ba()),subnetPurpose$:e.pipe(Da(e=>e.subnetType),Ba()),stack$:e.pipe(Da(e=>e.stack),Ba()),detail$:e.pipe(Da(e=>e.detail),Ba())},n=Ia(o.listAccounts("aws")).pipe(za(1)),r=Ga([a.account$,n]).pipe(Fa(([e,t])=>o.getRegionsForAccount(e)),za(1)),i=this.props.app.getDataSource("loadBalancers").data$,s=Ga([i,a.account$,a.region$]).pipe(Da(([e,t,a])=>e.filter(e=>e.account===t&&e.region===a).map(e=>e.name)),za(1)),l=Ga([a.account$,a.region$]).pipe(Fa(([e,t])=>this.getAvailableSubnets(e,t)),Da(e=>this.makeSubnetOptions(e)),za(1)),c=Ga([l,a.subnetPurpose$]).pipe(Da(([e,t])=>e&&e.find(e=>e.purpose===t))),d=c.pipe(Da(e=>e?sa(e.availabilityZones).sort():[])),u=a.region$.pipe(Ma(r),Da(([e,t])=>t.find(t=>t.name===e)),Da(e=>e?e.availabilityZones:[])),p=Ga([t,a.stack$,a.detail$]).pipe(Da(([e,t,a])=>({app:e,stack:t,detail:a,cluster:re.getClusterName(e,t,a)})));r.pipe(Ma(a.region$),$a(this.destroy$)).subscribe(([e,t])=>{e.some(e=>e.name===t)||this.props.formik.setFieldValue("region",e[0]&&e[0].name)}),u.pipe($a(this.destroy$)).subscribe(e=>{this.props.formik.setFieldValue("regionZones",e)}),c.pipe($a(this.destroy$)).subscribe(e=>{this.props.formik.setFieldValue("vpcId",e&&e.vpcIds[0]),this.props.formik.setFieldValue("subnetType",e&&e.purpose),!this.state.hideInternalFlag&&!this.state.internalFlagToggled&&e&&e.purpose&&this.props.formik.setFieldValue("isInternal",e.purpose.includes("internal"))}),p.pipe($a(this.destroy$)).subscribe(e=>{this.props.formik.setFieldValue("moniker",e),this.props.formik.setFieldValue("name",e.cluster)}),Ga([n,r,d,s,l]).pipe($a(this.destroy$)).subscribe(([e,t,a,n,r])=>this.setState({accounts:e,regions:t,availabilityZones:a,existingLoadBalancerNames:n,subnets:r}))}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}getAvailableSubnets(e,t){return g.listSubnets().then(a=>ta(a).filter({account:e,region:t}).reject({target:"ec2"}).reject({purpose:null}).value())}makeSubnetOptions(e){const t=ra(e,e=>e.purpose);return Object.keys(t).map(e=>t[e]).map(e=>(e=>{const{purpose:t,label:a,deprecated:n}=e[0];return{purpose:t,label:a,deprecated:n,vpcIds:sa(e.map(e=>e.vpcId)),availabilityZones:sa(e.map(e=>e.availabilityZone))}})(e))}render(){const{app:e}=this.props,{errors:t,values:a}=this.props.formik,{accounts:r,availabilityZones:i,hideInternalFlag:s,regions:l,subnets:o}=this.state,c=Na({"col-md-12":!0,well:!0,"alert-danger":!!t.name,"alert-info":!t.name});return Vt.createElement("div",{className:"container-fluid form-horizontal"},!r&&Vt.createElement("div",{style:{height:"200px"}},Vt.createElement(ae,{size:"medium"})),r&&Vt.createElement("div",{className:"modal-body"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:c},Vt.createElement("strong",null,"Your load balancer will be named: "),Vt.createElement("span",null,a.name),Vt.createElement(n,{id:"aws.loadBalancer.name"}),Vt.createElement(un,{type:"text",style:{display:"none"},className:"form-control input-sm no-spel",name:"name"}),t.name&&Vt.createElement(pe,{type:"error",message:t.name}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Vt.createElement("div",{className:"col-md-7"},Vt.createElement(Se,{value:a.credentials,onChange:e=>this.accountUpdated(e.target.value),accounts:r,provider:"aws"}))),Vt.createElement(ke,{labelColumns:3,component:a,field:"region",account:a.credentials,onChange:this.regionUpdated,regions:l}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Vt.createElement(n,{id:"aws.loadBalancer.stack"})),Vt.createElement("div",{className:"col-md-3"},Vt.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.stack?"invalid":""),value:a.stack,name:"stack",onChange:this.stackChanged})),Vt.createElement("div",{className:"col-md-6 form-inline"},Vt.createElement("label",{className:"sm-label-right"},Vt.createElement("span",null,"Detail ",Vt.createElement(n,{id:"aws.loadBalancer.detail"})," ")),Vt.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.detail?"invalid":""),value:a.detail,name:"detail",onChange:this.detailChanged})),t.stack&&Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement(pe,{type:"error",message:t.stack})),t.detail&&Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement(pe,{type:"error",message:t.detail}))),Vt.createElement(ri,{credentials:a.credentials,region:a.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:a.regionZones,allZones:i}),Vt.createElement(si,{labelColumns:3,helpKey:"aws.loadBalancer.subnet",component:a,field:"subnetType",region:a.region,subnets:o,application:e,onChange:()=>this.handleSubnetUpdated(a.subnetType)}),a.vpcId&&!s&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},Vt.createElement("b",null,"Internal")," ",Vt.createElement(n,{id:"aws.loadBalancer.internal"})),Vt.createElement("div",{className:"col-md-7 checkbox"},Vt.createElement("label",null,Vt.createElement(un,{name:"isInternal",onChange:this.internalFlagChanged,render:({field:{value:e,...t}})=>Vt.createElement("input",{type:"checkbox",...t,checked:!!e})}),"Create an internal load balancer")))))}}class oi extends Vt.Component{constructor(e){super(e),this.destroy$=new Ta,this.props$=new Ta,this.refresh$=new Ta,this.clearRemoved=()=>{this.setState({removed:[]},()=>this.props.formik.validateForm())},this.handleSecurityGroupsChanged=e=>{this.props.formik.setFieldValue("securityGroups",e.map(e=>e.value))};const t=ia(kn,"defaultSecurityGroups",[]);this.state={availableSecurityGroups:[],defaultSecurityGroups:t,loaded:!1,refreshing:!1,removed:[],refreshTime:Ne.get("securityGroups").getStats().ageMax}}validate(){const{removed:e}=this.state;if(e&&e.length){return{securityGroupsRemoved:`${U.get("Firewalls")} removed: ${e.join(", ")}`}}return{}}updateRemovedSecurityGroups(e,t){const{isNew:a}=this.props,{defaultSecurityGroups:n,removed:r}=this.state,i=e=>t.find(t=>t.name===e||t.id===e),[s,l]=ua((()=>{const t=e.concat(r).sort();return sa((a?n:[]).concat(t))})(),e=>!!i(e)),o=s.map(e=>i(e).name);Jt(e,o)||this.props.formik.setFieldValue("securityGroups",o),this.setState({removed:l},()=>this.props.formik.validateForm())}onRefreshStart(){this.props.onLoadingChanged(!0),this.setState({refreshing:!0})}onRefreshComplete(){this.props.onLoadingChanged(!1);const e=Ne.get("securityGroups").getStats().ageMax;this.setState({refreshing:!1,loaded:!0,refreshTime:e})}componentDidMount(){const e=this.refresh$.pipe(La(()=>this.onRefreshStart()),Fa(()=>h.cacheInitializer.refreshCache("securityGroups")),Ra(()=>h.securityGroupReader.getAllSecurityGroups()),La(()=>this.onRefreshComplete())),t=this.props$.pipe(Da(e=>e.formik.values)),a=t.pipe(Da(e=>e.vpcId),Ba());Ga([a,e]).pipe(Ma(t),Da(([[e,t],a])=>{const n=t[a.credentials]||{};return(n.aws&&n.aws[a.region]||[]).filter(t=>e===t.vpcId).sort()})).pipe(Ma(t),$a(this.destroy$)).subscribe(([e,t])=>{this.setState({availableSecurityGroups:e.map(e=>({label:`${e.name} (${e.id})`,value:e.name}))}),this.updateRemovedSecurityGroups(t.securityGroups,e)}),this.refresh$.next()}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next(),this.destroy$.complete()}render(){const{securityGroups:e}=this.props.formik.values,{availableSecurityGroups:t,loaded:a,refreshing:n,removed:r,refreshTime:i}=this.state;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",null,r.length>0&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following ",U.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,r.map(e=>Vt.createElement("li",{key:e},e))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:this.clearRemoved},"Okay"))))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},U.get("Firewalls")),Vt.createElement("div",{className:"col-md-9"},!a&&Vt.createElement("div",{style:{paddingTop:"13px"}},Vt.createElement(ae,{size:"small"})),a&&Vt.createElement(pn,{multi:!0,value:e,options:t,onChange:this.handleSecurityGroupsChanged,clearable:!1}))),Vt.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Vt.createElement("div",{className:"col-md-9 col-md-offset-3"},Vt.createElement("p",null,n&&Vt.createElement("span",null,Vt.createElement("span",{className:"fa fa-sync-alt fa-spin"})," "),U.get("Firewalls"),!n&&Vt.createElement("span",null," last refreshed ",z(i)),n&&Vt.createElement("span",null," refreshing...")),Vt.createElement("p",null,"If you're not finding a ",U.get("firewall")," that was recently added,"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.refresh$.next()},"click here")," ","to refresh the list.")))))}}Ar(".wizard-pod {\n padding-bottom: 15px;\n}\n.wizard-pod > div {\n border: 1px solid var(--color-cirrus);\n}\n.wizard-pod .wizard-pod-row {\n display: flex;\n padding: 5px;\n border-bottom: 1px solid var(--color-cirrus);\n}\n.wizard-pod .wizard-pod-row label {\n font-weight: 400;\n padding-right: 5px;\n}\n.wizard-pod .wizard-pod-row.header {\n background-color: var(--color-cirrus);\n}\n.wizard-pod .wizard-pod-row.header .glyphicon-trash {\n padding: 0 8px;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-title {\n font-weight: 800;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-data {\n flex-wrap: nowrap;\n padding: 0;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-data label {\n font-weight: 600;\n}\n.wizard-pod .wizard-pod-row.header .wizard-pod-row-contents .wizard-pod-row-data .wizard-pod-content {\n padding: 0 10px 0 0;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-title {\n display: flex;\n align-items: center;\n max-height: 37px;\n flex-basis: 120px;\n flex-direction: row-reverse;\n font-weight: 600;\n text-align: right;\n margin-right: 10px;\n width: 100px;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents {\n display: flex;\n width: 100%;\n align-items: baseline;\n flex-wrap: wrap;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data {\n display: flex;\n width: 100%;\n align-items: baseline;\n flex-wrap: wrap;\n padding: 5px 0;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data.spread {\n justify-content: space-between;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .wizard-pod-content {\n padding: 0 10px 5px 0;\n display: flex;\n align-items: center;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .group-name-prefix {\n flex-grow: 2;\n white-space: nowrap;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .rules-table thead th {\n font-weight: 600;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .rules-table td {\n vertical-align: middle;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-data .rules-table > tbody > tr:first-child > td {\n border-top: none;\n}\n.wizard-pod .wizard-pod-row .wizard-pod-row-contents .wizard-pod-row-errors {\n display: flex;\n width: 100%;\n}\n.wizard-pod .listener-rule .handle {\n cursor: move;\n width: 10px;\n padding: 0;\n}\n.wizard-pod .listener-rule .listener-rule-condition {\n display: flex;\n}\n.wizard-pod .listener-rule .listener-rule-condition label {\n white-space: nowrap;\n}\n.wizard-pod .listener-rule .listener-rule-condition .help-field > span {\n top: 4px;\n padding: 0 2px;\n}\n.wizard-pod .listener-rule .listener-rule-condition .remove-condition {\n min-width: 15px;\n padding-top: 4px;\n}\n.wizard-pod .listener-rule .add-new-container {\n display: flex;\n}\n.wizard-pod .listener-rule .add-new-container .add-new {\n padding: 2px;\n margin-bottom: 0;\n}\n.rule-sortable-helper {\n z-index: 99999;\n width: 500px;\n}\n");const ci=class e extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.submit=e=>{const{app:t,forPipelineConfig:a,closeModal:n}=this.props,{isNew:r}=this.state,i=r?"Create":"Update",s=_t(e);if(s.listeners.forEach(e=>{e.defaultActions.forEach(e=>{e.authenticateOidcConfig&&(e.authenticateOidcActionConfig=e.authenticateOidcConfig,delete e.authenticateOidcConfig)}),e.rules.forEach(e=>e.actions.forEach(e=>{e.authenticateOidcConfig&&(e.authenticateOidcActionConfig=e.authenticateOidcConfig,delete e.authenticateOidcConfig)}))}),a)this.formatListeners(s).then(()=>{this.setIpAddressType(s),n&&n(s)});else{const e=new v({application:t,title:(r?"Creating":"Updating")+" your load balancer",modalInstance:v.modalInstanceEmulation(()=>this.props.dismissModal()),onTaskComplete:()=>this.onTaskComplete(s)});e.submit(()=>this.formatListeners(s).then(()=>(this.formatCommand(s),Te.upsertLoadBalancer(s,t,i)))),this.setState({taskMonitor:e})}};const t=e.command?e.command:e.loadBalancer?Mr.convertApplicationLoadBalancerForEditing(e.loadBalancer):Mr.constructNewApplicationLoadBalancerTemplate(e.app);this.state={includeSecurityGroups:!!t.vpcId,isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(t){return b.show(e,t,{dialogClassName:"wizard-modal modal-lg"})}certificateIdAsARN(e,t,a,n){if(t&&(0!==t.indexOf("arn:aws:iam::")||0!==t.indexOf("arn:aws:acm:"))){if("iam"===n)return`arn:aws:iam::${e}:server-certificate/${t}`;if("acm"===n)return`arn:aws:acm:${a}:${e}:certificate/${t}`}return t}formatListeners(e){return o.getAccountDetails(e.credentials).then(t=>{e.listeners.forEach(a=>{"HTTP"===a.protocol&&(delete a.sslPolicy,a.certificates=[]),a.certificates.forEach(a=>{a.certificateArn=this.certificateIdAsARN(t.accountId,a.name,e.region,a.type||this.certificateTypes[0])})})})}setAvailabilityZones(e){const t={};t[e.region]=e.regionZones||[],e.availabilityZones=t}addAppName(e){return`${this.props.app.name}-${e}`}manageTargetGroupNames(e){(e.targetGroups||[]).forEach(e=>{e.name=this.addAppName(e.name)}),(e.listeners||[]).forEach(e=>{e.defaultActions.forEach(e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))}),(e.rules||[]).forEach(e=>{e.actions.forEach(e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))})})})}manageRules(e){e.listeners.forEach(e=>{e.rules.forEach((e,t)=>{e.priority=t+1,e.conditions=e.conditions.filter(e=>"http-request-method"!==e.field?e.values[0].length>0:e.values.length>0)})})}setIpAddressType(e){e.ipAddressType=e.dualstack?"dualstack":"ipv4",delete e.dualstack}formatCommand(e){this.setAvailabilityZones(e),this.manageTargetGroupNames(e),this.manageRules(e),this.setIpAddressType(e)}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.loadBalancerDetails")?h.$state.go("^.loadBalancerDetails",t):h.$state.go(".loadBalancerDetails",t)}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onTaskComplete(e){this.props.app.loadBalancers.refresh(),this.refreshUnsubscribe=this.props.app.loadBalancers.onNextRefresh(null,()=>this.onApplicationRefresh(e))}render(){const{app:e,dismissModal:t,forPipelineConfig:a,loadBalancer:n}=this.props,{isNew:r,loadBalancerCommand:i,taskMonitor:s}=this.state;let l=a?"Configure Application Load Balancer":"Create New Application Load Balancer";return r||(l=`Edit ${i.name}: ${i.region}: ${i.credentials}`),Vt.createElement(E,{heading:l,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",render:({formik:t,nextIdx:i,wizard:s})=>{const l=r||a,o=!!t.values.vpcId;return Vt.createElement(Vt.Fragment,null,l&&Vt.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Vt.createElement(li,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),o&&Vt.createElement(w,{label:U.get("Firewalls"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Vt.createElement(oi,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Vt.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(ni,{ref:a,app:e,formik:t,isNew:r,loadBalancer:n})}),Vt.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(Yr,{ref:a,app:e,formik:t})}),Vt.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(Vr,{ref:e})}))}})}};ci.defaultProps={closeModal:C,dismissModal:C};let di=ci;Ar(".AmazonLoadBalancer-AdvancedSettings .StandardFieldLayout .sm-label-right {\n width: 180px;\n}\n");class ui extends Vt.Component{render(){const{values:e}=this.props.formik,{maxValue:t}=ge;return Vt.createElement("div",{className:"form-group AmazonLoadBalancer-AdvancedSettings"},Vt.createElement(s,{name:"healthTimeout",label:"Timeout",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.healthTimeout"}),input:t=>Vt.createElement(p,{...t,min:0,max:e.healthInterval}),validate:t(e.healthInterval,"Timeout must be less than the health interval.")}),Vt.createElement(s,{name:"healthInterval",label:"Interval",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.healthInterval"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"healthyThreshold",label:"Healthy Threshold",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.healthyThreshold"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"unhealthyThreshold",label:"Unhealthy Threshold",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.unhealthyThreshold"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement(s,{name:"idleTimeout",label:"Idle Timeout",required:!0,help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Vt.createElement(p,{...e,min:0})}),Vt.createElement("div",{className:"col-md-12"},Vt.createElement("p",null,"Additional configuration options (cross-zone load balancing, session stickiness, access logs) are available via the AWS console.")))}}class pi extends Vt.Component{constructor(){super(...arguments),this.healthCheckPathChanged=e=>{e&&0!==e.indexOf("/")&&this.props.formik.setFieldValue("healthCheckPath",`/${e}`)}}requiresHealthCheckPath(){const{values:e}=this.props.formik;return e.healthCheckProtocol&&0===e.healthCheckProtocol.indexOf("HTTP")}render(){return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},"Ping"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{style:{width:"35%"}},"Protocol"),Vt.createElement("th",{style:{width:"30%"}},"Port"),Vt.createElement("th",null,this.requiresHealthCheckPath()&&Vt.createElement("span",null,"Path")))),Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement(s,{name:"healthCheckProtocol",required:!0,input:e=>Vt.createElement(de,{...e,options:["HTTP","HTTPS","SSL","TCP"]})})),Vt.createElement("td",null,Vt.createElement(s,{name:"healthCheckPort",required:!0,input:e=>Vt.createElement(p,{...e,min:1,max:65534})})),Vt.createElement("td",null,this.requiresHealthCheckPath()&&Vt.createElement(s,{name:"healthCheckPath",input:e=>Vt.createElement(l,{...e}),required:!0,onChange:this.healthCheckPathChanged})))))))}}Ar(".create-classic-load-balancer-wizard-listeners .Select-control {\n height: 30px;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-placeholder {\n line-height: 26px;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-value {\n line-height: 26px !important;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-value .Select-value-label {\n line-height: 26px;\n}\n.create-classic-load-balancer-wizard-listeners .Select-control .Select-input {\n height: 26px;\n}\n");class mi extends Vt.Component{constructor(){super(...arguments),this.protocols=["HTTP","HTTPS","TCP","SSL"],this.secureProtocols=["HTTPS","SSL"],this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.state={certificates:[]},this.addListener=()=>{this.props.formik.values.listeners.push({internalProtocol:"HTTP",externalProtocol:"HTTP",externalPort:80,internalPort:80}),this.updateListeners()}}componentDidMount(){this.loadCertificates()}loadCertificates(){Zr.listCertificates().then(e=>{this.setState({certificates:e})})}updateListeners(){const{values:e,setFieldValue:t}=this.props.formik;t("listeners",e.listeners)}showCertificateSelect(e){return"iam"===e.sslCertificateType&&this.state.certificates&&Object.keys(this.state.certificates).length>0}listenerExternalProtocolChanged(e,t){e.externalProtocol=t,this.secureProtocols.includes(t)&&(e.externalPort=443,this.certificateTypes.length>=1&&(e.sslCertificateType=this.certificateTypes[0])),"HTTP"===t&&(e.externalPort=80),this.updateListeners()}listenerInternalProtocolChanged(e,t){e.internalProtocol=t,this.updateListeners()}listenerExternalPortChanged(e,t){e.externalPort=Number.parseInt(t,10),this.updateListeners()}listenerInternalPortChanged(e,t){e.internalPort=Number.parseInt(t,10),this.updateListeners()}listenerCertificateTypeChanged(e,t){e.sslCertificateType=t,this.updateListeners()}handleListenerCertificateChanged(e,t){e.sslCertificateName=t,this.updateListeners()}removeListener(e){this.props.formik.values.listeners.splice(e,1),this.updateListeners()}renderCertificateSelector(e){if(this.secureProtocols.includes(e.externalProtocol)){if(this.showCertificateSelect(e)){const{values:t}=this.props.formik,{certificates:a}=this.state;return Vt.createElement(Or,{certificates:a,accountName:t.credentials,currentValue:e.sslCertificateName,app:this.props.app,onCertificateSelect:t=>this.handleListenerCertificateChanged(e,t)})}return Vt.createElement("input",{className:"input-sm",style:{width:"100%",marginLeft:"10px"},required:!0,onChange:t=>this.handleListenerCertificateChanged(e,t.target.value),value:e.sslCertificateName})}return null}render(){const{values:e}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal create-classic-load-balancer-wizard-listeners"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",null,"External Protocol"),Vt.createElement("th",null,"External Port"),Vt.createElement("th",null),Vt.createElement("th",null,"Internal Protocol"),Vt.createElement("th",null,"Internal Port"),Vt.createElement("th",null))),Vt.createElement("tbody",null,e.listeners.map((e,t)=>Vt.createElement(Vt.Fragment,{key:t},Vt.createElement("tr",{key:t+"-main"},Vt.createElement("td",null,Vt.createElement("select",{className:"form-control input-sm",value:e.externalProtocol,onChange:t=>this.listenerExternalProtocolChanged(e,t.target.value)},this.protocols.map(e=>Vt.createElement("option",{key:e},e)))),Vt.createElement("td",null,Vt.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.externalPort,onChange:t=>this.listenerExternalPortChanged(e,t.target.value),required:!0})),Vt.createElement("td",{className:"small",style:{paddingTop:"10px"}},"→"),Vt.createElement("td",null,Vt.createElement("select",{className:"form-control input-sm",value:e.internalProtocol,onChange:t=>this.listenerInternalProtocolChanged(e,t.target.value)},this.protocols.map(e=>Vt.createElement("option",{key:e},e)))),Vt.createElement("td",null,Vt.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.internalPort,onChange:t=>this.listenerInternalPortChanged(e,t.target.value),required:!0})),Vt.createElement("td",null,Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(t)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"})))),this.secureProtocols.includes(e.externalProtocol)&&Vt.createElement("tr",{key:t+"-ssl"},Vt.createElement("td",{colSpan:5,style:{borderTopWidth:0}},Vt.createElement("div",{className:"horizontal space-between"},Vt.createElement("div",{className:"sm-label-right"},"Certificate"),this.certificateTypes.length>1&&Vt.createElement("select",{style:{width:"45px",marginLeft:"10px"},className:"form-control input-sm",value:e.sslCertificateType,onChange:t=>this.listenerCertificateTypeChanged(e,t.target.value)},this.certificateTypes.map(e=>Vt.createElement("option",{key:e},e))),this.renderCertificateSelector(e))))))),Vt.createElement("tfoot",null,Vt.createElement("tr",null,Vt.createElement("td",{colSpan:5},Vt.createElement("button",{className:"add-new col-md-12",onClick:this.addListener,type:"button"},Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),Vt.createElement("span",null," Add new port mapping")))))))))}}const gi=class e extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.submit=e=>{const{app:t,forPipelineConfig:a,closeModal:n}=this.props,{isNew:r}=this.state,i=r?"Create":"Update",s=_t(e);if(a)this.formatListeners(s).then(()=>{n&&n(s)});else{const e=new v({application:t,title:(r?"Creating":"Updating")+" your load balancer",modalInstance:v.modalInstanceEmulation(()=>this.props.dismissModal()),onTaskComplete:()=>this.onTaskComplete(s)});e.submit(()=>this.formatListeners(s).then(()=>(this.formatCommand(s),Te.upsertLoadBalancer(s,t,i)))),this.setState({taskMonitor:e})}},this.validate=e=>({});const t=e.command?e.command:e.loadBalancer?Mr.convertClassicLoadBalancerForEditing(e.loadBalancer):Mr.constructNewClassicLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(t){return b.show(e,t,{dialogClassName:"wizard-modal modal-lg"})}certificateIdAsARN(e,t,a,n){if(t&&(0!==t.indexOf("arn:aws:iam::")||0!==t.indexOf("arn:aws:acm:"))){if("iam"===n)return`arn:aws:iam::${e}:server-certificate/${t}`;if("acm"===n)return`arn:aws:acm:${a}:${e}:certificate/${t}`}return t}formatListeners(e){return o.getAccountDetails(e.credentials).then(t=>{e.listeners.forEach(a=>{a.sslCertificateId=this.certificateIdAsARN(t.accountId,a.sslCertificateName,e.region,a.sslCertificateType||this.certificateTypes[0])})})}clearSecurityGroupsIfNotInVpc(e){e.vpcId||e.subnetType||(e.securityGroups=null)}addHealthCheckToCommand(e){let t=null;const a=e.healthCheckProtocol||"";t=a.startsWith("HTTP")?`${a}:${e.healthCheckPort}${e.healthCheckPath}`:`${a}:${e.healthCheckPort}`,e.healthCheck=t}setAvailabilityZones(e){const t={};t[e.region]=e.regionZones||[],e.availabilityZones=t}formatCommand(e){this.setAvailabilityZones(e),this.clearSecurityGroupsIfNotInVpc(e),this.addHealthCheckToCommand(e)}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.loadBalancerDetails")?h.$state.go("^.loadBalancerDetails",t):h.$state.go(".loadBalancerDetails",t)}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onTaskComplete(e){this.props.app.loadBalancers.refresh(),this.refreshUnsubscribe=this.props.app.loadBalancers.onNextRefresh(null,()=>this.onApplicationRefresh(e))}render(){const{app:e,dismissModal:t,forPipelineConfig:a,loadBalancer:n}=this.props,{isNew:r,loadBalancerCommand:i,taskMonitor:s}=this.state,l=r||a;let o=a?"Configure Classic Load Balancer":"Create New Classic Load Balancer";return r||(o=`Edit ${i.name}: ${i.region}: ${i.credentials}`),Vt.createElement(E,{heading:o,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",validate:this.validate,render:({formik:t,nextIdx:i,wizard:s})=>Vt.createElement(Vt.Fragment,null,l&&Vt.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Vt.createElement(li,{app:e,formik:t,isNew:r,forPipelineConfig:a,loadBalancer:n,ref:i})}),!!t.values.vpcId&&Vt.createElement(w,{label:U.get("Firewall"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Vt.createElement(oi,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Vt.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(mi,{ref:a,formik:t,app:e})}),Vt.createElement(w,{label:"Health Check",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(pi,{ref:e,formik:t})}),Vt.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(ui,{ref:e,formik:t})}))})}};gi.defaultProps={closeModal:C,dismissModal:C};let hi=gi;const fi=Vt.forwardRef((e,t)=>Vt.createElement("div",{ref:t},Vt.createElement(s,{name:"deletionProtection",label:"Protection",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Vt.createElement(d,{...e,text:"Enable deletion protection"})}),Vt.createElement(s,{name:"loadBalancingCrossZone",label:"Cross-Zone Load Balancing",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.loadBalancingCrossZone"}),input:e=>Vt.createElement(d,{...e,text:"Distribute traffic across zones"})}),e.showDualstack&&Vt.createElement(s,{name:"dualstack",label:"Dualstack",help:Vt.createElement(n,{id:"loadBalancer.advancedSettings.nlbIpAddressType"}),input:e=>Vt.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})})));function vi({availableCertificates:e,certificates:t,formik:a,app:n,certificateTypes:r}){function i(){a.setFieldValue("listeners",a.values.listeners)}function s(e,t){e.name=t,i()}function l(e){return"iam"===e.type&&t&&Object.keys(t).length>0}const{values:o}=a;return Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Vt.createElement("div",{className:"wizard-pod-row-contents"},e.map((e,a)=>Vt.createElement("div",{key:a,style:{width:"100%",display:"flex",flexDirection:"row"}},Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"45px"},value:e.type,onChange:t=>function(e,t){e.type=t,i()}(e,t.target.value)},r.map(e=>Vt.createElement("option",{key:e},e))),l(e)&&Vt.createElement(Or,{certificates:t,accountName:o.credentials,currentValue:e.name,app:n,onCertificateSelect:t=>s(e,t)}),!l(e)&&Vt.createElement("input",{className:"form-control input-sm no-spel",style:{display:"inline-block"},type:"text",value:e.name,onChange:t=>s(e,t.target.value),required:!0})))))}class yi extends Vt.Component{constructor(e){super(e),this.protocols=["TCP","UDP","TLS"],this.removedAuthActions=new Map,this.addListener=()=>{this.props.formik.values.listeners.push({certificates:[],protocol:"TCP",port:80,defaultActions:[{type:"forward",targetGroupName:""}],rules:[]}),this.updateListeners()},this.handleDefaultTargetChanged=(e,t)=>{e.defaultActions[0].targetGroupName=t,this.updateListeners()},this.state={certificates:[],certificateTypes:ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),oidcConfigs:void 0}}getAllTargetGroupsFromListeners(e){const t=Kt(e.map(e=>e.defaultActions)),a=Kt(e.map(e=>e.rules));return t.push(...Kt(a.map(e=>e.actions))),sa(t.map(e=>e.targetGroupName))}validate(e){const t={},a=e.targetGroups.map(e=>e.name),n=this.getAllTargetGroupsFromListeners(e.listeners),r=la(a,n);1===r.length?t.listeners=`Target group ${r[0]} is unused.`:r.length>1&&(t.listeners=`Target groups ${r.join(", ")} are unused.`);const{listeners:i}=e;return Zt(i,"port").length<i.length&&(t.listenerPorts="Multiple listeners cannot use the same port."),t}updateListeners(){this.props.formik.setFieldValue("listeners",this.props.formik.values.listeners)}componentDidMount(){this.loadCertificates()}addListenerCertificate(e){e.certificates=e.certificates||[],e.certificates.push({certificateArn:void 0,type:"iam",name:void 0})}loadCertificates(){Zr.listCertificates().then(e=>{this.setState({certificates:e})})}listenerProtocolChanged(e,t){e.protocol=t,"TCP"===e.protocol?e.port=80:"UDP"===e.protocol?e.port=53:"TLS"===e.protocol&&(e.port=443,e.certificates&&0!==e.certificates.length||this.addListenerCertificate(e),this.reenableAuthActions(e)),this.updateListeners()}reenableAuthActions(e){const t=this.removedAuthActions.has(e)?this.removedAuthActions.get(e):[],a=t[-1];a&&(t[-1]=void 0,e.defaultActions.unshift({...a})),e.rules.forEach((e,a)=>{const n=t[a];t[a]=void 0,n&&e.actions.unshift({...n})})}listenerPortChanged(e,t){e.port=Number.parseInt(t,10),this.updateListeners()}removeListener(e){this.props.formik.values.listeners.splice(e,1),this.updateListeners()}render(){const{errors:e,values:t}=this.props.formik,{certificates:a,certificateTypes:n}=this.state;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},t.listeners.map((e,r)=>Vt.createElement("div",{key:r,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Vt.createElement("div",{className:"wizard-pod-row-contents spread"},Vt.createElement("div",null,Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol"),Vt.createElement("select",{className:"form-control input-sm inline-number",style:{width:"80px"},value:e.protocol,onChange:t=>this.listenerProtocolChanged(e,t.target.value)},this.protocols.map(e=>Vt.createElement("option",{key:e},e)))),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port"),Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",min:0,value:e.port||"",onChange:t=>this.listenerPortChanged(e,t.target.value),style:{width:"80px"},required:!0}))),Vt.createElement("div",null,Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(r)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))))),Vt.createElement("div",null,"TLS"===e.protocol&&Vt.createElement(vi,{availableCertificates:e.certificates,formik:this.props.formik,app:this.props.app,certificateTypes:n,certificates:a})),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title",style:{height:"30px"}},"Rules"),Vt.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Vt.createElement("table",{className:"table table-condensed packed rules-table"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{style:{width:"10px",padding:"0"}}),Vt.createElement("th",{style:{width:"226px"}},"If"),Vt.createElement("th",{style:{width:"75px"}},"Then"),Vt.createElement("th",null,"Target"),Vt.createElement("th",{style:{width:"30px"}}))),Vt.createElement("tbody",null,Vt.createElement("tr",{className:"not-sortable"},Vt.createElement("td",null),Vt.createElement("td",null,"Default"),Vt.createElement("td",null,"forward to"),Vt.createElement("td",null,Vt.createElement("select",{className:"form-control input-sm",value:e.defaultActions[0].targetGroupName,onChange:t=>this.handleDefaultTargetChanged(e,t.target.value),required:!0},Vt.createElement("option",{value:""}),sa(t.targetGroups.map(e=>e.name)).map(e=>Vt.createElement("option",{key:e},e)))),Vt.createElement("td",null))))))))),e.listenerPorts&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listenerPorts})),e.listeners&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:e.listeners})),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Vt.createElement("span",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}class bi extends Vt.Component{constructor(e){super(e),this.protocols=["TCP","UDP"],this.healthProtocols=["TCP","HTTP","HTTPS"],this.targetTypes=["instance","ip"],this.destroy$=new Ta,this.addTargetGroup=()=>{const{setFieldValue:e,values:t}=this.props.formik,a=t.targetGroups.length;t.targetGroups.push({name:"targetgroup"+(a?`${a}`:""),protocol:"TCP",port:7001,targetType:"instance",healthCheckProtocol:"TCP",healthCheckPort:"traffic-port",healthCheckPath:"/healthcheck",healthCheckTimeout:5,healthCheckInterval:10,healthyThreshold:10,unhealthyThreshold:10,attributes:{deregistrationDelay:300,preserveClientIp:!0}}),e("targetGroups",t.targetGroups)};const t=e.isNew?0:e.formik.initialValues.targetGroups.length;this.state={existingTargetGroupNames:{},oldTargetGroupCount:t}}validate(e){const t=sa(Kt(ea(ra(e.targetGroups,"name"),e=>e.length>1)).map(e=>e.name)),a=new i(e),{arrayForEach:n}=a;return a.field("targetGroups").withValidators(n(a=>{a.field("name","Name").required().withValidators(ti(this.state.existingTargetGroupNames,e.credentials,e.region),ai(this.props.app.name.length),ge.valueUnique(t,"There is already a target group in this load balancer with the same name.")),a.field("port","Port").required().spelAware().withValidators(e=>he(e)),a.field("healthCheckInterval","Health Check Interval").required().spelAware().withValidators(e=>he(e)),a.field("healthyThreshold","Healthy Threshold").required().spelAware().withValidators(e=>he(e)),a.field("unhealthyThreshold","Unhealthy Threshold").required().spelAware().withValidators(e=>he(e)),a.field("healthCheckPort","Health Check Port").required().spelAware().withValidators(e=>"traffic-port"===e?null:he(e)),a.field("protocol","Protocol").required(),a.field("healthCheckProtocol","Health Check Protocol").required()})),a.validateForm()}removeAppName(e){return e.replace(`${this.props.app.name}-`,"")}updateLoadBalancerNames(e){const{app:t,loadBalancer:a}=e,n={};Ia(t.getDataSource("loadBalancers").refresh(!0)).pipe($a(this.destroy$)).subscribe(()=>{t.getDataSource("loadBalancers").data.forEach(e=>{"classic"!==e.loadBalancerType&&(a&&e.name===a.name||e.targetGroups.forEach(t=>{n[e.account]=n[e.account]||{},n[e.account][e.region]=n[e.account][e.region]||[],n[e.account][e.region].push(this.removeAppName(t.name))}))}),this.setState({existingTargetGroupNames:n},()=>this.props.formik.validateForm())})}targetGroupFieldChanged(e,t,a){const{setFieldValue:n,values:r}=this.props.formik,i=r.targetGroups[e];da(i,t,a),"healthyThreshold"===t&&da(i,"unhealthyThreshold",a),n("targetGroups",r.targetGroups)}removeTargetGroup(e){const{setFieldValue:t,values:a}=this.props.formik,{oldTargetGroupCount:n}=this.state;a.targetGroups.splice(e,1),e<n&&this.setState({oldTargetGroupCount:n-1}),t("targetGroups",a.targetGroups)}componentDidMount(){this.updateLoadBalancerNames(this.props)}componentWillUnmount(){this.destroy$.next(),this.destroy$.complete()}render(){const{app:e}=this.props,{errors:t,values:a}=this.props.formik,{oldTargetGroupCount:r}=this.state,i=this.protocols.map(e=>Vt.createElement("option",{key:e},e)),s=this.healthProtocols.map(e=>Vt.createElement("option",{key:e},e)),l=this.targetTypes.map(e=>Vt.createElement("option",{key:e},e));return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},a.targetGroups.map((a,o)=>{const c=t.targetGroups&&t.targetGroups[o]||{};return Vt.createElement("div",{key:o,className:"wizard-pod"},Vt.createElement("div",null,Vt.createElement("div",{className:"wizard-pod-row header"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"group-name-prefix"},e.name,"-"),Vt.createElement("input",{className:"form-control input-sm target-group-name",type:"text",value:a.name,onChange:e=>this.targetGroupFieldChanged(o,"name",e.target.value),required:!0,disabled:o<r}),Vt.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(o)},Vt.createElement("span",{className:"glyphicon glyphicon-trash"}))),c.name&&Vt.createElement("div",{className:"wizard-pod-row-errors"},Vt.createElement(pe,{type:"error",message:c.name})))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},Vt.createElement(n,{id:"aws.targetGroup.targetType"})," ",Vt.createElement("span",null,"Target Type ")),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("select",{className:"form-control input-sm",value:a.targetType,onChange:e=>this.targetGroupFieldChanged(o,"targetType",e.target.value),disabled:o<r},l))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),Vt.createElement(n,{id:"aws.targetGroup.protocol"})," ",Vt.createElement("select",{className:"form-control input-sm inline-number",value:a.protocol,onChange:e=>this.targetGroupFieldChanged(o,"protocol",e.target.value),disabled:o<r},i)),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(n,{id:"aws.targetGroup.port"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",value:a.port,onChange:e=>this.targetGroupFieldChanged(o,"port",e.target.value),type:"text",required:!0,disabled:o<r}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Protocol "),Vt.createElement("select",{disabled:o<r,className:"form-control input-sm inline-number",value:a.healthCheckProtocol,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckProtocol",e.target.value)},s)),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Port "),Vt.createElement(fe,{className:"form-control input-sm inline-number",error:c.healthCheckPort,name:"healthCheckPort",required:!0,value:a.healthCheckPort,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckPort",e.target.value)})),"TCP"!==a.healthCheckProtocol&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Path "),Vt.createElement(fe,{className:"form-control input-sm inline-text",error:c.healthCheckPath,name:"healthCheckPath",required:!0,value:a.healthCheckPath,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckPath",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Timeout "),Vt.createElement(ve,{error:c.healthCheckTimeout,required:!0,value:a.healthCheckTimeout,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckTimeout",e)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Interval "),Vt.createElement(ve,{error:c.healthCheckInterval,required:!0,value:a.healthCheckInterval,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckInterval",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},Vt.createElement(n,{id:"aws.targetGroup.nlbHealthcheckThreshold"})," ",Vt.createElement("span",null,"Healthcheck Threshold ")),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement(ve,{error:c.healthyThreshold,value:a.healthyThreshold,onChange:e=>this.targetGroupFieldChanged(o,"healthyThreshold",e)}))))),Vt.createElement("div",{className:"wizard-pod-row"},Vt.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),Vt.createElement("div",{className:"wizard-pod-row-contents"},Vt.createElement("div",{className:"wizard-pod-row-data"},Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement("label",null,"Dereg. Delay"),Vt.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Vt.createElement("input",{className:"form-control input-sm inline-number",type:"text",value:a.attributes.deregistrationDelay,onChange:e=>this.targetGroupFieldChanged(o,"attributes.deregistrationDelay",e.target.value)})),Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement(d,{name:"deregistrationDelayConnectionTermination",text:"Connection Termination",checked:a.attributes.deregistrationDelayConnectionTermination,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.deregistrationDelayConnectionTermination",e.target.checked)}}),Vt.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelayConnectionTermination"})),"instance"!==a.targetType&&Vt.createElement("span",{className:"wizard-pod-content"},Vt.createElement(d,{name:"preserveClientIp",text:"Preserve Client IP",checked:a.attributes.preserveClientIp,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.preserveClientIp",e.target.checked)}}),Vt.createElement(n,{id:"aws.targetGroup.attributes.preserveClientIp"})))))))}),Vt.createElement("table",{className:"table table-condensed packed"},Vt.createElement("tbody",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}}const Ei=class e extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ia(kn,"loadBalancers.certificateTypes",["iam","acm"]),this.submit=e=>{const{app:t,forPipelineConfig:a,closeModal:n}=this.props,{isNew:r}=this.state,i=r?"Create":"Update",s=_t(e);if(s.ipAddressType=s.dualstack?"dualstack":"ipv4",delete s.dualstack,a)this.formatListeners(s).then(()=>{n&&n(s)});else{const e=new v({application:t,title:(r?"Creating":"Updating")+" your load balancer",modalInstance:v.modalInstanceEmulation(()=>this.props.dismissModal()),onTaskComplete:()=>this.onTaskComplete(s)});e.submit(()=>this.formatListeners(s).then(()=>(this.formatCommand(s),Te.upsertLoadBalancer(s,t,i)))),this.setState({taskMonitor:e})}},this.validate=()=>({});const t=e.loadBalancer?Mr.convertNetworkLoadBalancerForEditing(e.loadBalancer):Mr.constructNewNetworkLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(t){return b.show(e,t,{dialogClassName:"wizard-modal modal-lg"})}certificateIdAsARN(e,t,a,n){if(t&&(0!==t.indexOf("arn:aws:iam::")||0!==t.indexOf("arn:aws:acm:"))){if("iam"===n)return`arn:aws:iam::${e}:server-certificate/${t}`;if("acm"===n)return`arn:aws:acm:${a}:${e}:certificate/${t}`}return t}formatListeners(e){return o.getAccountDetails(e.credentials).then(t=>{e.listeners.forEach(a=>{"TCP"===a.protocol&&(delete a.sslPolicy,a.certificates=[]),a.certificates.forEach(a=>{a.certificateArn=this.certificateIdAsARN(t.accountId,a.name,e.region,a.type||this.certificateTypes[0])})})})}setAvailabilityZones(e){const t={};t[e.region]=e.regionZones||[],e.availabilityZones=t}addAppName(e){return`${this.props.app.name}-${e}`}manageTargetGroupNames(e){(e.targetGroups||[]).forEach(e=>{e.name=this.addAppName(e.name)}),(e.listeners||[]).forEach(e=>{e.defaultActions.forEach(e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))}),(e.rules||[]).forEach(e=>{e.actions.forEach(e=>{e.targetGroupName&&(e.targetGroupName=this.addAppName(e.targetGroupName))})})})}manageRules(e){e.listeners.forEach(e=>{e.rules.forEach((e,t)=>{e.priority=t+1,e.conditions=e.conditions.filter(e=>e.values[0].length>0)})})}formatCommand(e){this.setAvailabilityZones(e),this.manageTargetGroupNames(e),this.manageRules(e)}onApplicationRefresh(e){if(this._isUnmounted)return;this.refreshUnsubscribe=void 0,this.props.dismissModal(),this.setState({taskMonitor:void 0});const t={name:e.name,accountId:e.credentials,region:e.region,vpcId:e.vpcId,provider:"aws"};h.$state.includes("**.loadBalancerDetails")?h.$state.go("^.loadBalancerDetails",t):h.$state.go(".loadBalancerDetails",t)}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}onTaskComplete(e){this.props.app.loadBalancers.refresh(),this.refreshUnsubscribe=this.props.app.loadBalancers.onNextRefresh(null,()=>this.onApplicationRefresh(e))}render(){const{app:e,dismissModal:t,forPipelineConfig:a,loadBalancer:n}=this.props,{isNew:r,loadBalancerCommand:i,taskMonitor:s}=this.state;let l=a?"Configure Network Load Balancer":"Create New Network Load Balancer";r||(l=`Edit ${i.name}: ${i.region}: ${i.credentials}`);const o=r||a;return Vt.createElement(E,{heading:l,initialValues:i,taskMonitor:s,dismissModal:t,closeModal:this.submit,submitButtonLabel:a?r?"Add":"Done":r?"Create":"Update",validate:this.validate,render:({formik:t,nextIdx:i,wizard:s})=>Vt.createElement(Vt.Fragment,null,o&&Vt.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Vt.createElement(li,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),Vt.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Vt.createElement(bi,{ref:a,formik:t,app:e,isNew:r,loadBalancer:n})}),Vt.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(yi,{ref:e,formik:t})}),Vt.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Vt.createElement(fi,{ref:e,showDualstack:!t.values.isInternal&&pa(t.values.targetGroups,{targetType:"instance"})})}))})}};Ei.defaultProps={closeModal:C,dismissModal:C};const wi=[{type:"application",label:"Application",sublabel:"ALB",description:"Highly configurable, application-focused balancer. HTTP and HTTPS only.",component:di},{type:"network",label:"Network",sublabel:"NLB",description:"Basic, high-performance balancer with fixed IP.",component:Ei},{type:"classic",label:"Classic",sublabel:"Legacy",description:"Previous generation balancer (ELB).",component:hi}],Ci=class e extends Vt.Component{constructor(e){super(e),this.choose=()=>{const{children:e,...t}=this.props;this.close(),this.state.selectedChoice.component.show(t).then(e=>{this.props.closeModal(e)}).catch(()=>{})},this.close=e=>{this.props.dismissModal(e)},this.state={choices:wi,selectedChoice:wi[0]}}static show(t){return b.show(e,{...t,className:"create-pipeline-modal-overflow-visible modal-lg"},{bsSize:"lg"})}choiceSelected(e){this.setState({selectedChoice:e})}getIncompatibility(e,t){const{loadBalancer:a={}}=V.getProvider(t),{incompatibleLoadBalancerTypes:n=[]}=a;return n.find(t=>t.type===e.type)}isIncompatibleWithAllProviders(e){const{app:{attributes:t}}=this.props,{cloudProviders:a=[]}=t;return a.length>0&&a.every(t=>!!this.getIncompatibility(e,t))}render(){const{app:{attributes:e}}=this.props,{cloudProviders:t=[]}=e,{choices:a,selectedChoice:n}=this.state,r=a.filter(e=>!this.isIncompatibleWithAllProviders(e)),i=t.map(e=>this.getIncompatibility(n,e)).filter(e=>e),s=kn.createLoadBalancerWarnings&&kn.createLoadBalancerWarnings[n.type];return Vt.createElement(Vt.Fragment,null,Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Select Type of Load Balancer")),Vt.createElement(Ha.Body,null,Vt.createElement("div",{className:"modal-body"},Vt.createElement("div",{className:"card-choices"},r.map(e=>Vt.createElement("div",{key:e.type,className:"card "+(n===e?"active":""),onClick:()=>this.choiceSelected(e)},Vt.createElement("h3",{className:"load-balancer-label"},e.label),Vt.createElement("h3",null,"(",e.sublabel,")"),Vt.createElement("div",null,e.description)))),Vt.createElement(Vt.Fragment,null,i.length>0&&i.map(e=>Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"})," ",e.reason)))),!!s&&Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),Vt.createElement(Ce,{message:s,style:{display:"inline-block",marginLeft:"2px"}}))),Vt.createElement("div",{className:"load-balancer-description"}))),Vt.createElement(Ha.Footer,null,Vt.createElement(Wa,{onClick:this.choose},"Configure Load Balancer ",Vt.createElement("span",{className:"glyphicon glyphicon-chevron-right"}))))}};Ci.defaultProps={closeModal:C,dismissModal:C};let Si=Ci;class ki extends Vt.Component{constructor(e){super(e),this.editLoadBalancer=()=>{const{loadBalancer:e}=this.props,{application:t}=this.state;wi.find(t=>t.type===e.loadBalancerType).component.show({app:t,loadBalancer:e})},this.deleteLoadBalancer=()=>{const{app:e,loadBalancer:t,loadBalancerFromParams:a}=this.props;if(t.instances&&t.instances.length)return;const n={application:e,title:"Deleting "+a.name},r={cloudProvider:t.cloudProvider,loadBalancerName:t.name,loadBalancerType:t.loadBalancerType||"classic",regions:[t.region],credentials:t.account,vpcId:ia(t,"elb.vpcId",null)};S.confirm({header:`Really delete ${a.name} in ${a.region}: ${a.accountId}?`,buttonText:`Delete ${a.name}`,account:a.accountId,taskMonitorConfig:n,submitMethod:()=>Te.deleteLoadBalancer(r,e)})},this.entityTagUpdate=()=>{this.props.app.loadBalancers.refresh()};const{app:t,loadBalancer:a}=this.props;let n;const r=a.name.split("-")[0];r===t.name?n=t:k.getApplication(r).then(e=>{this.setState({application:e})}).catch(()=>{}),this.state={application:n}}render(){const{app:e,loadBalancer:t}=this.props,{application:r}=this.state,{loadBalancerType:i,instances:s,instanceCounts:l}=t,o=t.name.split("-")[0],c=!("classic"===i&&ma(l).filter(e=>e).length)&&!s.length;return Vt.createElement("div",{style:{display:"inline-block"}},kn.adHocInfraWritesEnabled&&Vt.createElement(qa,{className:"dropdown",id:"load-balancer-actions-dropdown"},Vt.createElement(qa.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Vt.createElement("span",null,"Load Balancer Actions")),Vt.createElement(qa.Menu,{className:"dropdown-menu"},r&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.editLoadBalancer},"Edit Load Balancer"),!r&&Vt.createElement("li",{className:"disabled"},Vt.createElement("a",null,"Edit Load Balancer"," ",Vt.createElement(n,{content:`The application <b>${o}</b> must be configured before this load balancer can be edited.`}))),c&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.deleteLoadBalancer},"Delete Load Balancer"),!c&&Vt.createElement("li",{className:"disabled"},Vt.createElement("a",null,"Delete Load Balancer"," ",Vt.createElement(n,{content:"You must detach all instances before you can delete this load balancer."}))),a&&a.feature.entityTags&&Vt.createElement(N,{component:t,application:e,entityType:"loadBalancer",onUpdate:this.entityTagUpdate}))))}}const Ni="spinnaker.amazon.loadBalancer.details.loadBalancerActions.component";t(Ni,[]).component("loadBalancerActions",Ja(L(ki,"loadBalancerActions"),["app","loadBalancer","loadBalancerFromParams"]));class Ti{constructor(e,t,n,r,i,s,l){this.$scope=e,this.$state=t,this.$q=n,this.app=i,this.securityGroupReader=s,this.loadBalancerReader=l,this.state={loading:!0},this.firewallsLabel=U.get("Firewalls"),this.oidcConfigPath=a.oidcConfigPath,this.application=i,this.loadBalancerFromParams=r,this.app.ready().then(()=>this.extractLoadBalancer()).then(()=>{e.$$destroyed||i.getDataSource("loadBalancers").onRefresh(e,()=>this.extractLoadBalancer())})}autoClose(){this.$scope.$$destroyed||(this.$state.params.allowModalToStayOpen=!0,this.$state.go("^",null,{location:"replace"}))}extractLoadBalancer(){const e=this.app.loadBalancers.data.find(e=>e.name===this.loadBalancerFromParams.name&&e.region===this.loadBalancerFromParams.region&&e.account===this.loadBalancerFromParams.accountId);if(e){return this.loadBalancerReader.getLoadBalancerDetails("aws",this.loadBalancerFromParams.accountId,this.loadBalancerFromParams.region,this.loadBalancerFromParams.name).then(t=>{this.loadBalancer=e,this.state.loading=!1;const a=[];if(t.length){this.loadBalancer.elb=t[0],this.loadBalancer.elb.vpcId=this.loadBalancer.elb.vpcId||this.loadBalancer.elb.vpcid,this.loadBalancer.account=this.loadBalancerFromParams.accountId;const e=t[0];if("application"===e.loadBalancerType||"network"===e.loadBalancerType){const e=t[0];e.listeners&&e.listeners.length&&(this.elbProtocol="http:",e.listeners.some(e=>"HTTPS"===e.protocol)&&(this.elbProtocol="https:"),this.listeners=[],e.listeners.forEach(e=>{e.defaultActions.sort((e,t)=>e.order-t.order),e.rules.forEach(e=>e.actions.sort((e,t)=>e.order-t.order))}),e.listeners.forEach(e=>{e.rules.map(t=>{let a=[e.protocol,(t.conditions.find(e=>"host-header"===e.field)||{values:[""]}).values[0],e.port].filter(e=>e).join(":");const n=(t.conditions.find(e=>"path-pattern"===e.field)||{values:[]}).values[0];n&&(a=`${a}${n}`);const r=t.actions.map(e=>{const t={...e};return"forward"===t.type&&(t.targetGroup=this.loadBalancer.targetGroups.find(e=>e.name===t.targetGroupName)),t});this.listeners.push({in:a,actions:r})})})),"dualstack"===e.ipAddressType&&(this.ipAddressTypeDescription="IPv4 and IPv6"),"ipv4"===e.ipAddressType&&(this.ipAddressTypeDescription="IPv4")}else{const e=t[0];e.listenerDescriptions&&(this.elbProtocol="http:",e.listenerDescriptions.some(e=>"HTTPS"===e.listener.protocol)&&(this.elbProtocol="https:"))}(this.loadBalancer.elb.securityGroups||[]).forEach(e=>{const t=this.securityGroupReader.getApplicationSecurityGroup(this.app,this.loadBalancerFromParams.accountId,this.loadBalancerFromParams.region,e);t&&a.push(t)}),this.securityGroups=Qt(a,"name"),this.loadBalancer.subnets&&(this.loadBalancer.subnetDetails=this.loadBalancer.subnets.reduce((e,t)=>(g.getSubnetByIdAndProvider(t,this.loadBalancer.provider).then(t=>{e.push(t)}),e),[]))}},()=>this.autoClose())}return this.autoClose(),this.loadBalancer||this.autoClose(),this.$q.when(null)}getFirstSubnetPurpose(e=[]){return ga(e.map(e=>e.purpose))||""}}Ti.$inject=["$scope","$state","$q","loadBalancer","app","securityGroupReader","loadBalancerReader"];const Ii="spinnaker.amazon.loadBalancer.details.controller";t(Ii,[an,Ge,Ni,Ae,xe]).controller("awsLoadBalancerDetailsCtrl",Ti);class Gi{constructor(e,t,a,n,r){this.$scope=e,this.$q=t,this.$state=a,this.app=r,this.state={loading:!0},this.application=r,this.targetGroupFromParams=n,this.app.ready().then(()=>this.extractTargetGroup()).then(()=>{e.$$destroyed||r.getDataSource("loadBalancers").onRefresh(e,()=>this.extractTargetGroup())})}autoClose(){this.$scope.$$destroyed||(this.$state.params.allowModalToStayOpen=!0,this.$state.go("^",null,{location:"replace"}))}extractTargetGroup(){const{loadBalancerName:e,region:t,accountId:a,name:n}=this.targetGroupFromParams,r=this.app.loadBalancers.data.find(n=>n.name===e&&n.region===t&&n.account===a);if(!r)return this.autoClose(),this.$q.when(null);const i=r.targetGroups.find(e=>e.name===n);return i?(this.targetGroup=i,this.loadBalancer=r,this.state.loading=!1,this.elbProtocol="http:",this.loadBalancer.listeners&&this.loadBalancer.listeners.some(e=>"HTTPS"===e.protocol)&&(this.elbProtocol="https:"),this.$q.when(null)):(this.autoClose(),this.$q.when(null))}}Gi.$inject=["$scope","$q","$state","targetGroup","app"];const Ai="spinnaker.amazon.loadBalancer.details.targetGroupDetails.controller";t(Ai,[an,xe]).controller("awsTargetGroupDetailsCtrl",Gi);const xi="spinnaker.amazon.loadBalancer.targetGroup.states";t(xi,[Pe]).config(["applicationStateProvider",e=>{const t={name:"targetGroupDetails",url:"/targetGroupDetails/:provider/:accountId/:region/:vpcId/:loadBalancerName/:name",params:{vpcId:{value:null,squash:!0}},views:{"detail@../insight":{component:Lr,$type:"react"}},resolve:{accountId:["$stateParams",e=>e.accountId],targetGroup:["$stateParams",e=>({loadBalancerName:e.loadBalancerName,name:e.name,accountId:e.accountId,region:e.region,vpcId:e.vpcId})]},data:{pageTitleDetails:{title:"Target Group Details",nameParam:"name",accountParam:"accountId",regionParam:"region"}}};e.addInsightDetailState(t)}]);const Pi="spinnaker.amazon.loadBalancer";t(Pi,[Ii,Ai,Ni,xi]);const Di="spinnaker.amazon.pipeline.stage.bake.executionDetails.controller";t(Di,[an]).controller("awsBakeExecutionDetailsCtrl",["$scope","$stateParams","executionDetailsSectionService","$interpolate",function(e,t,n,r){e.configSections=["bakeConfig","taskStatus"];const i=()=>{e.detailsSection=t.details,e.provider=e.stage.context.cloudProviderType||"aws",e.roscoMode=a.feature.roscoMode||"function"==typeof a.feature.roscoSelector&&a.feature.roscoSelector(e.stage.context),e.bakeryDetailUrl=r(e.roscoMode&&a.roscoDetailUrl?a.roscoDetailUrl:a.bakeryDetailUrl),e.bakeFailedNoError="FAILURE"===ia(e.stage,"context.status.result")&&!e.stage.failureMessage},s=()=>n.synchronizeSection(e.configSections,i);s(),e.$on("$stateChangeSuccess",s)}]);const Bi="spinnaker.amazon.pipeline.stage.bakeStage";t(Bi,[Di]).config(function(){De.pipeline.registerStage({provides:"bake",cloudProvider:"aws",label:"Bake",description:"Bakes an image",templateUrl:"amazon/src/pipeline/stages/bake/bakeStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/bake/bakeExecutionDetails.html",executionLabelComponent:Be,extraLabelLines:e=>e.masterStage.context.allPreviouslyBaked||e.masterStage.context.somePreviouslyBaked?1:0,supportsCustomTimeout:!0,validators:[{type:"requiredField",fieldName:"package"},{type:"requiredField",fieldName:"regions"},{type:"upstreamVersionProvided",checkParentTriggers:!0,getMessage:e=>"Bake stages should always have a stage or trigger preceding them that provides version information: <ul>"+e.map(e=>`<li>${e}</li>`).join("")+"</ul>Otherwise, Spinnaker will bake and deploy the most-recently built package."}],restartable:!0})}).controller("awsBakeStageCtrl",["$scope","$q","$uibModal",function(e,t,n){function r(){if(e.baseOsOptions.length&&e.baseOsOptions.every(({vmTypes:e})=>e)){const t=e.baseOsOptions.length&&new Set(e.baseOsOptions.reduce((e,{vmTypes:t})=>e.concat(t),[])),a=e.baseOsOptions.find(({id:t})=>t===e.stage.baseOs);e.viewState.showVmTypeSelector=t.size>1,e.vmTypes=a.vmTypes}else e.viewState.showVmTypeSelector=!0,e.vmTypes=["hvm","pv"]}e.stage.extendedAttributes=e.stage.extendedAttributes||{},e.stage.regions=e.stage.regions&&e.stage.regions.sort()||[],e.stage.user||(e.stage.user=ze.getAuthenticatedUser().name),e.viewState={loading:!0,roscoMode:a.feature.roscoMode||"function"==typeof a.feature.roscoSelector&&a.feature.roscoSelector(e.stage),minRootVolumeSize:kn.minRootVolumeSize,showVmTypeSelector:!0,bakeWarning:kn.bakeWarning,dockerBakeWarning:kn.dockerBakeWarning,showDockerPreview:kn.dockerBakeryDeprecated&&"docker"===e.stage.storeType,showMigrationFields:"Started"!==e.pipeline.migrationStatus,showStoreType:!kn.dockerBakeryDeprecated},this.addExtendedAttribute=function(){e.stage.extendedAttributes||(e.stage.extendedAttributes={}),n.open({templateUrl:Fe.addExtendedAttributes,controller:"bakeStageAddExtendedAttributeController",controllerAs:"addExtendedAttribute",resolve:{extendedAttribute:function(){return{key:"",value:""}}}}).result.then(function(t){e.stage.extendedAttributes[t.key]=t.value}).catch(()=>{})},this.removeExtendedAttribute=function(t){delete e.stage.extendedAttributes[t]},this.showTemplateFileName=function(){return e.viewState.roscoMode||e.stage.templateFileName},this.showExtendedAttributes=function(){return e.viewState.roscoMode||e.stage.extendedAttributes&&Ht.size(e.stage.extendedAttributes)>0},this.showVarFileName=function(){return e.viewState.roscoMode||e.stage.varFileName},this.handleBaseOsChange=function(){r(),e.vmTypes&&e.vmTypes.length&&!e.vmTypes.includes(e.stage.vmType)&&(e.stage.vmType=e.vmTypes[0])},e.$watch("stage",function(){Ht.forOwn(e.stage,function(t,a){""===t&&delete e.stage[a]}),"ebs"===e.stage.storeType&&"aws"!==e.stage.cloudProviderType&&(e.stage.cloudProviderType="aws"),"function"==typeof a.feature.roscoSelector&&(e.viewState.roscoMode=a.feature.roscoSelector(e.stage))},!0),t.all([Me.getRegions("aws"),Me.getBaseOsOptions("aws"),Me.getBaseLabelOptions(),["ebs","docker"]]).then(function([t,a,n,i]){e.regions=[...t].sort(),e.storeTypes=i,!e.stage.storeType&&e.storeTypes&&e.storeTypes.length&&(e.stage.storeType=e.storeTypes[0]),1===e.regions.length?e.stage.region=e.regions[0]:e.regions.includes(e.stage.region)||delete e.stage.region,!e.stage.regions.length&&e.application.defaultRegions.aws&&e.stage.regions.push(...Object.keys(e.application.defaultRegions.aws).sort()),e.baseOsOptions=a.baseImages,e.baseLabelOptions=n,!e.stage.baseOs&&e.baseOsOptions&&e.baseOsOptions.length?e.stage.baseOs=e.baseOsOptions[0].id:e.stage.baseOs&&!(e.baseOsOptions||[]).find(t=>t.id===e.stage.baseOs)&&e.baseOsOptions.push({id:e.stage.baseOs,detailedDescription:"Custom",vmTypes:["hvm","pv"]}),!e.stage.baseLabel&&e.baseLabelOptions&&e.baseLabelOptions.length&&(e.stage.baseLabel=e.baseLabelOptions[0]),r(),!e.stage.vmType&&e.vmTypes&&e.vmTypes.length&&(e.stage.vmType=e.vmTypes[0]),e.showAdvancedOptions=function(){const t=e.stage;return!!(t.templateFileName||t.extendedAttributes&&Ht.size(t.extendedAttributes)>0||t.varFileName||t.baseName||t.baseAmi||t.amiName||t.amiSuffix||t.rootVolumeSize)}(),e.viewState.loading=!1})}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/bake/bakeStage.html",'<div ng-controller="awsBakeStageCtrl as bakeStageCtrl">\n <div ng-if="viewState.loading" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div ng-if="!viewState.loading && viewState.showDockerPreview">\n <div ng-if="viewState.dockerBakeWarning" class="alert alert-warning sp-margin-s-top horizontal middle">\n <i class="fa fa-exclamation-triangle"></i>\n <div class="sp-margin-s-left">\n <markdown message="viewState.dockerBakeWarning"></markdown>\n </div>\n </div>\n <div>\n <div class="alert alert-info horizontal middle">\n <i class="fa fa-info-circle"></i>\n <div class="sp-margin-s-left">\n <markdown\n message="\'To edit bake configuration or view advanced options, migrate to EBS store type.\'"\n ></markdown>\n </div>\n </div>\n <stage-config-field label="Store Type" ng-if="!viewState.roscoMode && viewState.showMigrationFields">\n <label class="radio-inline" ng-repeat="storeType in storeTypes">\n <input type="radio" ng-model="stage.storeType" ng-value="storeType" />\n {{storeType | uppercase}}\n </label>\n </stage-config-field>\n <stage-config-field label="Regions">\n <span class="sp-margin-xs-right" ng-repeat="region in stage.regions">{{region}}</span>\n </stage-config-field>\n <stage-config-field label="Skip Region Detection">{{!!stage.skipRegionDetection}}</stage-config-field>\n <stage-config-field label="Repo Path">{{stage.package}}</stage-config-field>\n <stage-config-field label="Base OS">{{stage.baseOs}}</stage-config-field>\n <stage-config-field label="VM Type">{{stage.vmType}}</stage-config-field>\n <stage-config-field label="Store Type">{{stage.storeType}}</stage-config-field>\n <stage-config-field label="Base Label">{{stage.baseLabel}}</stage-config-field>\n </div>\n </div>\n <div ng-if="!viewState.loading && !viewState.showDockerPreview">\n <div\n ng-if="pipeline.migrationStatus === \'Started\' && viewState.bakeWarning"\n class="alert alert-warning sp-margin-s-top horizontal middle"\n >\n <i class="fa fa-exclamation-triangle"></i>\n <div class="sp-margin-s-left">\n <markdown message="viewState.bakeWarning"></markdown>\n </div>\n </div>\n <stage-config-field label="Regions">\n <checklist items="regions" model="stage.regions" inline="true" include-select-all-button="true"></checklist>\n </stage-config-field>\n <stage-config-field label="Skip Region Detection" help-key="pipeline.config.bake.skipRegionDetection">\n <div class="checkbox" style="margin-bottom: 0">\n <label>\n <input type="checkbox" ng-model="stage.skipRegionDetection" />\n Only bake explicitly selected regions\n </label>\n </div>\n </stage-config-field>\n <stage-config-field\n label="{{stage.storeType === \'docker\' ? \'Repo Path\' : \'Package\'}}"\n help-key="pipeline.config.bake.package"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.package" />\n </stage-config-field>\n <stage-config-field label="Base OS">\n <bake-stage-choose-os\n model="stage.baseOs"\n base-os-options="baseOsOptions"\n on-change="bakeStageCtrl.handleBaseOsChange()"\n ></bake-stage-choose-os>\n </stage-config-field>\n <stage-config-field label="VM Type" ng-if="viewState.showVmTypeSelector && viewState.showMigrationFields">\n <label class="radio-inline" ng-repeat="vmType in vmTypes">\n <input type="radio" ng-model="stage.vmType" ng-value="vmType" />\n {{vmType | uppercase}}\n </label>\n </stage-config-field>\n <stage-config-field\n label="Store Type"\n ng-if="!viewState.roscoMode && viewState.showMigrationFields && viewState.showStoreType"\n >\n <label class="radio-inline" ng-repeat="storeType in storeTypes">\n <input type="radio" ng-model="stage.storeType" ng-value="storeType" />\n {{storeType | uppercase}}\n </label>\n </stage-config-field>\n <stage-config-field label="Base Label">\n <label class="radio-inline" ng-repeat="baseLabel in baseLabelOptions">\n <input type="radio" ng-model="stage.baseLabel" ng-value="baseLabel" />\n {{baseLabel}}\n </label>\n </stage-config-field>\n \x3c!-- Even if the roscoMode flag is false, we should show the control if rebake is set. --\x3e\n <stage-config-field label="Rebake" ng-if="viewState.roscoMode || stage.rebake">\n <div class="checkbox" style="margin-bottom: 0">\n <label>\n <input type="checkbox" ng-model="stage.rebake" />\n Rebake image without regard to the status of any existing bake\n </label>\n </div>\n </stage-config-field>\n <div class="form-group">\n <div class="col-md-9 col-md-offset-1">\n <div class="checkbox">\n <label>\n <input type="checkbox" ng-model="showAdvancedOptions" />\n <strong>Show Advanced Options</strong>\n </label>\n </div>\n </div>\n </div>\n <div ng-class="{collapse: showAdvancedOptions !== true, \'collapse.in\': !showAdvancedOptions === true}">\n <stage-config-field\n label="Template File Name"\n help-key="pipeline.config.bake.templateFileName"\n ng-if="bakeStageCtrl.showTemplateFileName() && viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.templateFileName" />\n </stage-config-field>\n <stage-config-field\n label="Extended Attributes"\n help-key="pipeline.config.bake.extendedAttributes"\n ng-if="bakeStageCtrl.showExtendedAttributes()"\n >\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 40%">Key</th>\n <th style="width: 60%">Value</th>\n <th class="text-right">Actions</th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="(key,value) in stage.extendedAttributes">\n <td>\n <strong class="small">{{key}}</strong>\n </td>\n <td>\n <input\n type="text"\n ng-model="stage.extendedAttributes[key]"\n value="{{value}}"\n class="form-control input-sm"\n />\n </td>\n <td class="text-right">\n <a class="small" href ng-click="bakeStageCtrl.removeExtendedAttribute(key)">Remove</a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="7">\n <button class="btn btn-block btn-sm add-new" ng-click="bakeStageCtrl.addExtendedAttribute()">\n <span class="glyphicon glyphicon-plus-sign"></span> Add Extended Attribute\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </stage-config-field>\n <stage-config-field\n label="Var File Name"\n help-key="pipeline.config.bake.varFileName"\n ng-if="bakeStageCtrl.showVarFileName() && viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.varFileName" />\n </stage-config-field>\n <stage-config-field label="Root Volume Size" ng-if="viewState.minRootVolumeSize && viewState.showMigrationFields">\n <input\n type="number"\n class="form-control input-sm"\n style="width: 80px; display: inline-block"\n ng-min="viewState.minRootVolumeSize"\n ng-model="stage.rootVolumeSize"\n />\n GB <span class="small">(minimum: {{viewState.minRootVolumeSize}})</span>\n </stage-config-field>\n <stage-config-field label="Base Name" ng-if="stage.storeType !== \'docker\' && viewState.showMigrationFields">\n <input type="text" class="form-control input-sm" ng-model="stage.baseName" />\n </stage-config-field>\n <stage-config-field\n label="Base AMI"\n help-key="pipeline.config.bake.baseAmi"\n ng-if="stage.storeType !== \'docker\' && viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.baseAmi" />\n </stage-config-field>\n <stage-config-field\n label="{{stage.storeType === \'docker\' ? \'Docker Image Name\' : \'AMI Name\'}}"\n help-key="pipeline.config.bake.amiName"\n ng-if="viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.amiName" />\n </stage-config-field>\n <stage-config-field\n label="{{stage.storeType === \'docker\' ? \'Docker Image Prefix\' : \'AMI Suffix\'}}"\n help-key="pipeline.config.bake.amiSuffix"\n ng-if="viewState.showMigrationFields"\n >\n <input type="text" class="form-control input-sm" ng-model="stage.amiSuffix" />\n </stage-config-field>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/bake/bakeExecutionDetails.html",'<div ng-controller="awsBakeExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'bakeConfig\'">\n <div class="row">\n <div class="col-md-6">\n <dl class="dl-narrow dl-horizontal">\n <dt if-multiple-providers>Provider</dt>\n <dd if-multiple-providers>Amazon</dd>\n <dt>Image</dt>\n <dd>{{stage.context.ami}}</dd>\n <dt>Region</dt>\n <dd>{{stage.context.region}}</dd>\n <dt>Package</dt>\n <dd>{{stage.context.package}}</dd>\n </dl>\n </div>\n <div class="col-md-6">\n <dl class="dl-narrow dl-horizontal">\n <dt>Base OS</dt>\n <dd>{{stage.context.baseOs}}</dd>\n <dt>VM Type</dt>\n <dd>{{stage.context.vmType | uppercase}}</dd>\n <dt ng-if="!roscoMode">Store Type</dt>\n <dd ng-if="!roscoMode">{{stage.context.storeType | uppercase}}</dd>\n <dt ng-if="!roscoMode">Label</dt>\n <dd ng-if="!roscoMode">{{stage.context.baseLabel}}</dd>\n <dt ng-if="roscoMode || execution.trigger.rebake || stage.context.rebake">Rebake</dt>\n <dd ng-if="roscoMode || execution.trigger.rebake || stage.context.rebake">\n {{execution.trigger.rebake || stage.context.rebake || false}}\n </dd>\n <dt ng-if="stage.context.templateFileName">Template</dt>\n <dd ng-if="stage.context.templateFileName">{{stage.context.templateFileName}}</dd>\n <dt ng-if="stage.context.varFileName">Var File</dt>\n <dd ng-if="stage.context.varFileName">{{stage.context.varFileName}}</dd>\n </dl>\n </div>\n </div>\n <stage-failure-message\n stage="stage"\n message="stage.failureMessage"\n ng-if="stage.failureMessage"\n ></stage-failure-message>\n\n <div class="row" ng-if="stage.context.region && stage.context.status.resourceId">\n <div class="col-md-12">\n <div class="alert alert-{{stage.isFailed ? \'danger\' : \'info\'}}">\n <div ng-if="stage.context.previouslyBaked">No changes detected; reused existing bake</div>\n <div ng-if="stage.context.imageName">\n <strong>Image:</strong>\n <div select-on-dbl-click>{{stage.context.imageName}}</div>\n <div>({{stage.context.ami}})</div>\n </div>\n <span ng-if="bakeFailedNoError">Bake failed. </span>\n <a target="_blank" href="{{ bakeryDetailUrl(stage) }}">View Bakery Details</a>\n <span ng-if="bakeFailedNoError"> for more info.</span>\n </div>\n </div>\n </div>\n </div>\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]);const zi="spinnaker.amazon.pipeline.stage.cloneServerGroupStage";t(zi,[]).config(function(){De.pipeline.registerStage({provides:"cloneServerGroup",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStepLabel.html",accountExtractor:e=>[e.context.credentials],validators:[{type:"requiredField",fieldName:"targetCluster",fieldLabel:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"region"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsCloneServerGroupStageCtrl",["$scope",function(e){const t=e.stage;e.viewState={accountsLoaded:!1},o.listAccounts("aws").then(t=>{e.accounts=t,e.viewState.accountsLoaded=!0}),this.cloneTargets=$e.TARGET_LIST,t.target=t.target||this.cloneTargets[0].val,t.application=e.application.name,t.cloudProvider="aws",t.cloudProviderType="aws",t.viewState={mode:"editPipeline"},t.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(t.interestingHealthProviderNames=["Amazon"]),!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),t.isNew&&(t.useAmiBlockDeviceMappings=Ht.get(e,"application.attributes.providerSettings.aws.useAmiBlockDeviceMappings",!1),t.copySourceCustomBlockDeviceMappings=!1),this.targetClusterUpdated=()=>{if(t.targetCluster){const a=Le.monikerClusterNameFilter(t.targetCluster),n=Ht.first(Le.getMonikers([e.application],a));if(n)t.stack=n.stack,t.freeFormDetails=n.detail;else{const e=re.parseClusterName(t.targetCluster);t.stack=e.stack,t.freeFormDetails=e.freeFormDetails}}else t.stack="",t.freeFormDetails=""},e.$watch("stage.targetCluster",this.targetClusterUpdated),this.removeCapacity=()=>{delete t.capacity},Ht.has(t,"useSourceCapacity")||(t.useSourceCapacity=!0),this.toggleSuspendedProcess=e=>{t.suspendedProcesses=t.suspendedProcesses||[];const a=t.suspendedProcesses.indexOf(e);-1===a?t.suspendedProcesses.push(e):t.suspendedProcesses.splice(a,1)},this.processIsSuspended=e=>t.suspendedProcesses&&t.suspendedProcesses.includes(e),this.getBlockDeviceMappingsSource=()=>t.copySourceCustomBlockDeviceMappings?"source":t.useAmiBlockDeviceMappings?"ami":"default",this.selectBlockDeviceMappingsSource=e=>{"source"===e?(t.copySourceCustomBlockDeviceMappings=!0,t.useAmiBlockDeviceMappings=!1):"ami"===e?(t.copySourceCustomBlockDeviceMappings=!1,t.useAmiBlockDeviceMappings=!0):(t.copySourceCustomBlockDeviceMappings=!1,t.useAmiBlockDeviceMappings=!1)},this.onRedBlackFieldChange=(e,a)=>{Ht.set(t,e,a)}}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStage.html",'<div ng-controller="awsCloneServerGroupStageCtrl as cloneServerGroupStageCtrl">\n <div ng-if="!pipeline.strategy">\n <div ng-if="viewState.loading" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div ng-if="!viewState.loading">\n <account-region-cluster-selector\n application="application"\n component="stage"\n accounts="accounts"\n single-region="true"\n cluster-field="targetCluster"\n >\n </account-region-cluster-selector>\n </div>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="cloneServerGroupStageCtrl.cloneTargets"></target-select>\n </stage-config-field>\n <div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Capacity</div>\n <div class="col-md-9 radio">\n <label>\n <input\n type="radio"\n ng-model="stage.useSourceCapacity"\n ng-value="true"\n ng-click="cloneServerGroupStageCtrl.removeCapacity()"\n id="useSourceCapacityTrue"\n />\n Copy the capacity from the current server group\n <help-field key="serverGroupCapacity.useSourceCapacityTrue"></help-field>\n </label>\n </div>\n <div class="col-md-9 col-md-offset-3 radio">\n <label>\n <input type="radio" ng-model="stage.useSourceCapacity" ng-value="false" id="useSourceCapacityFalse" />\n Let me specify the capacity\n <help-field key="serverGroupCapacity.useSourceCapacityFalse"></help-field>\n </label>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-2 col-md-offset-3">Min</div>\n <div class="col-md-2">Max</div>\n <div class="col-md-2">Desired</div>\n </div>\n <div class="form-group">\n <div class="col-md-2 col-md-offset-3">\n <input\n type="number"\n ng-disabled="stage.useSourceCapacity"\n class="form-control input-sm"\n ng-model="stage.capacity.min"\n min="0"\n max="{{stage.capacity.max}}"\n required\n />\n </div>\n <div class="col-md-2">\n <input\n type="number"\n ng-disabled="stage.useSourceCapacity"\n class="form-control input-sm"\n ng-model="stage.capacity.max"\n min="{{stage.capacity.min}}"\n required\n />\n </div>\n <div class="col-md-2">\n <input\n type="number"\n ng-disabled="stage.useSourceCapacity"\n class="form-control input-sm"\n ng-model="stage.capacity.desired"\n min="{{stage.capacity.min}}"\n max="{{stage.capacity.max}}"\n required\n />\n </div>\n </div>\n </div>\n <stage-config-field label="Traffic" help-key="aws.serverGroup.traffic">\n <div class="checkbox">\n <label>\n <input\n type="checkbox"\n ng-click="cloneServerGroupStageCtrl.toggleSuspendedProcess(\'AddToLoadBalancer\')"\n ng-checked="!cloneServerGroupStageCtrl.processIsSuspended(\'AddToLoadBalancer\')"\n />\n Send client requests to new instances\n </label>\n </div>\n </stage-config-field>\n <stage-config-field label="AMI Block Device Mappings">\n <div class="radio">\n <div>\n <label>\n <input\n type="radio"\n ng-click="cloneServerGroupStageCtrl.selectBlockDeviceMappingsSource(\'source\')"\n ng-checked="cloneServerGroupStageCtrl.getBlockDeviceMappingsSource() === \'source\'"\n name="blockDeviceMappingsSource"\n />\n Copy from current server group\n <help-field key="aws.blockDeviceMappings.useSource"></help-field>\n </label>\n </div>\n <div>\n <label>\n <input\n type="radio"\n ng-click="cloneServerGroupStageCtrl.selectBlockDeviceMappingsSource(\'ami\')"\n ng-checked="cloneServerGroupStageCtrl.getBlockDeviceMappingsSource() === \'ami\'"\n name="blockDeviceMappingsSource"\n />\n Prefer AMI block device mappings\n <help-field key="aws.blockDeviceMappings.useAMI"></help-field>\n </label>\n </div>\n <div>\n <label>\n <input\n type="radio"\n ng-click="cloneServerGroupStageCtrl.selectBlockDeviceMappingsSource(\'default\')"\n ng-checked="cloneServerGroupStageCtrl.getBlockDeviceMappingsSource() === \'default\'"\n name="blockDeviceMappingsSource"\n />\n Defaults for selected instance type\n <help-field key="aws.blockDeviceMappings.useDefaults"></help-field>\n </label>\n </div>\n </div>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n <deployment-strategy-selector\n field-columns="6"\n command="stage"\n on-field-change="cloneServerGroupStageCtrl.onRedBlackFieldChange"\n ></deployment-strategy-selector>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/cloneServerGroup/cloneServerGroupStepLabel.html",'<span class="task-label"> Clone Server Group: {{step.context.source.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const Fi=[{label:"Newest Function Version",value:"$LATEST",description:"Delete the most recently deployed function version when this stage starts."},{label:"Previous Function Version",value:"$PREVIOUS",description:"Delete the second-most recently deployed function version when this stage starts."},{label:"Older Than N",value:"$MOVING",description:"Delete all version but the N most recent versions."},{label:"Provide Version Number",value:"$PROVIDED",description:"Provide a specific version number to delete."},{label:"All Function Versions",value:"$ALL",description:"Delete all function versions and function infrastructure. This will completely delete the Lambda function."}];class Mi extends Vt.Component{constructor(e){super(e);const{value:t}=this.props,a=Fi.filter(e=>e.value===t)[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Vt.createElement("div",null,Vt.createElement("b",null," ",this.state.label," "),Vt.createElement("br",null),Vt.createElement("small",null," ",this.state.description," "))}}function $i(e){const{values:t}=e.formik,{functions:a}=e.application,{result:r,status:i}=F(()=>o.listAccounts("aws"),[],[]),l=t.account&&t.region?a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).map(e=>e.functionName):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement(s,{label:"Account",name:"account",onChange:(t,a)=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue(t,a)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map(e=>e.name)})}),Vt.createElement(s,{label:"Region",name:"region",onChange:(t,a)=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue(t,a)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===i,stringOptions:r.filter(e=>e.name===t.account).flatMap(e=>e.regions).map(e=>e.name)})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:l})}),Vt.createElement(s,{label:"Target Version",name:"version",input:t=>Vt.createElement(c,{...t,clearable:!1,options:Fi,optionRenderer:t=>Vt.createElement(Mi,{config:e,value:t.value,showingDetails:!0})})}),"$PROVIDED"===t.version?Vt.createElement(s,{label:"Version Number",name:"versionNumber",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).filter(e=>e.functionName===t.functionName).flatMap(e=>Object.values(e.revisions).sort(function(e,t){return t-e})).filter(e=>"$LATEST"!==e)})}):null,"$MOVING"===t.version?Vt.createElement(s,{name:"retentionNumber",help:Vt.createElement(n,{content:"The number of Lambda versions to retain"}),label:"Prior Versions to Retain",input:e=>Vt.createElement(p,{...e,min:1,max:100})}):null)}function Li(e){const{stage:t,name:a,current:n}=e;return Vt.createElement(Re,{name:a,current:n},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," ",Vt.createElement("b",null," Status: ")," ","done"===t.outputs.deleteTask?"COMPLETE":t.outputs.deleteTask," "),Vt.createElement("p",null," ",Vt.createElement("b",null," Deleted Version: ")," ",t.outputs["deleteTask:deleteVersion"]?t.outputs["deleteTask:deleteVersion"]:"N/A"," ")))}function Ri(e){const t=new i(e);return t.field("account","Account Name").required(),t.field("region","Region").required(),t.field("functionName","Lambda Function Name").required(),t.field("version","Lambda Function Version").required(),t.validateForm()}(Li||(Li={})).title="Delete Lambda Stage";const Oi={key:"Aws.LambdaDeleteStage",label:"AWS Lambda Delete",description:"Delete an AWS Lambda Function",component:function(e){return Vt.createElement("div",{className:"DeleteLambdaStageConfig"},Vt.createElement(Ue,{...e,validate:Ri,onChange:e.updateStage,render:e=>Vt.createElement($i,{...e})}))},executionDetailsSections:[Li,Ve],validateFn:Ri},Vi="spinnaker.amazon.pipeline.stage.Aws.LambdaDeleteStage";t(Vi,[]).config(function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Oi)});const Ui="spinnaker.amazon.cloudformation.changetset.info.component";t(Ui,[]).component("cloudFormationChangeSetInfo",Ja(L(e=>{const{stage:t,stageconfig:a}=e,[n,r]=Ut(t.changeSetName?t.changeSetName:"ChangeSet-${execution['id']}"),[i,s]=Ut(t.executeChangeSet),[o,u]=Ut(t.actionOnReplacement);return Vt.createElement("div",null,Vt.createElement("hr",null),Vt.createElement("h4",null,"ChangeSet Configuration"),Vt.createElement(qe,{label:"ChangeSet Name"},Vt.createElement(l,{className:"form-control",type:"text",value:n,onChange:e=>{return t=e.target.value,r(t),void a.updateStageField({changeSetName:t});var t}})),Vt.createElement(qe,{label:"Execute ChangeSet"},Vt.createElement(d,{checked:i,onChange:e=>{return t=e.target.checked,s(t),void a.updateStageField({executeChangeSet:t});var t}})),i&&Vt.createElement(qe,{label:"If ChangeSet contains a replacement","help-key":"aws.cloudformation.changeSet.options"},Vt.createElement(c,{clearable:!1,value:o,options:[{value:"ask",label:"ask"},{value:"skip",label:"skip it"},{value:"execute",label:"execute it"},{value:"fail",label:"fail stage"}],onChange:e=>{return t=e.target.value,u(t),void a.updateStageField({actionOnReplacement:t});var t}})))},"cloudFormationChangeSetInfo"),["stage","stageconfig"]));class qi{constructor(e){this.$scope=e,this.$onInit=()=>{"string"==typeof this.command.templateBody?this.rawTemplateBody=this.command.templateBody:this.rawTemplateBody=He(this.command.templateBody)},this.handleChange=(e,t)=>{this.command.templateBody=t||e,this.templateBody=t||e,this.rawTemplateBody=e,this.$scope.$applyAsync()}}}qi.$inject=["$scope"];const Hi={bindings:{command:"<",templateBody:"<"},controller:qi,controllerAs:"ctrl",template:'\n <yaml-editor\n value="ctrl.rawTemplateBody"\n on-change="ctrl.handleChange"\n ></yaml-editor>'},Wi="spinnaker.amazon.cloudformation.entry.component";t(Wi,[]).component("cloudFormationTemplateEntry",Hi);class ji extends Ot.Component{constructor(e){super(e)}render(){const{stage:e,current:t,name:a}=this.props;return Ot.createElement(Re,{name:a,current:t},Ot.createElement(We,{item:e}),Ot.createElement(Oe,{stage:e,message:e.failureMessage}))}}ji.title="Task Status";class Zi{constructor(e){this.$scope=e,this.state={loaded:!1},this.textSource="text",this.artifactSource="artifact",this.sources=[this.textSource,this.artifactSource],this.showClusterSelect=!1,this.onStackArtifactEdited=e=>{this.$scope.$applyAsync(()=>{this.$scope.stage.stackArtifactId=null,this.$scope.stage.stackArtifact=e})},this.onStackArtifactSelected=e=>{this.onChangeStackArtifactId(e.id)},this.onChangeStackArtifactId=e=>{this.$scope.$applyAsync(()=>{this.$scope.stage.stackArtifactId=e,this.$scope.stage.stackArtifact=null})},this.onStackArtifactAccountSelected=e=>{this.$scope.$applyAsync(()=>{this.$scope.stage.stackArtifactAccount=e})},this.updatePipeline=e=>{this.$scope.$applyAsync(()=>{ha(this.$scope.pipeline,e)})};const t={accounts:o.getAllAccountDetailsForProvider("aws"),artifactAccounts:o.getArtifactAccounts()};Xa.all(t).then(e=>{const{accounts:t,artifactAccounts:a}=e;this.accounts=t,this.state.loaded=!0,this.cloudFormationStackArtifactDelegate.setAccounts(a),this.cloudFormationStackArtifactController.updateAccounts(this.cloudFormationStackArtifactDelegate.getSelectedExpectedArtifact())}),this.cloudFormationStackArtifactDelegate=new je(e,"stack"),this.cloudFormationStackArtifactController=new Ze(this.cloudFormationStackArtifactDelegate)}canShowAccountSelect(){return this.$scope.stage.source===this.artifactSource&&!this.$scope.showCreateArtifactForm&&this.cloudFormationStackArtifactController.accountsForArtifact.length>1}toggleChangeSet(){this.$scope.stage.isChangeSet=!this.$scope.stage.isChangeSet}}Zi.$inject=["$scope"];const _i=e=>{const{execution:t,stage:a,application:n}=e,[r,i]=Ut(!1),[s,l]=Ut(""),[o,c]=Ut(!1),d=e=>{i(!0),l(e),c(!1),Xn.evaluateCloudFormationChangeSetExecutionService.evaluateExecution(n,t,a,e)},u=e=>a.judgmentStatus===e||r&&s===e;return Vt.createElement("div",null,Vt.createElement("div",null,Vt.createElement("p",null,"This ChangeSet contains a replacement, which means there will be ",Vt.createElement("b",null,"potential data loss")," when executed."),Vt.createElement("p",null,"How do you want to proceed?"),Vt.createElement("div",{className:"action-buttons"},Vt.createElement("button",{className:"btn btn-danger",onClick:()=>{d("execute")},disabled:r},u("Execute")&&Vt.createElement(ae,{mode:"circular"}),a.context.stopButtonLabel||"Execute"),Vt.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("skip")}},u("Skip")&&Vt.createElement(ae,{mode:"circular"}),a.context.skipButtonLabel||"Skip"),Vt.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("fail")}},u("Fail")&&Vt.createElement(ae,{mode:"circular"}),a.context.FailButtonLabel||"Fail"))),o&&Vt.createElement("div",{className:"error-message"},"There was an error recording your decision. Please try again."))};class Ki extends Ot.Component{constructor(e){super(e)}render(){const{application:e,execution:t,stage:a,current:n,name:r}=this.props,i=a.context.changeSetContainsReplacement,s=i&&a.isRunning&&"ask"===a.context.actionOnReplacement,l=a.context.isChangeSet;return Ot.createElement(Re,{name:r,current:n},s?Ot.createElement(_i,{key:a.refId,application:e,execution:t,stage:a}):Ot.createElement("div",null,l?Ot.createElement("div",null,Ot.createElement("dl",{className:"no-margin"},Ot.createElement("dt",null,"ChangeSet Name"),Ot.createElement("dd",null,a.context.changeSetName),Ot.createElement("dt",null,"Replacement"),Ot.createElement("dd",null,String(i)),a.context.changeSetExecutionChoice&&Ot.createElement("div",null,Ot.createElement("dt",null,"Judgment"),Ot.createElement("dd",null,a.context.changeSetExecutionChoice),Ot.createElement("dt",null,"Judged By"),Ot.createElement("dd",null,a.context.lastModifiedBy)))):Ot.createElement("div",null,"No changeSets found")))}}Ki.title="Change Set Execution";class Yi extends Ot.Component{render(){if(!this.props.executionMarker)return Ot.createElement(_e,{...this.props});const{stage:e}=this.props;if(e.isRunning&&e.stages[0].context.changeSetContainsReplacement&&"ask"===e.stages[0].context.actionOnReplacement){const t=Ot.createElement("div",null,Ot.createElement("div",null,Ot.createElement("b",null,e.name)),Ot.createElement(_i,{stage:e.masterStage,application:this.props.application,execution:this.props.execution}));return Ot.createElement(ne,{template:t},this.props.children)}const t=Ot.createElement(ja,{id:e.id},e.name);return Ot.createElement(Za,{placement:"top",overlay:t},Ot.createElement("span",null,this.props.children))}}class Xi extends Ot.Component{constructor(e){super(e)}render(){return this.props.stage.isRunning&&this.props.stage.stages[0].context.changeSetContainsReplacement&&"ask"===this.props.stage.stages[0].context.actionOnReplacement?(this.props.stage.requiresAttention=!0,Ot.createElement("span",{className:"fa fa-child"})):null}}const Ji="spinnaker.amazon.pipeline.stages.deployCloudFormationStage";t(Ji,[]).config(()=>{De.pipeline.registerStage({label:"Deploy (CloudFormation Stack)",description:"Deploy a CloudFormation Stack",key:"deployCloudFormation",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/deployCloudFormation/deployCloudFormationStackConfig.html",controller:"DeployCloudFormationStackConfigController",controllerAs:"ctrl",useCustomTooltip:!0,executionDetailsSections:[ji,Ki],executionLabelComponent:Yi,producesArtifacts:!0,supportsCustomTimeout:!0,validators:[],markerIcon:Xi,accountExtractor:e=>e.account?[e.account]:[],configAccountExtractor:e=>e.account?[e.account]:[],artifactExtractor:Ye.accumulateArtifacts(["stackArtifactId","requiredArtifactIds"]),artifactRemover:Ke.removeArtifactFromFields(["stackArtifactId","requiredArtifactIds"])})}).controller("DeployCloudFormationStackConfigController",Zi),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/deployCloudFormation/deployCloudFormationStackConfig.html",'<div ng-if="ctrl.state.loaded" class="clearfix">\n <div class="container-fluid form-horizontal">\n <h4>Basic Settings</h4>\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector\n application="application"\n component="stage"\n accounts="ctrl.accounts"\n show-cluster-select="ctrl.showClusterSelect"\n >\n </account-region-cluster-selector>\n </div>\n <h4>Template Configuration</h4>\n <ng-form name="amazonCloudFormationTemplateSource">\n <stage-config-field label="Stack name">\n <label class="sm-label-right">\n <input type="text" class="form-control input-sm" required ng-model="stage.stackName" />\n </label>\n <br />\n <label>\n <input type="checkbox" ng-checked="stage.isChangeSet" ng-click="ctrl.toggleChangeSet()" />\n <strong>Create CloudFormation ChangeSet</strong>\n </label>\n </stage-config-field>\n\n <stage-config-field label="IAM role ARN">\n <label class="sm-label-right">\n <input type="text" class="form-control input-sm" ng-model="stage.roleARN" />\n </label>\n </stage-config-field>\n <stage-config-field label="Source" help-key="aws.cloudformation.source">\n <label class="sm-label-right">\n <input type="radio" ng-model="ctrl.$scope.stage.source" value="{{ctrl.textSource}}" />\n {{ ctrl.textSource | robotToHuman }}\n <span ng-if="stage.source === ctrl.textSource"> </span> </label\n ><br />\n <label class="sm-label-right">\n <input type="radio" ng-model="ctrl.$scope.stage.source" value="{{ctrl.artifactSource}}" />\n {{ ctrl.artifactSource | robotToHuman }}\n </label>\n </stage-config-field>\n </ng-form>\n <cloud-formation-template-entry\n ng-if="stage.source === ctrl.textSource"\n templateBody="stage.templateBody"\n command="stage"\n >\n </cloud-formation-template-entry>\n <stage-artifact-selector-delegate\n ng-if="ctrl.$scope.stage.source === ctrl.artifactSource"\n artifact="stage.stackArtifact"\n excluded-artifact-type-patterns="[]"\n expected-artifact-id="stage.stackArtifactId"\n field-columns="8"\n help-key="\'aws.cloudformation.expectedArtifact\'"\n label="\'Expected Artifact\'"\n on-artifact-edited="ctrl.onStackArtifactEdited"\n on-expected-artifact-selected="ctrl.onStackArtifactSelected"\n pipeline="pipeline"\n stage="stage"\n >\n </stage-artifact-selector-delegate>\n <div ng-if="stage.isChangeSet">\n <cloud-formation-change-set-info stage="stage" stageconfig="stageConfigCtrl"> </cloud-formation-change-set-info>\n </div>\n <hr />\n <stage-config-field label="Parameters" field-columns="6">\n <map-editor model="ctrl.$scope.stage.parameters" add-button-label="Add parameter"></map-editor>\n </stage-config-field>\n <hr />\n <stage-config-field label="Tags" field-columns="6">\n <map-editor model="ctrl.$scope.stage.tags" add-button-label="Add tag"></map-editor>\n </stage-config-field>\n <hr />\n <stage-config-field label="Capabilities" field-columns="6">\n <ui-select multiple ng-model="stage.capabilities" class="form-control input-sm">\n <ui-select-match>{{$item}}</ui-select-match>\n <ui-select-choices repeat="capability in [\'CAPABILITY_IAM\', \'CAPABILITY_NAMED_IAM\', \'CAPABILITY_AUTO_EXPAND\']">\n <span>{{ capability }}</span>\n </ui-select-choices>\n </ui-select>\n </stage-config-field>\n </div>\n</div>\n')}]);class Qi{constructor(e){this.executionService=e}evaluateExecution(e,t,a,n){const r=e=>{const t=e.stages.find(e=>e.id===a.id);return t&&"RUNNING"!==t.status};return this.executionService.patchExecution(t.id,a.id,{changeSetExecutionChoice:n}).then(()=>this.executionService.waitUntilExecutionMatches(t.id,r)).then(t=>this.executionService.updateExecution(e,t))}}Qi.$inject=["executionService"];const es="spinnaker.amazon.deployCloudFormation.service";function ts(e,t){return Object.entries(t).forEach(([t,a])=>{var n;e[t]||fa(n=a)&&(Yt(n)||""===n)||(e[t]=a)}),e}function as(e){const{values:t}=e.formik,a=()=>{const a=re.getClusterName(e.application.name,t.stackName,t.detailName),n=t.functionUid;e.formik.setFieldValue("functionName",`${a}-${n}`)},{result:r,status:i}=F(()=>o.listAccounts("aws"),[],[]);return Vt.createElement("div",null,Vt.createElement(s,{label:"Account",name:"account",input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map(e=>e.name)})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("enableLambdaAtEdge",!1),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.filter(e=>e.name===t.account).flatMap(e=>e.regions).map(e=>e.name)})}),Vt.createElement(s,{name:"functionUid",label:"Function Name",onChange:t=>{e.formik.setFieldValue("functionUid",t),a()},help:Vt.createElement(n,{id:"aws.function.name"}),input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"stackName",label:"Stack",help:Vt.createElement(n,{content:Ln}),onChange:t=>{e.formik.setFieldValue("stackName",t),a()},input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"detailName",label:"Detail",help:Vt.createElement(n,{content:Rn}),onChange:t=>{e.formik.setFieldValue("detailName",t),a()},input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"aliasNames",label:"Alias Name",help:Vt.createElement(n,{content:"AWS Lambda aliases are like a pointer to a specific function version. Users can access the function version using the alias Amazon Resource Name (ARN). Input the alias name and select `Create option ALIAS-INPUT` to add the alias."}),input:a=>Vt.createElement(Je,{...a,multi:!0,clearable:!1,placeholder:"Input Alias Name...",onChange:t=>{var a,n;a=t,n="aliases",e.formik.setFieldValue(n,a.map(e=>e.value))},value:t.aliases?t.aliases.map(e=>({value:e,label:e})):[]})}),Vt.createElement(s,{name:"runtime",label:"Runtime",help:Vt.createElement(n,{id:"aws.function.runtime"}),input:e=>Vt.createElement(c,{...e,stringOptions:$n,clearable:!0})}),Vt.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Vt.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Vt.createElement(l,{...e,placeholder:"S3 bucket name"})}),Vt.createElement(s,{name:"s3key",label:"S3 Key",help:Vt.createElement(n,{id:"aws.function.s3key"}),input:e=>Vt.createElement(l,{...e,placeholder:"object.zip"})}),Vt.createElement(s,{name:"handler",label:"Handler",help:Vt.createElement(n,{id:"aws.function.handler"}),input:e=>Vt.createElement(l,{...e,placeholder:"filename.method"})}),Vt.createElement(s,{name:"publish",label:"Publish",help:Vt.createElement(n,{id:"aws.function.publish"}),input:e=>Vt.createElement(d,{...e})}))}t(es,[Xe]).service("evaluateCloudFormationChangeSetExecutionService",Qi);function ns(e){const{values:t}=e.formik,a=t=>{e.formik.setFieldValue("securityGroupIds",null),e.formik.setFieldValue("subnetIds",null),e.formik.setFieldValue("vpcId",t.target.value)},{result:n,status:r}=F(()=>m.listNetworksByProvider("aws"),[],[]),{result:i}=F(()=>g.listSubnetsByProvider("aws"),[],[]),{result:l}=F(()=>h.securityGroupReader.getAllSecurityGroups(),void 0,[]),o=t.account&&t.region&&"PENDING"!==r?n.filter(e=>!1===e.deprecated).filter(e=>e.account===t.account).filter(e=>e.region===t.region).map(e=>e.id):[],d=Zt(i.filter(e=>e.vpcId===t.vpcId),"id"),u=t.account&&t.region&&t.vpcId?l[t.account].aws[t.region].filter(e=>e.vpcId===t.vpcId).map(e=>({value:e.id,label:e.name})):[];return Vt.createElement("div",null,Vt.createElement(s,{name:"vpcId",label:"VPC Id",input:e=>Vt.createElement(c,{...e,onChange:a,isLoading:"PENDING"===r,stringOptions:o,clearable:!0})}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Subnets ")),0===d.length?Vt.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC "):Vt.createElement("div",{className:"col-md-6"},Vt.createElement(f,{multi:!0,options:d.map(e=>{return{value:(t=e).id,label:t.id};var t}),value:t.subnetIds,onChange:t=>{const a=t.map(e=>e.value);e.formik.setFieldValue("subnetIds",a)}}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Security Groups ")),0===u.length?Vt.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC "):Vt.createElement("div",{className:"col-md-6"},Vt.createElement(f,{multi:!0,options:u,value:t.securityGroupIds,onChange:t=>{const a=t.map(e=>e.value);e.formik.setFieldValue("securityGroupIds",a)}}))))}function rs(){return Vt.createElement(s,{name:"role",label:"Role ARN",input:e=>Vt.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"})})}function is(e){const{values:t}=e.formik;return Vt.createElement("div",null,Vt.createElement(s,{name:"triggerArns",label:"Event ARNs",help:Vt.createElement(n,{content:"The resource ARNs for Lambda event trigger sources. Triggers created here will only be applied to the higher level function, and will NOT be applied to function aliases. Input the entire ARN and select `Create option TRIGGER-ARN-INPUT` to add the ARN."}),input:a=>Vt.createElement(Je,{...a,multi:!0,placeholder:"Input ARN...",onChange:t=>{var a,n;a=t,n="triggerArns",e.formik.setFieldValue(n,a.map(e=>e.value))},value:t.triggerArns?t.triggerArns.map(e=>({value:e,label:e})):[]})}),Vt.createElement(s,{name:"batchsize",label:"Event Batch Size",input:e=>Vt.createElement(p,{...e,min:1,max:1e3})}))}const ss="Validate AWS Lambda function configuration against Lambda@Edge requirements. This will not enable Lambda@Edge on this function. ";function ls(e){const{values:t}=e.formik;return"us-east-1"!==t.region?Vt.createElement("div",{className:"horizontal center"},"Lambda@Edge is only available in region us-east-1."):Vt.createElement("div",null,Vt.createElement(s,{name:"enableLambdaAtEdge",label:"Enable Lambda@Edge Validation",help:Vt.createElement(n,{content:ss}),input:e=>Vt.createElement(d,{...e})}))}function os(e){const{values:t,errors:a}=e.formik,r=Na({well:!0,"alert-danger":!!a.functionName,"alert-info":!a.functionName});return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("div",{className:r},Vt.createElement("strong",null,"Your function will be named: "),Vt.createElement(n,{id:"aws.function.name"}),Vt.createElement("span",null,t.functionName?t.functionName:e.application.name),Vt.createElement(s,{name:"functionName",input:()=>null})),Vt.createElement("h4",null,"Basic Settings"),Vt.createElement(as,{...e}),Vt.createElement("h4",null," Execution Role "),Vt.createElement(rs,null),Vt.createElement("h4",null," Environment "),!0!==t.enableLambdaAtEdge?Vt.createElement(Vt.Fragment,null,Vt.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Vt.createElement(s,{name:"encryptionKMSKeyArn",label:"Key ARN",help:Vt.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Vt.createElement(l,{...e})})):Vt.createElement("div",{className:"horizontal center"},"Environment variables not available with Lambda@Edge functions."),Vt.createElement("h4",null," Tags "),Vt.createElement(s,{name:"tags",input:e=>Vt.createElement(u,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}),Vt.createElement("h4",null," Settings "),Vt.createElement(s,{name:"description",label:"Description",input:e=>Vt.createElement(l,{...e})}),Vt.createElement(s,{name:"layers",label:"Layer ARNs",help:Vt.createElement(n,{content:"The resource ARNs for Lambda layer. Input the entire ARN and select `Create option TRIGGER-ARN-INPUT` to add the ARN."}),input:a=>Vt.createElement(Je,{...a,multi:!0,placeholder:"Layer ARN...",onChange:t=>{var a,n;a=t,n="layers",e.formik.setFieldValue(n,a.map(e=>e.value))},value:t.layers?t.layers.map(e=>({value:e,label:e})):[]})}),Vt.createElement(s,{name:"reservedConcurrentExecutions",label:"Reserved Concurrency",help:Vt.createElement(n,{content:"The total number of current executions of your Lambda function that can be instantiated at any time."}),input:e=>Vt.createElement(p,{...e,min:0,max:3e3})}),Vt.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Vt.createElement(p,{...e,min:128,max:!0===t.enableLambdaAtEdge?128:3008})}),Vt.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Vt.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Vt.createElement(p,{...e,min:1,max:!0===t.enableLambdaAtEdge?5:900})}),Vt.createElement(ls,{...e}),Vt.createElement("h4",null," Network "),!0!==t.enableLambdaAtEdge?Vt.createElement(ns,{...e}):Vt.createElement("div",{className:"horizontal center"},"VPC configuration not available with Lambda@Edge functions."),Vt.createElement("h4",null," Event Triggers "),Vt.createElement(is,{...e}),Vt.createElement("h4",null," Debugging and Error Handling "),"Dead Letter Config",Vt.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Vt.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Vt.createElement(l,{...e})}),"X-Ray Tracing",Vt.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Vt.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Vt.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}function cs(e){const t=new i(e);return t.field("runtime","Runtime").required(),t.field("s3key","S3 Object Key").required(),t.field("handler","Handler").required(),t.field("functionUid","Function Name").required(),t.field("stackName","Stack Name").optional().withValidators(Fn),t.field("detailName","Detail Name").optional().withValidators(Fn),t.field("s3bucket","S3 Bucket Name").required().withValidators(Dn),t.field("role","Role ARN").required().withValidators(Pn),t.field("triggerArns","Trigger ARNs").optional().withValidators((e,t)=>e.map(e=>Bn(e,e)).every(e=>void 0===e)?void 0:"Invalid ARN. Event ARN must match regular expression: /^arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./"),t.validateForm()}function ds(e){const{stage:t,current:a,name:n}=e;return Vt.createElement(Re,{name:n,current:a},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," ",Vt.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ",Vt.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}(ds||(ds={})).title="Lambda Deployment Stage";const us={key:"Aws.LambdaDeploymentStage",label:"AWS Lambda Deployment",description:"Create a Single AWS Lambda Function",component:function(e){const t={role:"",runtime:"",s3key:"",s3bucket:"",handler:"",functionName:"",publish:!1,tags:{},memorySize:128,description:"",credentials:"",cloudProvider:"aws",region:"",envVariables:{},tracingConfig:{mode:"PassThrough"},kmskeyArn:"",vpcId:"",subnetIds:[],securityGroupIds:[],timeout:3,deadLetterConfig:{targetArn:""},operation:"",targetGroups:""};return Vt.createElement("div",{className:"LambdaDeploymentConfig"},Vt.createElement(Ue,{...e,stage:ts(e.stage,t),validate:cs,onChange:e.updateStage,render:e=>Vt.createElement(os,{...e})}))},executionDetailsSections:[ds,Ve],validateFn:cs},ps="spinnaker.amazon.pipeline.stage.Aws.LambdaDeploymentStage";t(ps,[]).config(function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(us)});const ms="spinnaker.amazon.pipeline.stage.aws.destroyAsgStage";t(ms,[]).config(function(){De.pipeline.registerStage({provides:"destroyServerGroup",alias:"destroyAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/destroyAsg/destroyAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/destroyAsg/destroyAsgStepLabel.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"targetImpedance",message:"This pipeline will attempt to destroy a server group without deploying a new version into the same cluster."},{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsDestroyAsgStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),e.regions=["us-east-1","us-west-1","eu-west-1","us-west-2"],e.targets=$e.TARGET_LIST,t.regions=t.regions||[],t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),t.target||(t.target=e.targets[0].val)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/destroyAsg/destroyAsgStage.html",'<div ng-controller="awsDestroyAsgStageCtrl as destroyAsgStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/destroyAsg/destroyAsgStepLabel.html",'<span class="task-label"> Destroy Server Group: {{step.context.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const gs="spinnaker.amazon.pipeline.stage.disableAsgStage";t(gs,[]).config(function(){De.pipeline.registerStage({provides:"disableServerGroup",alias:"disableAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/disableAsg/disableAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/disableAsg/disableAsgStepLabel.html",validators:[{type:"targetImpedance",message:"This pipeline will attempt to disable a server group without deploying a new version into the same cluster."},{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsDisableAsgStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),e.targets=$e.TARGET_LIST,t.regions=t.regions||[],t.cloudProvider="aws",t.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(t.interestingHealthProviderNames=["Amazon"]),!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),t.target||(t.target=e.targets[0].val)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/disableAsg/disableAsgStage.html",'<div ng-controller="awsDisableAsgStageCtrl as disableAsgStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/disableAsg/disableAsgStepLabel.html",'<span class="task-label"> Disable Server Group: {{step.context.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const hs="spinnaker.amazon.pipeline.stage.disableClusterStage";t(hs,[]).config(function(){De.pipeline.registerStage({provides:"disableCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/disableCluster/disableClusterStage.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"remainingEnabledServerGroups",fieldLabel:"Keep [X] enabled Server Groups"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsDisableClusterStageCtrl",["$scope",function(e){const t=this,a=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),t.reset=()=>{t.accountUpdated(),t.resetSelectedCluster()},a.regions=a.regions||[],a.cloudProvider="aws",a.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(a.interestingHealthProviderNames=["Amazon"]),!a.credentials&&e.application.defaultCredentials.aws&&(a.credentials=e.application.defaultCredentials.aws),!a.regions.length&&e.application.defaultRegions.aws&&a.regions.push(e.application.defaultRegions.aws),void 0===a.remainingEnabledServerGroups&&(a.remainingEnabledServerGroups=1),t.pluralize=function(e,t){return 1===t?e:e+"s"},void 0===a.preferLargerOverNewer&&(a.preferLargerOverNewer="false"),a.preferLargerOverNewer=a.preferLargerOverNewer.toString()}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/disableCluster/disableClusterStage.html",'<div ng-controller="awsDisableClusterStageCtrl as disableClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Disable Options">\n <div class="form-inline">\n Keep the\n <input\n type="number"\n min="0"\n required\n ng-model="stage.remainingEnabledServerGroups"\n class="form-control input-sm"\n style="width: 50px"\n />\n <select class="form-control input-sm" ng-model="stage.preferLargerOverNewer" style="width: 100px">\n <option value="true">largest</option>\n <option value="false">newest</option>\n </select>\n {{disableClusterStageCtrl.pluralize(\'server group\', stage.remainingEnabledServerGroups)}} enabled.\n </div>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]);const fs="spinnaker.amazon.pipeline.stage.enableAsgStage";t(fs,[]).config(function(){De.pipeline.registerStage({provides:"enableServerGroup",alias:"enableAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/enableAsg/enableAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/enableAsg/enableAsgStepLabel.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsEnableAsgStageCtrl",["$scope",function(e){const t=this,a=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),t.reset=()=>{t.accountUpdated(),t.resetSelectedCluster()},e.targets=$e.TARGET_LIST,a.regions=a.regions||[],a.cloudProvider="aws",a.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(a.interestingHealthProviderNames=["Amazon"]),!a.credentials&&e.application.defaultCredentials.aws&&(a.credentials=e.application.defaultCredentials.aws),!a.regions.length&&e.application.defaultRegions.aws&&a.regions.push(e.application.defaultRegions.aws),a.target||(a.target=e.targets[0].val),e.$watch("stage.credentials",e.accountUpdated)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/enableAsg/enableAsgStage.html",'<div ng-controller="awsEnableAsgStageCtrl as enableAsgStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/enableAsg/enableAsgStepLabel.html",'<span class="task-label"> Enable Server Group: {{step.context.serverGroupName}} ({{step.context.region}}) </span>\n')}]);const vs="spinnaker.amazon.pipeline.stage.findAmiStage";e.module(vs,[]).config(function(){De.pipeline.registerStage({provides:"findImage",alias:"findAmi",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/findAmi/findAmiStage.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"selectionStrategy",fieldLabel:"Server Group Selection"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials"}]})}).controller("awsFindAmiStageCtrl",["$scope",function(t){const a=t.stage;t.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(e){t.accounts=e,t.state.accounts=!0}),t.selectionStrategies=[{label:"Largest",val:"LARGEST",description:"When multiple server groups exist, prefer the server group with the most instances"},{label:"Newest",val:"NEWEST",description:"When multiple server groups exist, prefer the newest"},{label:"Oldest",val:"OLDEST",description:"When multiple server groups exist, prefer the oldest"},{label:"Fail",val:"FAIL",description:"When multiple server groups exist, fail"}],a.regions=a.regions||[],a.cloudProvider="aws",a.selectionStrategy=a.selectionStrategy||t.selectionStrategies[0].val,e.isUndefined(a.onlyEnabled)&&(a.onlyEnabled=!0),!a.credentials&&t.application.defaultCredentials.aws&&(a.credentials=t.application.defaultCredentials.aws),!a.regions.length&&t.application.defaultRegions.aws&&a.regions.push(t.application.defaultRegions.aws),t.$watch("stage.credentials",t.accountUpdated)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/findAmi/findAmiStage.html",'<div ng-controller="awsFindAmiStageCtrl as findAmiCtrl" class="form-horizontal">\n <account-region-cluster-selector\n application="application"\n component="stage"\n accounts="accounts"\n show-all-regions="true"\n >\n </account-region-cluster-selector>\n <stage-config-field label="Server Group Selection">\n <ui-select ng-model="stage.selectionStrategy" class="form-control input-sm">\n <ui-select-match placeholder="None">{{$select.selected.label}}</ui-select-match>\n <ui-select-choices repeat="strategy.val as strategy in selectionStrategies | filter: $select.search">\n <strong ng-bind-html="strategy.label | highlight: $select.search"></strong>\n <div ng-bind-html="strategy.description"></div>\n </ui-select-choices>\n </ui-select>\n </stage-config-field>\n <stage-config-field label="Server Group Filters">\n <label class="checkbox-inline">\n <input type="checkbox" ng-model="stage.onlyEnabled" />\n Only consider enabled Server Groups\n </label>\n </stage-config-field>\n</div>\n')}]);const ys="spinnaker.amazon.pipeline.stage.findImageFromTagsStage";function bs(e){const{values:t}=e.formik,a=Qe(et.BITBUCKET_FILE,et.CUSTOM_OBJECT,et.EMBEDDED_BASE64,et.REMOTE_BASE64,et.GCS_OBJECT,et.GITHUB_FILE,et.GITLAB_FILE,et.S3_OBJECT,et.HTTP_FILE),n=(e,t)=>e[t]?e[t]:{account:"",id:""};return Vt.createElement("div",null,Vt.createElement(s,{name:"timeout",label:"Timeout",input:e=>Vt.createElement(p,{...e,min:0,max:900})}),Vt.createElement(s,{name:"executionCount",label:"Execution Count",input:e=>Vt.createElement(p,{...e,min:0,max:100})}),Vt.createElement(tt,{artifact:n(t,"payloadArtifact").artifact,excludedArtifactTypePatterns:a,expectedArtifactId:n(t,"payloadArtifact").id,label:"Payload Artifact",onArtifactEdited:t=>{((t,a)=>{e.formik.setFieldValue(`${a}.id`,null),e.formik.setFieldValue(`${a}.artifact`,t),e.formik.setFieldValue(`${a}.account`,t.artifactAccount)})(t,"payloadArtifact")},helpKey:"",onExpectedArtifactSelected:t=>{return a=t.id,n="payloadrtifact",e.formik.setFieldValue(`${n}.id`,a),void e.formik.setFieldValue(`${n}.artifact`,null);var a,n},pipeline:e.pipeline,stage:t}))}function Es(e){const{values:t}=e.formik,{functions:a}=e.application,{result:n,status:r}=F(()=>o.listAccounts("aws"),[],[]),i=t.account&&t.region?a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).map(e=>e.functionName):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("h4",null," Basic Settings "),Vt.createElement(s,{label:"Account",name:"account",onChange:t=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("account",t)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===r,stringOptions:n.map(e=>e.name)})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===r,stringOptions:n.filter(e=>e.name===t.account).flatMap(e=>e.regions).map(e=>e.name)})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:i})}),Vt.createElement(s,{label:"Alias",name:"aliasName",input:e=>Vt.createElement(l,{...e})}),Vt.createElement("h4",null," Invoke Settings "),Vt.createElement(bs,{...e}))}function ws(e){const{stage:t}=e;return Vt.createElement(Re,{name:e.name,current:e.current},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," Function Name: ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ","Deployed Alias:"," ",t.outputs["deployment:aliasDeployed"]?t.outputs["deployment:aliasDeployed"]:"N/A"," "),Vt.createElement("p",null," ","Deployed Major Version:"," ",t.outputs["deployment:majorVersionDeployed"]?t.outputs["deployment:majorVersionDeployed"]:"N/A"," ")))}function Cs(e){const t=new i(e);return t.field("triggerArns","Trigger ARNs").optional().withValidators((e,t)=>e.map(e=>Bn(e,e)).every(e=>void 0===e)?void 0:"Invalid ARN. Event ARN must match regular expression: /^arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./"),t.validateForm()}t(ys,[]).config(function(){De.pipeline.registerStage({provides:"findImageFromTags",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsExecutionDetails.html",executionConfigSections:["findImageConfig","taskStatus"],validators:[{type:"requiredField",fieldName:"packageName"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"tags"}]})}).controller("awsFindImageFromTagsStageCtrl",["$scope",function(e){e.stage.tags=e.stage.tags||{},e.stage.regions=e.stage.regions||[],e.stage.cloudProvider=e.stage.cloudProvider||"aws",Me.getRegions("aws").then(function(t){e.regions=t})}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsStage.html",'<div ng-controller="awsFindImageFromTagsStageCtrl as findImageFromTagsCtrl" class="form-horizontal">\n <stage-config-field label="Package">\n <input type="text" class="form-control input-sm" ng-model="stage.packageName" />\n </stage-config-field>\n <stage-config-field label="Regions">\n <checklist items="regions" model="stage.regions" inline="true" include-select-all-button="true"></checklist>\n </stage-config-field>\n <stage-config-field label="Tags">\n <map-editor model="stage.tags" allow-empty="true"></map-editor>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/findImageFromTags/findImageFromTagsExecutionDetails.html",'<div ng-controller="BaseExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'findImageConfig\'">\n <div class="row">\n <div class="col-md-12">\n <dl class="dl-narrow dl-horizontal">\n <dt if-multiple-providers>Provider</dt>\n <dd if-multiple-providers>Amazon</dd>\n <dt>Package</dt>\n <dd>{{stage.context.packageName}}</dd>\n <dt>Regions</dt>\n <dd>{{stage.context.regions.join(\', \')}}</dd>\n <dt>Tags</dt>\n <dd>\n <span ng-repeat="(key, val) in stage.context.tags"> {{key}}:{{val}}{{$last ? \'\' : \', \'}} </span>\n </dd>\n </dl>\n </div>\n </div>\n <stage-failure-message stage="stage" message="stage.failureMessage"></stage-failure-message>\n\n <div class="row" ng-if="stage.context.amiDetails">\n <div class="col-md-12">\n <div class="well alert alert-info">\n <h4>Results</h4>\n <dl ng-repeat="image in stage.context.amiDetails" class="dl-narrow dl-horizontal">\n <dt>Region</dt>\n <dd>{{image.region}}</dd>\n <dt>Image ID</dt>\n <dd>{{image.imageId}}</dd>\n <dt>Name</dt>\n <dd>{{image.imageName}}</dd>\n </dl>\n </div>\n </div>\n </div>\n </div>\n\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]),(ws||(ws={})).title="Invoke Lambda Stage";const Ss={key:"Aws.LambdaInvokeStage",label:"AWS Lambda Invoke",description:"Invoke a Lambda function",component:function(e){return Vt.createElement("div",{className:"InvokeLambdaStageConfig"},Vt.createElement(Ue,{...e,validate:Cs,onChange:e.updateStage,render:e=>Vt.createElement(Es,{...e})}))},executionDetailsSections:[ws,Ve],validateFn:Cs},ks="spinnaker.amazon.pipeline.stage.Aws.LambdaInvokeStage";t(ks,[]).config(function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Ss)});const Ns="spinnaker.amazon.pipeline.stage.modifyScalingProcessStage";t(Ns,[]).config(function(){De.pipeline.registerStage({label:"Modify Scaling Process",description:"Suspend/Resume Scaling Processes",key:"modifyAwsScalingProcess",alias:"modifyScalingProcess",controller:"ModifyScalingProcessStageCtrl",templateUrl:"amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessExecutionDetails.html",executionConfigSections:["modifyScalingProcessesConfig","taskStatus"],validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"action"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"processes"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}],cloudProvider:"aws",strategy:!0})}).controller("ModifyScalingProcessStageCtrl",["$scope","stage",function(e,t){e.stage=t,e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),e.targets=$e.TARGET_LIST,e.actions=[{label:"Suspend",val:"suspend"},{label:"Resume",val:"resume"}],e.processes=["Launch","Terminate","AddToLoadBalancer","AlarmNotification","AZRebalance","HealthCheck","ReplaceUnhealthy","ScheduledActions"],t.processes=t.processes||[],t.regions=t.regions||[],t.action=t.action||e.actions[0].val,t.target=t.target||e.targets[0].val,t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),e.toggleProcess=function(e){t.processes||(t.processes=[]);const a=t.processes.indexOf(e);a>-1?t.processes.splice(a,1):t.processes.push(e)},e.$watch("stage.credentials",e.accountUpdated)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessStage.html",'<div class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="targets"></target-select>\n </stage-config-field>\n <stage-config-field label="Action">\n <select\n class="form-control input-sm"\n required\n ng-model="stage.action"\n ng-options="a.val as a.label for a in actions"\n >\n <option>Select an action...</option>\n </select>\n </stage-config-field>\n <stage-config-field label="Processes" field-columns="8">\n <div class="checkbox" style="padding-left: 0">\n <checklist model="stage.processes" items="processes"></checklist>\n </div>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/modifyScalingProcess/modifyScalingProcessExecutionDetails.html",'<div ng-controller="BaseExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'modifyScalingProcessesConfig\'">\n <div class="row">\n <div class="col-md-9">\n <dl class="dl-narrow dl-horizontal">\n <dt>Account</dt>\n <dd><account-tag account="stage.context.credentials"></account-tag></dd>\n <dt>Region</dt>\n <dd>{{stage.context.region}}</dd>\n <dt>ASG Name</dt>\n <dd>{{stage.context.asgName}}</dd>\n <dt>Action</dt>\n <dd>{{stage.context.action}}</dd>\n <dt>Processes</dt>\n <dd>{{stage.context.processes.join(\', \')}}</dd>\n </dl>\n </div>\n </div>\n <stage-failure-message stage="stage" message="stage.failureMessage"></stage-failure-message>\n\n <div class="row" ng-if="stage.context.execution.logs">\n <div class="col-md-12">\n <div class="well alert alert-info">\n <a target="_blank" href="{{stage.context.execution.logs}}"> View Execution Logs </a>\n </div>\n </div>\n </div>\n </div>\n\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]);const Ts="spinnaker.amazon.pipeline.stage.aws.resizeAsgStage";t(Ts,[]).config(function(){De.pipeline.registerStage({provides:"resizeServerGroup",alias:"resizeAsg",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/resizeAsg/resizeAsgStage.html",executionStepLabelUrl:"amazon/src/pipeline/stages/resizeAsg/resizeAsgStepLabel.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"targetImpedance",message:"This pipeline will attempt to resize a server group without deploying a new version into the same cluster."},{type:"requiredField",fieldName:"target"},{type:"requiredField",fieldName:"action"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsResizeAsgStageCtrl",["$scope",function(e){const t=e.stage;e.viewState={accountsLoaded:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.viewState.accountsLoaded=!0}),e.resizeTargets=$e.TARGET_LIST,e.scaleActions=[{label:"Scale Up",val:"scale_up"},{label:"Scale Down",val:"scale_down"},{label:"Scale to Cluster Size",val:"scale_to_cluster"},{label:"Scale to Exact Size",val:"scale_exact"}],e.resizeTypes=[{label:"Percentage",val:"pct"},{label:"Incremental",val:"incr"}],t.capacity=t.capacity||{},t.regions=t.regions||[],t.target=t.target||e.resizeTargets[0].val,t.action=t.action||e.scaleActions[0].val,t.resizeType=t.resizeType||e.resizeTypes[0].val,void 0===t.targetHealthyDeployPercentage&&(t.targetHealthyDeployPercentage=100),t.action||"exact"!==t.resizeType||(t.action="scale_exact"),t.cloudProvider="aws",t.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(t.interestingHealthProviderNames=["Amazon"]),!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),this.updateResizeType=function(){"scale_exact"===t.action?(t.resizeType="exact",delete t.scalePct,delete t.scaleNum):(t.capacity={},"pct"===t.resizeType?delete t.scaleNum:(t.resizeType="incr",delete t.scalePct,t.scaleNum=t.scaleNum||0))}}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/resizeAsg/resizeAsgStage.html",'<div ng-controller="awsResizeAsgStageCtrl as resizeAsgStageCtrl">\n <div ng-if="!pipeline.strategy">\n <div ng-if="!viewState.accountsLoaded" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div ng-if="viewState.accountsLoaded">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n </div>\n <stage-config-field label="Target">\n <target-select model="stage" options="resizeTargets"></target-select>\n </stage-config-field>\n <stage-config-field label="Action" help-key="pipeline.config.resizeAsg.action">\n <select\n class="form-control input-sm"\n required\n ng-model="stage.action"\n ng-change="resizeAsgStageCtrl.updateResizeType()"\n ng-options="a.val as a.label for a in scaleActions"\n >\n <option>Select an action...</option>\n </select>\n </stage-config-field>\n <div ng-if="stage.action !== \'scale_exact\'">\n <stage-config-field label="{{stage.action === \'scale_to_cluster\' ? \'Additional Capacity\' : \'Type\'}}">\n <select\n class="form-control input-sm"\n required\n ng-model="stage.resizeType"\n ng-change="resizeAsgStageCtrl.updateResizeType()"\n ng-options="t.val as t.label for t in resizeTypes"\n >\n <option>Select an action...</option>\n </select>\n </stage-config-field>\n <div ng-if="stage.resizeType === \'pct\'">\n <stage-config-field label="Resize Percentage">\n <input type="number" min="0" ng-model="stage.scalePct" class="form-control input-sm" style="width: 80px" />\n <div>\n <em class="subinput-note"\n >This is the percentage by which the target server group\'s capacity will be increased</em\n >\n </div>\n </stage-config-field>\n </div>\n <div ng-if="stage.resizeType === \'incr\'">\n <stage-config-field label="Resize-by Amount">\n <input type="number" min="0" ng-model="stage.scaleNum" class="form-control input-sm" style="width: 80px" />\n <div>\n <em class="subinput-note"\n >This is the exact amount by which the target server group\'s capacity will be increased</em\n >\n </div>\n </stage-config-field>\n </div>\n <div ng-if="stage.action === \'scale_up\' || stage.action === \'scale_to_cluster\'">\n <stage-config-field>\n <target-healthy-percentage-selector command="stage"></target-healthy-percentage-selector>\n </stage-config-field>\n </div>\n </div>\n <div ng-if="stage.action === \'scale_exact\'">\n <stage-config-field class="small">\n <div class="row">\n <div class="col-md-3">Min</div>\n <div class="col-md-3">Max</div>\n <div class="col-md-3">Desired</div>\n </div>\n </stage-config-field>\n <stage-config-field label="Match Capacity">\n <div class="row">\n <div class="col-md-3">\n <input type="number" ng-model="stage.capacity.min" class="form-control input-sm" />\n </div>\n <div class="col-md-3">\n <input type="number" ng-model="stage.capacity.max" class="form-control input-sm" />\n </div>\n <div class="col-md-3">\n <input type="number" ng-model="stage.capacity.desired" class="form-control input-sm" />\n </div>\n </div>\n </stage-config-field>\n <stage-config-field>\n <em class="subinput-note">This is the exact amount to which the target server group will be scaled</em>\n </stage-config-field>\n </div>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/resizeAsg/resizeAsgStepLabel.html",'<span class="task-label" ng-if="!step.context.useNameAsLabel">\n Resize Server Group: {{step.context.serverGroupName}} ({{step.context.region}})\n</span>\n<span class="task-label" ng-if="step.context.useNameAsLabel"> {{step.name}} </span>\n')}]);const Is="spinnaker.amazon.pipeline.stage.rollbackClusterStage";function Gs(e){const{values:t}=e.formik;return Vt.createElement("div",null,Vt.createElement(s,{name:"triggerArns",label:"Event ARNs",help:Vt.createElement(n,{content:"The resource ARNs for Lambda event trigger sources. Input the entire ARN and select `Create option TRIGGER-ARN-INPUT` to add the ARN."}),input:a=>Vt.createElement(Je,{...a,multi:!0,placeholder:"Input ARN...",onChange:t=>{var a,n;a=t,n="triggerArns",e.formik.setFieldValue(n,a.map(e=>e.value))},value:t.triggerArns?t.triggerArns.map(e=>({value:e,label:e})):[]}),required:!1}),Vt.createElement(s,{name:"batchsize",label:"Event Batch Size",input:e=>Vt.createElement(p,{...e,min:1,max:10}),required:!1}))}function As(e){const{values:t}=e.formik,a=Qe(et.BITBUCKET_FILE,et.CUSTOM_OBJECT,et.EMBEDDED_BASE64,et.GCS_OBJECT,et.GITHUB_FILE,et.GITLAB_FILE,et.S3_OBJECT,et.HTTP_FILE),n=(t,a)=>{e.formik.setFieldValue(`${a}.id`,null),e.formik.setFieldValue(`${a}.artifact`,t),e.formik.setFieldValue(`${a}.account`,t.artifactAccount)},r=(t,a)=>{e.formik.setFieldValue(`${a}.id`,t),e.formik.setFieldValue(`${a}.artifact`,null)},i=(e,t)=>e[t]?e[t]:{account:"",id:""};return Vt.createElement("div",null,Vt.createElement(s,{name:"destroyOnFail",label:"On Fail",input:e=>Vt.createElement(d,{text:"Destroy latest lambda version on fail.",...e})}),Vt.createElement(s,{name:"timeout",label:"Timeout",input:e=>Vt.createElement(p,{...e,min:0,max:900})}),Vt.createElement(tt,{artifact:i(t,"payloadArtifact").artifact,excludedArtifactTypePatterns:a,expectedArtifactId:i(t,"payloadArtifact").id,label:"Payload Artifact",onArtifactEdited:e=>{n(e,"payloadArtifact")},helpKey:"",onExpectedArtifactSelected:e=>r(e.id,"payloadrtifact"),pipeline:e.pipeline,stage:t}),Vt.createElement(tt,{artifact:i(t,"outputArtifact").artifact,excludedArtifactTypePatterns:a,expectedArtifactId:i(t,"outputArtifact").id,label:"Output Artifact",onArtifactEdited:e=>{n(e,"outputArtifact")},helpKey:"",onExpectedArtifactSelected:e=>r(e.id,"outputArtifact"),pipeline:e.pipeline,stage:t}))}t(Is,[]).config(function(){De.pipeline.registerStage({provides:"rollbackCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/rollbackCluster/rollbackClusterStage.html",validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsRollbackClusterStageCtrl",["$scope",function(e){const t=this,n=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),t.reset=()=>{t.accountUpdated(),t.resetSelectedCluster()},n.regions=n.regions||[],n.cloudProvider="aws",n.targetHealthyRollbackPercentage=n.targetHealthyRollbackPercentage||100,n.isNew&&e.application.attributes.platformHealthOnlyShowOverride&&e.application.attributes.platformHealthOnly&&(n.interestingHealthProviderNames=["Amazon"]),!n.credentials&&e.application.defaultCredentials.aws&&(n.credentials=e.application.defaultCredentials.aws),!n.regions.length&&e.application.defaultRegions.aws&&n.regions.push(e.application.defaultRegions.aws),e.viewState.dynamicRollbackTimeout=a.feature.dynamicRollbackTimeout}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/rollbackCluster/rollbackClusterStage.html",'<div ng-controller="awsRollbackClusterStageCtrl as rollbackClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n\n <div class="row">\n <div class="col-sm-10 col-sm-offset-2" ng-if="stage.regions.length > 1">\n Wait\n <input\n type="number"\n min="0"\n ng-model="stage.waitTimeBetweenRegions"\n class="form-control input-sm inline-number"\n />\n seconds between regional rollbacks.\n </div>\n <div class="col-sm-10 col-sm-offset-2">\n Consider rollback successful when\n <input\n type="number"\n min="0"\n max="100"\n ng-model="stage.targetHealthyRollbackPercentage"\n class="form-control input-sm inline-number"\n />\n percent of instances are healthy.\n </div>\n <div class="col-sm-10 col-sm-offset-2" ng-if="viewState.dynamicRollbackTimeout">\n Rollback Timeout is\n <input\n type="number"\n min="0"\n max="100"\n ng-model="stage.rollbackTimeout"\n class="form-control input-sm inline-number"\n />\n minutes.\n </div>\n </div>\n</div>\n')}]);const xs=[{label:"Lambda Invocation",value:"$LAMBDA"}];function Ps(e){const{values:t}=e.formik;return Vt.createElement("div",null,Vt.createElement(s,{label:"Health Check Type",name:"healthCheckType",input:e=>Vt.createElement(c,{...e,clearable:!1,options:xs})}),t.healthCheckType?function(e,t){return"$LAMBDA"===e?Vt.createElement(As,{...t}):null}(t.healthCheckType,e):null)}const Ds=[{label:"Simple",value:"$SIMPLE",description:"Route 100% of traffic to specified version"},{label:"Weighted Deployment",value:"$WEIGHTED",description:"Split the traffic weight between two function versions."},{label:"Blue/Green",value:"$BLUEGREEN",description:"Disable all previous versions once the latest version passes health checks."}];class Bs extends Vt.Component{constructor(e){super(e);const{value:t}=this.props,a=Ds.filter(e=>e.value===t)[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Vt.createElement("div",null,Vt.createElement("b",null," ",this.state.label," "),Vt.createElement("br",null),Vt.createElement("small",null," ",this.state.description," "))}}const zs=[{label:"Newest Function Version",value:"$LATEST",description:"Selects the most recently deployed function when this stage starts."},{label:"Previous Function Version",value:"$PREVIOUS",description:"Selects the second-most recently deployed function when this stage starts."},{label:"Oldest Function Verion",value:"$OLDEST",description:"Selects the least recently deployed function when this stage starts."},{label:"Provide Version Number",value:"$PROVIDED",description:"Provide a specific version number to destroy."}];class Fs extends Vt.Component{constructor(e){super(e);const{value:t}=this.props,a=zs.filter(e=>e.value===t)[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Vt.createElement("div",null,Vt.createElement("b",null," ",this.state.label," ")," ",Vt.createElement("br",null),Vt.createElement("small",null," ",this.state.description," "))}}function Ms(e){const{values:t}=e.formik,{functions:a}=e.application;return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement(s,{label:"Target Version",name:"versionNameA",onChange:t=>{e.formik.setFieldValue("trafficPercentA",100),e.formik.setFieldValue("versionNameA",t)},input:e=>Vt.createElement(c,{...e,clearable:!1,options:zs,optionRenderer:e=>Vt.createElement(Fs,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameA?Vt.createElement(s,{label:"Version Number",name:"versionNumberA",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).filter(e=>e.functionName===t.functionName).flatMap(e=>Object.values(e.revisions).sort(function(e,t){return t-e})).filter(e=>"$LATEST"!==e)})}):null,Vt.createElement(s,{name:"trafficPercentA",label:"Traffic %",input:e=>Vt.createElement(p,{...e,min:0,max:100,value:100,disabled:!0})}))}function $s(e){const{values:t}=e.formik,{functions:a}=e.application;return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement(s,{label:"Target Version",name:"versionNameA",input:e=>Vt.createElement(c,{...e,clearable:!1,options:zs,optionRenderer:e=>Vt.createElement(Fs,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameA?Vt.createElement(s,{label:"Version Number",name:"versionNumberA",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).filter(e=>e.functionName===t.functionName).flatMap(e=>Object.values(e.revisions).sort(function(e,t){return t-e})).filter(e=>"$LATEST"!==e)})}):null,Vt.createElement(s,{name:"trafficPercentA",label:"Traffic %",input:e=>Vt.createElement(p,{...e,min:0,max:100})}),Vt.createElement(s,{label:"Version Name",name:"versionNameB",input:e=>Vt.createElement(c,{...e,clearable:!1,options:zs,optionRenderer:e=>Vt.createElement(Fs,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameB?Vt.createElement(s,{label:"Version Number",name:"versionNumberB",input:e=>Vt.createElement(c,{...e,clearable:!1,stringOptions:a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).filter(e=>e.functionName===t.functionName).flatMap(e=>Object.values(e.revisions).sort(function(e,t){return t-e})).filter(e=>"$LATEST"!==e)})}):null,Vt.createElement(s,{name:"trafficPercentB",label:"Traffic %",input:e=>Vt.createElement(p,{...e,min:0,max:100,disabled:!0,value:t.trafficPercentA||0===t.trafficPercentA?100-t.trafficPercentA:null})}))}function Ls(e){const{values:t}=e.formik;return Vt.createElement("div",{className:"form-horizontal"},t.deploymentStrategy?function(e,t){switch(e){case"$SIMPLE":return Vt.createElement(Ms,{...t});case"$WEIGHTED":return Vt.createElement($s,{...t});case"$BLUEGREEN":return Vt.createElement(Ps,{...t});default:return null}}(t.deploymentStrategy,e):null)}function Rs(e){const{values:t}=e.formik,{functions:a}=e.application,{result:r,status:i}=F(()=>o.listAccounts("aws"),[],[]),d=t.account&&t.region?a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).map(e=>e.functionName):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("h4",null," Basic Settings "),Vt.createElement(s,{label:"Account",name:"account",onChange:t=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("account",t)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map(e=>e.name)})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===i,stringOptions:r.filter(e=>e.name===t.account).flatMap(e=>e.regions).map(e=>e.name)})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:d})}),Vt.createElement(s,{label:"Alias",name:"aliasName",input:e=>Vt.createElement(l,{...e})}),Vt.createElement("h4",null," Alias Settings "),Vt.createElement(Gs,{...e}),Vt.createElement(s,{name:"provisionedConcurrentExecutions",label:"Provisioned Concurrency",help:Vt.createElement(n,{content:"To enable your function to scale without fluctuations in latency, use provisioned concurrency. Provisioned concurrency runs continually and has separate pricing for concurrency and execution duration. Concurrency cannot be provisioned with a weighted deployment strategy."}),input:e=>"$WEIGHTED"===t.deploymentStrategy?Vt.createElement(p,{...e,min:0,max:0}):Vt.createElement(p,{...e,min:0,max:3e3}),required:!1}),Vt.createElement("h4",null," Deployment Strategy "),Vt.createElement(s,{label:"Strategy",name:"deploymentStrategy",help:Vt.createElement(n,{content:""}),input:t=>Vt.createElement(c,{...t,clearable:!1,options:Ds,optionRenderer:t=>Vt.createElement(Bs,{config:e,value:t.value,showingDetails:!0})})}),t.deploymentStrategy?Vt.createElement(Ls,{...e}):null)}function Os(e){const{stage:t}=e;return Vt.createElement(Re,{name:e.name,current:e.current},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," Function Name: ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ","Deployed Alias:"," ",t.outputs["deployment:aliasDeployed"]?t.outputs["deployment:aliasDeployed"]:"N/A"," "),Vt.createElement("p",null," ","Deployed Major Version:"," ",t.outputs["deployment:majorVersionDeployed"]?t.outputs["deployment:majorVersionDeployed"]:"N/A"," ")))}function Vs(e){const t=new i(e);return t.field("triggerArns","Trigger ARNs").optional().withValidators((e,t)=>e.map(e=>Bn(e,e)).every(e=>void 0===e)?void 0:"Invalid ARN. Event ARN must match regular expression: /^arn:aws[a-zA-Z-]?:[a-zA-Z_0-9.-]+:./"),t.validateForm()}(Os||(Os={})).title="Route Lambda Traffic Stage";const Us={key:"Aws.LambdaTrafficRoutingStage",label:"AWS Lambda Route",description:"Route traffic across various versions of your Lambda function",component:function(e){return Vt.createElement("div",{className:"RouteLambdaStageConfig"},Vt.createElement(Ue,{...e,validate:Vs,onChange:e.updateStage,render:e=>Vt.createElement(Rs,{...e})}))},executionDetailsSections:[Os,Ve],validateFn:Vs},qs="spinnaker.amazon.pipeline.stage.Aws.LambdaTrafficRoutingStage";t(qs,[]).config(function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Us)});const Hs="spinnaker.amazon.pipeline.stage.scaleDownClusterStage";t(Hs,[]).config(function(){De.pipeline.registerStage({provides:"scaleDownCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/scaleDownCluster/scaleDownClusterStage.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"remainingFullSizeServerGroups",fieldLabel:"Keep [X] full size Server Groups"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}],strategy:!0})}).controller("awsScaleDownClusterStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),t.regions=t.regions||[],t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),void 0===t.remainingFullSizeServerGroups&&(t.remainingFullSizeServerGroups=1),void 0===t.allowScaleDownActive&&(t.allowScaleDownActive=!1),this.pluralize=function(e,t){return 1===t?e:e+"s"},void 0===t.preferLargerOverNewer&&(t.preferLargerOverNewer="false"),t.preferLargerOverNewer=t.preferLargerOverNewer.toString()}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/scaleDownCluster/scaleDownClusterStage.html",'<div ng-controller="awsScaleDownClusterStageCtrl as scaleDownClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Scale Down Options">\n <div class="form-inline">\n <p>\n Keep the\n <input\n type="number"\n min="0"\n required\n ng-model="stage.remainingFullSizeServerGroups"\n class="form-control input-sm"\n style="width: 50px"\n />\n <select class="form-control input-sm" ng-model="stage.preferLargerOverNewer" style="width: 100px">\n <option value="true">largest</option>\n <option value="false">newest</option>\n </select>\n {{scaleDownClusterStageCtrl.pluralize(\'server group\', stage.remainingFullSizeServerGroups)}} at current size.\n </p>\n <p>The remaining server groups will be scaled down to zero instances.</p>\n </div>\n </stage-config-field>\n <div class="form-group">\n <div class="col-md-offset-3 col-md-6 checkbox">\n <label>\n <input type="checkbox" ng-model="stage.allowScaleDownActive" />\n Allow scale down of active server groups\n </label>\n </div>\n </div>\n</div>\n')}]);const Ws="spinnaker.amazon.pipeline.stage.aws.shrinkClusterStage";t(Ws,[]).config(function(){De.pipeline.registerStage({provides:"shrinkCluster",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/shrinkCluster/shrinkClusterStage.html",accountExtractor:e=>[e.context.credentials],configAccountExtractor:e=>[e.credentials],validators:[{type:"requiredField",fieldName:"cluster"},{type:"requiredField",fieldName:"shrinkToSize",fieldLabel:"shrink to [X] Server Groups"},{type:"requiredField",fieldName:"regions"},{type:"requiredField",fieldName:"credentials",fieldLabel:"account"}]})}).controller("awsShrinkClusterStageCtrl",["$scope",function(e){const t=e.stage;e.state={accounts:!1,regionsLoaded:!1},o.listAccounts("aws").then(function(t){e.accounts=t,e.state.accounts=!0}),t.regions=t.regions||[],t.cloudProvider="aws",!t.credentials&&e.application.defaultCredentials.aws&&(t.credentials=e.application.defaultCredentials.aws),!t.regions.length&&e.application.defaultRegions.aws&&t.regions.push(e.application.defaultRegions.aws),void 0===t.shrinkToSize&&(t.shrinkToSize=1),void 0===t.allowDeleteActive&&(t.allowDeleteActive=!1),this.pluralize=function(e,t){return 1===t?e:e+"s"},void 0===t.retainLargerOverNewer&&(t.retainLargerOverNewer="false"),t.retainLargerOverNewer=t.retainLargerOverNewer.toString()}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/shrinkCluster/shrinkClusterStage.html",'<div ng-controller="awsShrinkClusterStageCtrl as shrinkClusterStageCtrl" class="form-horizontal">\n <div ng-if="!pipeline.strategy">\n <account-region-cluster-selector application="application" component="stage" accounts="accounts">\n </account-region-cluster-selector>\n </div>\n <stage-config-field label="Shrink Options">\n <div class="form-inline">\n Shrink to\n <input\n type="number"\n min="0"\n required\n ng-model="stage.shrinkToSize"\n class="form-control input-sm"\n style="width: 50px"\n />\n {{shrinkClusterStageCtrl.pluralize(\'server group\', stage.shrinkToSize)}}, keeping the\n <select class="form-control input-sm" ng-model="stage.retainLargerOverNewer" style="width: 100px">\n <option value="true">largest</option>\n <option value="false">newest</option>\n </select>\n </div>\n </stage-config-field>\n <div class="form-group">\n <div class="col-md-offset-3 col-md-6 checkbox">\n <label>\n <input type="checkbox" ng-model="stage.allowDeleteActive" />\n Allow deletion of active server groups\n </label>\n </div>\n </div>\n <stage-platform-health-override application="application" stage="stage" platform-health-type="\'Amazon\'">\n </stage-platform-health-override>\n</div>\n')}]);const js="spinnaker.amazon.pipeline.stage.tagImageStage";function Zs(e){const{values:t}=e.formik,{functions:a}=e.application,{result:r,status:i}=F(()=>o.listAccounts("aws"),[],[]),u=t.account&&t.region?a.data.filter(e=>e.account===t.account).filter(e=>e.region===t.region).map(e=>e.functionName):[];return Vt.createElement("div",{className:"form-horizontal"},Vt.createElement("h4",null," Basic Settings "),Vt.createElement(s,{label:"Account",name:"account",onChange:t=>{e.formik.setFieldValue("region",null),e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("account",t)},required:!0,input:e=>Vt.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map(e=>e.name)})}),Vt.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Vt.createElement(c,{clearable:!1,disabled:!t.account,placeholder:t.account?"Select...":"Select an Account...",...e,isLoading:"PENDING"===i,stringOptions:r.filter(e=>e.name===t.account).flatMap(e=>e.regions).map(e=>e.name)})}),Vt.createElement(s,{label:"Function Name",name:"functionName",input:e=>Vt.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:u})}),Vt.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Vt.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Vt.createElement(l,{...e,placeholder:"S3 bucket name"})}),Vt.createElement(s,{name:"s3key",label:"S3 Key",help:Vt.createElement(n,{id:"aws.function.s3key"}),input:e=>Vt.createElement(l,{...e,placeholder:"object.zip"})}),Vt.createElement(s,{name:"publish",label:"Publish",help:Vt.createElement(n,{id:"aws.function.publish"}),input:e=>Vt.createElement(d,{...e})}))}t(js,[]).config(function(){De.pipeline.registerStage({provides:"upsertImageTags",cloudProvider:"aws",templateUrl:"amazon/src/pipeline/stages/tagImage/tagImageStage.html",executionDetailsUrl:"amazon/src/pipeline/stages/tagImage/tagImageExecutionDetails.html",executionConfigSections:["tagImageConfig","taskStatus"]})}).controller("awsTagImageStageCtrl",["$scope",e=>{e.stage.tags=e.stage.tags||{},e.stage.cloudProvider=e.stage.cloudProvider||"aws";e.$watch("stage.requisiteStageRefIds",()=>{const t=at.getAllUpstreamDependencies(e.pipeline,e.stage).filter(e=>$e.IMAGE_PRODUCING_STAGES.includes(e.type));e.consideredStages=new Map(t.map(e=>[e.refId,e.name]))})}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/tagImage/tagImageStage.html",'<div ng-controller="awsTagImageStageCtrl as tagImageStageCtrl" class="form-horizontal">\n <stage-config-field label="Tags">\n <map-editor model="stage.tags" allow-empty="true"></map-editor>\n </stage-config-field>\n <stage-config-field label="Stages (optional)" help-key="aws.tagImage.consideredStages" help-key-expand="true">\n <div class="checkbox">\n <checklist model="stage.consideredStages" items="consideredStages"></checklist>\n </div>\n </stage-config-field>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/pipeline/stages/tagImage/tagImageExecutionDetails.html",'<div ng-controller="BaseExecutionDetailsCtrl">\n <execution-details-section-nav sections="configSections"></execution-details-section-nav>\n <div class="step-section-details" ng-if="detailsSection === \'tagImageConfig\'">\n <div class="row" ng-if="stage.context.targets">\n <div class="col-md-12">\n <dl class="dl-narrow dl-horizontal">\n <dt if-multiple-providers>Provider</dt>\n <dd if-multiple-providers>Amazon</dd>\n <dt>Images</dt>\n <dd ng-repeat="target in stage.context.targets">\n {{target.imageName}}<br />\n <em>{{target.regions.join(\', \')}}</em>\n </dd>\n </dl>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <dl class="dl-narrow dl-horizontal">\n <dt>Tags</dt>\n <dd ng-repeat="(key, val) in stage.context.tags" ng-if="val !== null">{{key}} = {{val}}</dd>\n <dt ng-if="stage.context.consideredStages">Stages</dt>\n <dd ng-repeat="consideredStage in stage.context.consideredStages">\n <stage-name stages="execution.stages" ref-id="consideredStage"></stage-name>\n </dd>\n </dl>\n </div>\n </div>\n\n <stage-failure-message stage="stage" message="stage.failureMessage"></stage-failure-message>\n </div>\n\n <div class="step-section-details" ng-if="detailsSection === \'taskStatus\'">\n <div class="row">\n <execution-step-details item="stage"></execution-step-details>\n </div>\n </div>\n</div>\n')}]);function _s(e){const t=new i(e);return t.field("account","Account Name").required(),t.field("region","Region").required(),t.field("functionName","Lambda Function Name").required(),t.field("s3key","S3 Object Key").required(),t.field("s3bucket","S3 Bucket Name").required().withValidators(Dn),t.validateForm()}function Ks(e){const{stage:t,current:a,name:n}=e;return Vt.createElement(Re,{name:n,current:a},Vt.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Vt.createElement("div",null,Vt.createElement("p",null," ",Vt.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Vt.createElement("p",null," ",Vt.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}Ar(""),(Ks||(Ks={})).title="Lambda Update Code Stage";const Ys={key:"Aws.LambdaUpdateCodeStage",label:"AWS Lambda Update Code",description:"Update code for a single AWS Lambda Function",component:function(e){return Vt.createElement("div",{className:"LambdaUpdateCodeConfig"},Vt.createElement(Ue,{...e,validate:_s,onChange:e.updateStage,render:e=>Vt.createElement(Zs,{...e})}))},executionDetailsSections:[Ks,Ve],validateFn:_s},Xs="spinnaker.amazon.pipeline.stage.Aws.LambdaUpdateCodeStage";t(Xs,[]).config(function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Ys)});const Js="spinnaker.amazon.react";t(Js,[]).run(["$injector",function(e){Xn.initialize(e)}]);const Qs="spinnaker.amazon.search.searchResultFormatter";t(Qs,[]).factory("awsSearchResultFormatter",function(){return{securityGroups:function(e){return Wn.getVpcName(e.vpcId).then(function(t){const a=t?e.region+" - "+t.toLowerCase():e.region;return e.name+" ("+a+")"})}}});const el="spinnaker.amazon.securityGroup.baseConfig.controller";t(el,[an,Ge]).controller("awsConfigSecurityGroupMixin",["$scope","$state","$uibModalInstance","application","securityGroup","securityGroupReader","cacheInitializer",function(e,t,a,n,r,i,s){let l;const c=this;e.self=e,e.application=n,e.customComponentIsvalid=!0,e.state={submitting:!1,regionError:void 0,refreshingSecurityGroups:!1,removedRules:[],infiniteScroll:{numToAdd:20,currentItems:20}},e.allVpcs=[],e.wizard=nt,e.hideClassic=!1,c.addMoreItems=function(){e.state.infiniteScroll.currentItems+=e.state.infiniteScroll.numToAdd};const d=()=>e.securityGroup.accountName||e.securityGroup.credentials;function u(){if(e.$$destroyed)return;a.close();const n={name:e.securityGroup.name,accountId:d(),region:e.securityGroup.regions[0],vpcId:e.securityGroup.vpcId,provider:"aws"};t.includes("**.firewallDetails")?t.go("^.firewallDetails",n):t.go(".firewallDetails",n)}function p(){e.availableSecurityGroups=[],e.existingSecurityGroupNames=[]}function m(){e.state.refreshTime=Ne.get("securityGroups").getStats().ageMax}e.taskMonitor=new v({application:n,title:`Creating your ${U.get("firewall")}`,modalInstance:a,onTaskComplete:function(){n.securityGroups.refresh(),n.securityGroups.onNextRefresh(e,u)}}),e.securityGroup=r,c.initializeAccounts=()=>o.listAllAccounts("aws").then(function(t){e.accounts=t.filter(e=>!1!==e.authorized),e.allAccounts=t,c.accountUpdated()}),c.upsert=function(){e.taskMonitor.submit(function(){return rt.upsertSecurityGroup(e.securityGroup,n,"Create")})},c.accountUpdated=function(){const t=e.securityGroup;t.account=t.accountId=t.accountName=t.credentials,o.getRegionsForAccount(d()).then(t=>{e.regions=t.map(e=>e.name),p(),c.regionUpdated(),e.state.isNew&&c.updateName()})},c.regionUpdated=function(){const t=d(),a=e.securityGroup.regions||[];Wn.listVpcs().then(function(n){const r=Ht.groupBy(n.filter(e=>e.account===t),"label");e.allVpcs=n;const i=[];Ht.forOwn(r,function(e,n){a.every(a=>e.some(e=>e.region===a&&e.account===t))&&i.push({ids:e.filter(e=>a.includes(e.region)).map(e=>e.id),label:n,deprecated:e[0].deprecated})}),e.activeVpcs=i.filter(function(e){return!e.deprecated}),e.deprecatedVpcs=i.filter(function(e){return e.deprecated}),e.vpcs=i,e.state.regionError=e.state.isClone&&(e.securityGroup.regions||[]).includes(e.state.originRegion),c.updateVpcId(i)})},this.updateVpcId=t=>{const a=kn.classicLaunchLockout;if(!r.id&&a){if(Number(Ht.get(n,"attributes.createTs",0))>=a&&(e.hideClassic=!0,!r.vpcId&&t.length)){let a;if(kn.defaults.vpc){const e=t.find(e=>e.label===kn.defaults.vpc);e&&(a=e.ids[0])}r.vpcId=a||(e.activeVpcs.length?e.activeVpcs[0].ids[0]:t[0].ids[0])}}const i=e.allVpcs.find(t=>t.id===e.securityGroup.vpcId),s=(t||[]).find(e=>i&&i.label===e.label),l=(t||[]).find(e=>kn.defaults.vpc===e.label)||(e.activeVpcs||[])[0];e.securityGroup.vpcId=s&&s.ids[0]||l&&l.ids[0],this.vpcUpdated()},this.vpcUpdated=function(){const t=d(),a=e.securityGroup.regions;t&&a.length?function(){const t=e.securityGroup.vpcId||null,a=d(),n=e.securityGroup.regions||[];let r=[],i=[];n.forEach(function(n){let s=null;if(t){const r=Ht.find(e.allVpcs,{id:t});s=Ht.find(e.allVpcs,{account:a,region:n,name:r.name}).id}const o=Ht.get(l,[a,"aws",n].join("."),[]).filter(e=>e.vpcId===s).map(e=>e.name);r=Ht.uniq(r.concat(o)),i=i.length?Ht.intersection(i,o):r}),e.availableSecurityGroups=i,e.existingSecurityGroupNames=r,e.state.securityGroupsLoaded=!0,function(){const t=e.state.removedRules,a=e.securityGroup;e.securityGroup.securityGroupIngress=(a.securityGroupIngress||[]).filter(n=>!(!n.accountName||!n.vpcId||n.accountName===a.accountName&&n.vpcId===a.vpcId)||(!(n.name&&!e.availableSecurityGroups.includes(n.name)&&!t.includes(n.name))||(t.push(n.name),!1))),t.length&&nt.markDirty("Ingress")}()}():p(),e.coordinatesChanged.next()},c.mixinUpsert=function(t){e.taskMonitor.submit(function(){return rt.upsertSecurityGroup(e.securityGroup,n,t)})},c.refreshSecurityGroups=function(){return e.state.refreshingSecurityGroups=!0,s.refreshCache("securityGroups").then(function(){return c.initializeSecurityGroups().then(function(){c.vpcUpdated(),e.state.refreshingSecurityGroups=!1,m()})})},l={},e.allSecurityGroupsUpdated=new Ta,e.coordinatesChanged=new Ta,c.initializeSecurityGroups=function(){return i.getAllSecurityGroups().then(function(t){m(),l=t;const a=e.securityGroup.credentials||e.securityGroup.accountName,n=e.securityGroup.regions[0],r=e.securityGroup.vpcId||null;let i;i=a&&n?Ht.filter(t[a].aws[n],{vpcId:r}):t,e.availableSecurityGroups=Ht.map(i,"name");const s=kn.securityGroupExclusions;e.allSecurityGroups=s?it(t,e=>!s.includes(e)):t,e.allSecurityGroupsUpdated.next(),e.state.regionError=e.state.isClone&&(e.securityGroup.regions||[]).includes(e.state.originRegion)})},c.cancel=function(){a.dismiss()};const g=/^[\x20-\x7F]+$/,h=/^[a-zA-Z0-9\s._\-:/()#,@[\]+=&;{}!$*]+$/;c.getCurrentNamePattern=function(){return e.securityGroup.vpcId?h:g},c.updateName=function(){const{securityGroup:t}=e,a=n.isStandalone?n.name.split("-")[0]:n.name,r=re.getClusterName(a,t.stack,t.detail);t.name=r,e.namePreview=r},c.namePattern={test:function(e){return c.getCurrentNamePattern().test(e)}},c.addRule=function(e){e.push({type:"tcp",startPort:7001,endPort:7001})},c.removeRule=function(e,t){e.splice(t,1)},c.updateRuleType=function(e,t,a){const n=t[a];"icmp"!==e&&"icmpv6"!==e||(n.startPort=0,n.endPort=0)},c.dismissRemovedRules=function(){e.state.removedRules=[],nt.markClean("Ingress"),nt.markComplete("Ingress")}}]);const tl="spinnaker.amazon.securityGroup.clone.controller";e.module(tl,[el]).controller("awsCloneSecurityGroupController",["$scope","$uibModalInstance","$controller","securityGroup","application",function(t,a,n,r,i){const s=this;s.firewallLabel=U.get("Firewall"),t.pages={location:"amazon/src/securityGroup/configure/createSecurityGroupProperties.html",ingress:"amazon/src/securityGroup/configure/createSecurityGroupIngress.html"},r.credentials=r.accountName,t.namePreview=r.name,e.extend(this,n("awsConfigSecurityGroupMixin",{$scope:t,$uibModalInstance:a,application:i,securityGroup:r})),t.state.isNew=!0,t.allowDuplicateNames=!0,t.state.isClone=!0,t.state.originRegion=r.regions&&r.regions[0],o.listAccounts("aws").then(function(e){t.accounts=e,s.accountUpdated()}),r.securityGroupIngress=Ht.chain(r.inboundRules).filter(function(e){return e.securityGroup}).map(function(e){return e.portRanges.map(function(t){return{name:e.securityGroup.name,type:e.protocol,startPort:t.startPort,endPort:t.endPort}})}).flatten().value(),r.ipIngress=Ht.chain(r.inboundRules).filter(function(e){return e.range}).map(function(e){return e.portRanges.map(function(t){return{cidr:e.range.ip+e.range.cidr,type:e.protocol,startPort:t.startPort,endPort:t.endPort}})}).flatten().value(),s.upsert=function(){const{credentials:e}=t.securityGroup;Object.assign(t.securityGroup,{account:e,accountName:e,accountId:e}),s.mixinUpsert("Clone")},s.initializeSecurityGroups().then(s.initializeAccounts)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupProperties.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="form-group">\n <div\n class="col-md-12 well"\n ng-class="{\'alert-danger\': form.securityGroupName.$error.validateUnique, \'alert-info\': !form.securityGroupName.$error.validateUnique}"\n >\n <strong>Your <firewall-label label="firewall"></firewall-label> will be named:</strong>\n <span ng-bind="namePreview"></span>\n <help-field key="aws.securityGroup.name"></help-field>\n <input\n type="hidden"\n class="form-control input-sm"\n ng-model="securityGroup.name"\n ng-model-options="{allowInvalid: true}"\n validate-unique="{{allowDuplicateNames ? \'\' : \'existingSecurityGroupNames\'}}"\n validate-ignore-case="true"\n name="securityGroupName"\n ng-pattern="ctrl.namePattern"\n trigger-validation="securityGroup.subnet"\n required\n />\n <validation-error\n ng-if="form.securityGroupName.$error.validateUnique && securityGroup.credentials"\n message="A {{ctrl.translate(\'firewall\')}} named \'{{namePreview}}\' already exists in one or more of the selected regions. Use a unique stack and detail to create a new {{ctrl.translate(\'firewall\')}}."\n ></validation-error>\n <validation-error\n ng-if="form.securityGroupName.$error.pattern"\n message="Name must match {{ctrl.getCurrentNamePattern().toString()}}"\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Account</div>\n <div class="col-md-8">\n <account-select-field\n component="securityGroup"\n field="credentials"\n accounts="accounts"\n provider="\'aws\'"\n on-change="ctrl.accountUpdated()"\n ></account-select-field>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Regions</div>\n <div class="col-md-8">\n <input type="hidden" ng-model="securityGroup.regions[0]" required />\n <checklist\n ng-if="securityGroup.credentials"\n items="regions"\n model="securityGroup.regions"\n inline="true"\n on-change="ctrl.regionUpdated()"\n ></checklist>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <validation-error\n ng-if="state.regionError"\n message="A security group cannot be cloned into a region it already exists in. Please deselect \'{{state.originRegion}}\' to clear this error."\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Stack</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.stack"\n ng-change="ctrl.updateName()"\n />\n </div>\n <div class="col-md-2 sm-label-right">Detail</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.detail"\n ng-change="ctrl.updateName()"\n />\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Description (required)</div>\n <div class="col-md-8">\n <textarea required cols="2" class="form-control input-sm no-spel" ng-model="securityGroup.description">\n </textarea>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">VPC <help-field key="aws.securityGroup.vpc"></help-field></div>\n <div class="col-md-8">\n <select\n class="form-control input-sm"\n ng-model="securityGroup.vpcId"\n ng-change="ctrl.vpcUpdated()"\n ng-if="securityGroup.regions.length"\n >\n <option value="" ng-if="!hideClassic">None (EC2 Classic)</option>\n <option\n ng-repeat="vpc in activeVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n <option ng-if="activeVpcs.length && deprecatedVpcs.length" disabled>---------------</option>\n <option\n ng-repeat="vpc in deprecatedVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n </select>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <p class="form-control-static" ng-if="securityGroup.credentials && !securityGroup.regions.length">\n (Select at least one region)\n </p>\n </div>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupIngress.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="row">\n <div class="col-md-12" ng-if="state.removedRules.length">\n <div class="alert alert-danger">\n <p>\n <i class="fa fa-exclamation-triangle"></i> The following\n <firewall-label label="firewalls"></firewall-label> could not be found in the selected account/region/VPC\n and were removed:\n </p>\n <ul>\n <li ng-repeat="securityGroup in state.removedRules">{{securityGroup}}</li>\n </ul>\n <p class="text-right">\n <a class="btn btn-sm btn-primary dirty-flag-dismiss" href ng-click="ctrl.dismissRemovedRules()">Okay</a>\n </p>\n </div>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <p class="info">\n <span class="glyphicon glyphicon-info-sign"></span> IP range rules can only be edited through the AWS Console.\n </p>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-12">\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 50%"><firewall-label label="Firewall"></firewall-label></th>\n <th style="width: 15%">Protocol</th>\n <th style="width: 15%">Start Port</th>\n <th style="width: 15%">End Port</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="rule in securityGroup.securityGroupIngress">\n <td>\n <ingress-rule-group-selector\n rule="rule"\n ng-if="state.securityGroupsLoaded"\n security-group="securityGroup"\n vpcs="allVpcs"\n accounts="allAccounts"\n all-security-groups="allSecurityGroups"\n coordinates-changed="coordinatesChanged"\n all-security-groups-updated="allSecurityGroupsUpdated"\n ></ingress-rule-group-selector>\n </td>\n <td>\n <select\n class="form-control input-sm"\n ng-model="rule.type"\n ng-options="protocol as protocol.toUpperCase() for protocol in [\'tcp\', \'udp\', \'icmp\', \'icmpv6\']"\n ng-change="ctrl.updateRuleType(rule.type, securityGroup.securityGroupIngress, $index)"\n required\n ></select>\n </td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.startPort" required /></td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.endPort" required /></td>\n <td>\n <a class="sm-label" ng-click="ctrl.removeRule(securityGroup.securityGroupIngress, $index)">\n <span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addRule(securityGroup.securityGroupIngress)">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new\n <firewall-label label="Firewall"></firewall-label> Rule\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n <div class="form-group small" style="margin-top: 20px">\n <div class="col-md-12">\n <p>\n <span ng-if="state.refreshingSecurityGroups"><span class="fa fa-sync-alt fa-spin"></span></span>\n <firewall-label label="Firewalls"></firewall-label>\n <span ng-if="!state.refreshingSecurityGroups">last refreshed {{ state.refreshTime | timestamp }}</span>\n <span ng-if="state.refreshingSecurityGroups"> refreshing...</span>\n </p>\n <p>\n If you\'re not finding a <firewall-label label="firewall"></firewall-label> that was recently added,\n <a href ng-click="ctrl.refreshSecurityGroups()">click here</a> to refresh the list.\n </p>\n </div>\n </div>\n <security-group-details-custom security-group-details="securityGroup" ctrl="ctrl" scope="self" />\n </div>\n</div>\n')}]);const al="spinnaker.amazon.securityGroup.create.controller";e.module(al,[an,st]).controller("awsCreateSecurityGroupCtrl",["$scope","$uibModalInstance","$state","$controller","cacheInitializer","application","securityGroup",function(t,a,n,r,i,s,l){t.pages={location:"amazon/src/securityGroup/configure/createSecurityGroupProperties.html",ingress:"amazon/src/securityGroup/configure/createSecurityGroupIngress.html"};const o=this;o.translate=e=>U.get(e),e.extend(this,r("awsConfigSecurityGroupMixin",{$scope:t,$uibModalInstance:a,application:s,securityGroup:l})),t.state.isNew=!0,o.upsert=()=>o.mixinUpsert("Create"),o.initializeSecurityGroups().then(o.initializeAccounts)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupProperties.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="form-group">\n <div\n class="col-md-12 well"\n ng-class="{\'alert-danger\': form.securityGroupName.$error.validateUnique, \'alert-info\': !form.securityGroupName.$error.validateUnique}"\n >\n <strong>Your <firewall-label label="firewall"></firewall-label> will be named:</strong>\n <span ng-bind="namePreview"></span>\n <help-field key="aws.securityGroup.name"></help-field>\n <input\n type="hidden"\n class="form-control input-sm"\n ng-model="securityGroup.name"\n ng-model-options="{allowInvalid: true}"\n validate-unique="{{allowDuplicateNames ? \'\' : \'existingSecurityGroupNames\'}}"\n validate-ignore-case="true"\n name="securityGroupName"\n ng-pattern="ctrl.namePattern"\n trigger-validation="securityGroup.subnet"\n required\n />\n <validation-error\n ng-if="form.securityGroupName.$error.validateUnique && securityGroup.credentials"\n message="A {{ctrl.translate(\'firewall\')}} named \'{{namePreview}}\' already exists in one or more of the selected regions. Use a unique stack and detail to create a new {{ctrl.translate(\'firewall\')}}."\n ></validation-error>\n <validation-error\n ng-if="form.securityGroupName.$error.pattern"\n message="Name must match {{ctrl.getCurrentNamePattern().toString()}}"\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Account</div>\n <div class="col-md-8">\n <account-select-field\n component="securityGroup"\n field="credentials"\n accounts="accounts"\n provider="\'aws\'"\n on-change="ctrl.accountUpdated()"\n ></account-select-field>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Regions</div>\n <div class="col-md-8">\n <input type="hidden" ng-model="securityGroup.regions[0]" required />\n <checklist\n ng-if="securityGroup.credentials"\n items="regions"\n model="securityGroup.regions"\n inline="true"\n on-change="ctrl.regionUpdated()"\n ></checklist>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <validation-error\n ng-if="state.regionError"\n message="A security group cannot be cloned into a region it already exists in. Please deselect \'{{state.originRegion}}\' to clear this error."\n ></validation-error>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Stack</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.stack"\n ng-change="ctrl.updateName()"\n />\n </div>\n <div class="col-md-2 sm-label-right">Detail</div>\n <div class="col-md-3">\n <input\n type="text"\n class="form-control input-sm no-spel"\n ng-model="securityGroup.detail"\n ng-change="ctrl.updateName()"\n />\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">Description (required)</div>\n <div class="col-md-8">\n <textarea required cols="2" class="form-control input-sm no-spel" ng-model="securityGroup.description">\n </textarea>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-3 sm-label-right">VPC <help-field key="aws.securityGroup.vpc"></help-field></div>\n <div class="col-md-8">\n <select\n class="form-control input-sm"\n ng-model="securityGroup.vpcId"\n ng-change="ctrl.vpcUpdated()"\n ng-if="securityGroup.regions.length"\n >\n <option value="" ng-if="!hideClassic">None (EC2 Classic)</option>\n <option\n ng-repeat="vpc in activeVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n <option ng-if="activeVpcs.length && deprecatedVpcs.length" disabled>---------------</option>\n <option\n ng-repeat="vpc in deprecatedVpcs | orderBy: \'label\'"\n value="{{vpc.ids[0]}}"\n ng-selected="securityGroup.vpcId === vpc.ids[0]"\n >\n {{vpc.label}}\n </option>\n </select>\n <p class="form-control-static" ng-if="!securityGroup.credentials">(Select an account)</p>\n <p class="form-control-static" ng-if="securityGroup.credentials && !securityGroup.regions.length">\n (Select at least one region)\n </p>\n </div>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupIngress.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="row">\n <div class="col-md-12" ng-if="state.removedRules.length">\n <div class="alert alert-danger">\n <p>\n <i class="fa fa-exclamation-triangle"></i> The following\n <firewall-label label="firewalls"></firewall-label> could not be found in the selected account/region/VPC\n and were removed:\n </p>\n <ul>\n <li ng-repeat="securityGroup in state.removedRules">{{securityGroup}}</li>\n </ul>\n <p class="text-right">\n <a class="btn btn-sm btn-primary dirty-flag-dismiss" href ng-click="ctrl.dismissRemovedRules()">Okay</a>\n </p>\n </div>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <p class="info">\n <span class="glyphicon glyphicon-info-sign"></span> IP range rules can only be edited through the AWS Console.\n </p>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-12">\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 50%"><firewall-label label="Firewall"></firewall-label></th>\n <th style="width: 15%">Protocol</th>\n <th style="width: 15%">Start Port</th>\n <th style="width: 15%">End Port</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="rule in securityGroup.securityGroupIngress">\n <td>\n <ingress-rule-group-selector\n rule="rule"\n ng-if="state.securityGroupsLoaded"\n security-group="securityGroup"\n vpcs="allVpcs"\n accounts="allAccounts"\n all-security-groups="allSecurityGroups"\n coordinates-changed="coordinatesChanged"\n all-security-groups-updated="allSecurityGroupsUpdated"\n ></ingress-rule-group-selector>\n </td>\n <td>\n <select\n class="form-control input-sm"\n ng-model="rule.type"\n ng-options="protocol as protocol.toUpperCase() for protocol in [\'tcp\', \'udp\', \'icmp\', \'icmpv6\']"\n ng-change="ctrl.updateRuleType(rule.type, securityGroup.securityGroupIngress, $index)"\n required\n ></select>\n </td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.startPort" required /></td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.endPort" required /></td>\n <td>\n <a class="sm-label" ng-click="ctrl.removeRule(securityGroup.securityGroupIngress, $index)">\n <span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addRule(securityGroup.securityGroupIngress)">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new\n <firewall-label label="Firewall"></firewall-label> Rule\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n <div class="form-group small" style="margin-top: 20px">\n <div class="col-md-12">\n <p>\n <span ng-if="state.refreshingSecurityGroups"><span class="fa fa-sync-alt fa-spin"></span></span>\n <firewall-label label="Firewalls"></firewall-label>\n <span ng-if="!state.refreshingSecurityGroups">last refreshed {{ state.refreshTime | timestamp }}</span>\n <span ng-if="state.refreshingSecurityGroups"> refreshing...</span>\n </p>\n <p>\n If you\'re not finding a <firewall-label label="firewall"></firewall-label> that was recently added,\n <a href ng-click="ctrl.refreshSecurityGroups()">click here</a> to refresh the list.\n </p>\n </div>\n </div>\n <security-group-details-custom security-group-details="securityGroup" ctrl="ctrl" scope="self" />\n </div>\n</div>\n')}]);const nl="spinnaker.amazon.securityGroup.edit.controller";e.module(nl,[an]).controller("awsEditSecurityGroupCtrl",["$scope","$uibModalInstance","$state","application","securityGroup","$controller",function(t,a,n,r,i,s){t.self=t,t.pages={ingress:"amazon/src/securityGroup/configure/createSecurityGroupIngress.html"},t.securityGroup=i,t.state={refreshingSecurityGroups:!1},t.securityGroup.regions=[t.securityGroup.region],t.securityGroup.credentials=t.securityGroup.accountName,e.extend(this,s("awsConfigSecurityGroupMixin",{$scope:t,$uibModalInstance:a,application:r,securityGroup:i})),t.state.isNew=!1,t.taskMonitor=new v({application:r,title:`Updating your ${U.get("firewall")}`,modalInstance:a,onTaskComplete:()=>r.securityGroups.refresh()}),i.securityGroupIngress=Ht.chain(i.inboundRules).filter(e=>e.securityGroup).map(e=>e.portRanges.map(t=>{const a=e.securityGroup.vpcId===i.vpcId?null:e.securityGroup.vpcId;return{accountName:e.securityGroup.accountName||e.securityGroup.accountId,accountId:e.securityGroup.accountId,vpcId:a,id:e.securityGroup.id,name:e.securityGroup.inferredName?null:e.securityGroup.name,type:e.protocol,startPort:t.startPort,endPort:t.endPort,existing:!0}})).flatten().value(),i.ipIngress=Ht.chain(i.inboundRules).filter(function(e){return e.range}).map(function(e){return e.portRanges.map(function(t){return{cidr:e.range.ip+e.range.cidr,type:e.protocol,startPort:t.startPort,endPort:t.endPort}})}).flatten().value(),this.upsert=function(){const e=t.securityGroup,a={credentials:e.accountName,name:e.name,description:e.description,vpcId:e.vpcId,region:e.region,securityGroupIngress:e.securityGroupIngress,ipIngress:e.ipIngress};t.taskMonitor.submit(function(){return rt.upsertSecurityGroup(a,r,"Update")})},this.cancel=function(){a.dismiss()},this.initializeSecurityGroups().then(this.initializeAccounts)}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroupIngress.html",'<div class="container-fluid form-horizontal">\n <div class="modal-body">\n <div class="row">\n <div class="col-md-12" ng-if="state.removedRules.length">\n <div class="alert alert-danger">\n <p>\n <i class="fa fa-exclamation-triangle"></i> The following\n <firewall-label label="firewalls"></firewall-label> could not be found in the selected account/region/VPC\n and were removed:\n </p>\n <ul>\n <li ng-repeat="securityGroup in state.removedRules">{{securityGroup}}</li>\n </ul>\n <p class="text-right">\n <a class="btn btn-sm btn-primary dirty-flag-dismiss" href ng-click="ctrl.dismissRemovedRules()">Okay</a>\n </p>\n </div>\n </div>\n </div>\n <div class="row">\n <div class="col-md-12">\n <p class="info">\n <span class="glyphicon glyphicon-info-sign"></span> IP range rules can only be edited through the AWS Console.\n </p>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-12">\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th style="width: 50%"><firewall-label label="Firewall"></firewall-label></th>\n <th style="width: 15%">Protocol</th>\n <th style="width: 15%">Start Port</th>\n <th style="width: 15%">End Port</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="rule in securityGroup.securityGroupIngress">\n <td>\n <ingress-rule-group-selector\n rule="rule"\n ng-if="state.securityGroupsLoaded"\n security-group="securityGroup"\n vpcs="allVpcs"\n accounts="allAccounts"\n all-security-groups="allSecurityGroups"\n coordinates-changed="coordinatesChanged"\n all-security-groups-updated="allSecurityGroupsUpdated"\n ></ingress-rule-group-selector>\n </td>\n <td>\n <select\n class="form-control input-sm"\n ng-model="rule.type"\n ng-options="protocol as protocol.toUpperCase() for protocol in [\'tcp\', \'udp\', \'icmp\', \'icmpv6\']"\n ng-change="ctrl.updateRuleType(rule.type, securityGroup.securityGroupIngress, $index)"\n required\n ></select>\n </td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.startPort" required /></td>\n <td><input class="form-control input-sm" type="number" min="0" ng-model="rule.endPort" required /></td>\n <td>\n <a class="sm-label" ng-click="ctrl.removeRule(securityGroup.securityGroupIngress, $index)">\n <span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addRule(securityGroup.securityGroupIngress)">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new\n <firewall-label label="Firewall"></firewall-label> Rule\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n <div class="form-group small" style="margin-top: 20px">\n <div class="col-md-12">\n <p>\n <span ng-if="state.refreshingSecurityGroups"><span class="fa fa-sync-alt fa-spin"></span></span>\n <firewall-label label="Firewalls"></firewall-label>\n <span ng-if="!state.refreshingSecurityGroups">last refreshed {{ state.refreshTime | timestamp }}</span>\n <span ng-if="state.refreshingSecurityGroups"> refreshing...</span>\n </p>\n <p>\n If you\'re not finding a <firewall-label label="firewall"></firewall-label> that was recently added,\n <a href ng-click="ctrl.refreshSecurityGroups()">click here</a> to refresh the list.\n </p>\n </div>\n </div>\n <security-group-details-custom security-group-details="securityGroup" ctrl="ctrl" scope="self" />\n </div>\n</div>\n')}]);const rl={bindings:{rule:"=",securityGroup:"=",accounts:"=",vpcs:"=",allSecurityGroups:"=",coordinatesChanged:"=",allSecurityGroupsUpdated:"="},templateUrl:"amazon/src/securityGroup/configure/ingressRuleGroupSelector.component.html",controller:class{constructor(){this.infiniteScroll={currentItems:20}}addMoreItems(){this.infiniteScroll.currentItems+=20}resetCurrentItems(){this.infiniteScroll.currentItems=20}addRegionalVpc(e){const t=e.account;this.regionalVpcs[t]||(this.regionalVpcs[t]=[]),this.regionalVpcs[t].push({name:e.name,region:e.region,account:t,id:e.id,label:e.label,deprecated:e.deprecated,cloudProvider:e.cloudProvider})}enableCrossAccount(){var e;this.rule.crossAccountEnabled=!0,this.crossAccountAccounts=this.accounts;const t=null==(e=kn)?void 0:e.crossAccountIngressExclusions[this.securityGroup.credentials];t&&Array.isArray(t)&&(this.crossAccountAccounts=this.accounts.filter(e=>!t.includes(e.name))),this.rule.accountName=this.securityGroup.credentials,this.rule.vpcId=this.securityGroup.vpcId}disableCrossAccount(){this.rule.crossAccountEnabled=!1,this.rule.accountName=void 0,this.rule.vpcId=void 0}$onInit(){this.setAvailableSecurityGroups(),this.coordinatesChangedListener=this.coordinatesChanged.subscribe(()=>this.setAvailableSecurityGroups()),this.securityGroupsUpdatedListener=this.allSecurityGroupsUpdated.subscribe(()=>this.setAvailableSecurityGroups())}$onDestroy(){this.coordinatesChangedListener.unsubscribe(),this.securityGroupsUpdatedListener.unsubscribe()}setAvailableSecurityGroups(){const e=this.rule.accountName||this.securityGroup.credentials,t=this.securityGroup.regions,a=this.rule.vpcId||this.securityGroup.vpcId||null;let n=[],r=[];t.length>1&&this.disableCrossAccount(),t.forEach(t=>{var i,s,l,o;let c=null;if(a){const n=this.vpcs.find(e=>e.id===a),r=this.vpcs.find(a=>a.account===e&&a.region===t&&a.name===n.name);c=r?r.id:void 0}const d=(null!=(o=null==(l=null==(s=null==(i=this.allSecurityGroups)?void 0:i[e])?void 0:s.aws)?void 0:l[t])?o:[]).filter(e=>e.vpcId===c).map(e=>e.name);n=sa(n.concat(d)),r=r.length?va(r,d):n}),1===t.length&&this.configureAvailableVpcs(),this.availableSecurityGroups=r,r.includes(this.rule.name)||this.rule.existing||(this.rule.name=null)}configureAvailableVpcs(){const e=this.securityGroup.regions[0],t=this.vpcs.filter(t=>t.region===e);this.regionalVpcs={},t.forEach(e=>this.addRegionalVpc(e)),this.reconcileRuleVpc(t)}reconcileRuleVpc(e){if(this.rule.vpcId&&!this.rule.existing){if(!this.securityGroup.vpcId)return this.rule.vpcId=null,void(this.rule.name=null);const t=e.find(e=>e.id===this.rule.vpcId),a=e.find(e=>e.account===this.rule.accountName&&e.name===t.name);a?this.rule.vpcId=a.id:(this.rule.vpcId=null,this.rule.name=null)}}}},il="spinnaker.amazon.securityGroup.configure.ingressRuleGroupSelector";t(il,[]).component("ingressRuleGroupSelector",rl),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/ingressRuleGroupSelector.component.html",'<span class="form-control-static" ng-if="$ctrl.rule.existing">\n <account-tag\n account="$ctrl.rule.accountName"\n ng-if="$ctrl.rule.accountName !== $ctrl.securityGroup.accountName"\n ></account-tag>\n {{ $ctrl.rule.name || $ctrl.rule.id }}\n</span>\n\n<div ng-if="$ctrl.rule.crossAccountEnabled && $ctrl.securityGroup.regions.length === 1" class="cross-account-select">\n <div class="row">\n <div class="col-md-3"><span class="small">Account</span></div>\n <div class="col-md-9">\n <account-select-field\n component="$ctrl.rule"\n field="accountName"\n accounts="$ctrl.crossAccountAccounts"\n provider="\'aws\'"\n on-change="$ctrl.setAvailableSecurityGroups()"\n ></account-select-field>\n </div>\n </div>\n <div class="row" ng-if="$ctrl.securityGroup.vpcId">\n <div class="col-md-3"><span class="small">VPC</span></div>\n <div class="col-md-9">\n <select class="form-control input-sm" ng-model="$ctrl.rule.vpcId" ng-change="$ctrl.setAvailableSecurityGroups()">\n <option\n ng-repeat="vpc in $ctrl.regionalVpcs[$ctrl.rule.accountName]"\n value="{{ vpc.id }}"\n ng-selected="$ctrl.rule.vpcId === vpc.id"\n >\n {{ vpc.label }}\n </option>\n </select>\n </div>\n </div>\n</div>\n\n<div class="row">\n <div class="col-md-3">\n <span class="small" ng-if="$ctrl.rule.crossAccountEnabled">Group</span>\n </div>\n <div class="col-md-{{ $ctrl.rule.crossAccountEnabled ? 9 : 12 }}">\n <ui-select\n ng-if="!$ctrl.rule.existing"\n ng-model="$ctrl.rule.name"\n uis-open-close="$ctrl.resetCurrentItems()"\n class="form-control input-sm"\n required\n style="width: 100%"\n >\n <ui-select-match>{{ $select.selected }}</ui-select-match>\n <ui-select-choices\n repeat="securityGroup as securityGroup in $ctrl.availableSecurityGroups | filter: $select.search | limitTo: $ctrl.infiniteScroll.currentItems"\n infinite-scroll="$ctrl.addMoreItems()"\n infinite-scroll-distance="4"\n >\n <span ng-bind-html="securityGroup | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n</div>\n\n<a\n href\n class="small"\n ng-if="!$ctrl.rule.existing && $ctrl.securityGroup.regions.length === 1 && !$ctrl.rule.crossAccountEnabled"\n ng-click="$ctrl.enableCrossAccount($index)"\n>\n Select from a different account <span ng-if="$ctrl.securityGroup.vpcId">or VPC</span>\n</a>\n\n<div ng-if="$ctrl.crossAccountAccounts && $ctrl.crossAccountAccounts.length !== $ctrl.accounts.length">\n <help-field key="aws.securityGroup.cross.account.ingress.help" expand="true"></help-field>\n</div>\n<span ng-if="$ctrl.securityGroup.regions.length > 1" class="small">\n Cross-account rules disabled when 2+ regions selected\n</span>\n')}]);var sl=Object.getOwnPropertyDescriptor;let ll=class extends Vt.Component{render(){return null}};ll=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?sl(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("aws.securityGroup.details.custom")],ll);const ol="spinnaker.amazon.securityGroups.details.custom.component";t(ol,[]).component("securityGroupDetailsCustom",Ja(L(ll,"securityGroupDetailsCustom"),["securityGroupDetails","ctrl","scope"]));const cl="spinnaker.amazon.securityGroup.details.controller";e.module(cl,[an,Ge,tl,xe]).controller("awsSecurityGroupDetailsCtrl",["$scope","$state","resolvedSecurityGroup","app","securityGroupReader","$uibModal",function(t,a,n,r,i,s){this.application=r;const l=r,o=n;function c(){return i.getSecurityGroupDetails(l,o.accountId,o.provider,o.region,o.vpcId,o.name).then(function(e){return Wn.getVpcName(e.vpcId).then(t=>(e.vpcName=t,e))}).then(function(a){if(t.state.loading=!1,!a||Ht.isEmpty(a))u();else{const n=i.getApplicationSecurityGroup(l,o.accountId,o.region,o.name);e.extend(o,n,a),t.securityGroup=o,t.ipRules=function(e){const t=Ht.groupBy(e.ipRangeRules,e=>e.range.ip+e.range.cidr);return Object.keys(t).map(e=>({address:e,rules:d(t,e)})).filter(e=>e.rules.length)}(o),t.securityGroupRules=function(e){const t=Ht.groupBy(e.securityGroupRules,e=>e.securityGroup.id);return Object.keys(t).map(e=>({securityGroup:t[e][0].securityGroup,rules:d(t,e)})).filter(e=>e.rules.length)}(o)}},u)}function d(e,t){const a=[];return e[t].forEach(e=>{(e.portRanges||[]).forEach(t=>{("-1"===e.protocol||void 0!==t.startPort&&void 0!==t.endPort)&&a.push({startPort:t.startPort,endPort:t.endPort,protocol:e.protocol,description:e.description})})}),a}function u(){t.$$destroyed||(r.isStandalone?(t.group=o.name,t.state.notFound=!0,t.state.loading=!1,q.removeLastItem("securityGroups")):a.go("^",{allowModalToStayOpen:!0},{location:"replace"}))}this.firewallLabel=U.get("Firewall"),t.detailsTemplateUrl=V.getValue("aws","securityGroup.detailsTemplateUrl"),t.isDisabled=!kn.adHocInfraWritesEnabled,t.state={loading:!0,standalone:r.isStandalone},c().then(()=>{t.$$destroyed||r.isStandalone||r.securityGroups.onRefresh(t,c)}),this.editInboundRules=function(){lt(t.securityGroup,l).then(a=>new Promise(e=>setTimeout(e,500)).then(()=>{a&&s.open({templateUrl:"amazon/src/securityGroup/configure/editSecurityGroup.html",controller:"awsEditSecurityGroupCtrl as ctrl",size:"lg",resolve:{securityGroup:function(){return e.copy(t.securityGroup)},application:function(){return l}}})}))},this.cloneSecurityGroup=function(){s.open({templateUrl:"amazon/src/securityGroup/clone/cloneSecurityGroup.html",controller:"awsCloneSecurityGroupController as ctrl",size:"lg",resolve:{securityGroup:function(){const a=e.copy(t.securityGroup);return a.region&&(a.regions=[a.region]),a},application:function(){return l}}})},this.deleteSecurityGroup=function(){let e=!1;const a={removeDependencies:!0},n={application:l,title:"Deleting "+o.name,onTaskRetry:()=>{e=!0}},r=()=>{const t={cloudProvider:o.provider,vpcId:o.vpcId};return e&&Object.assign(t,a),rt.deleteSecurityGroup(o,l,t)};lt(t.securityGroup,l).then(e=>{e&&S.confirm({header:"Really delete "+o.name+"?",buttonText:"Delete "+o.name,account:o.accountId,taskMonitorConfig:n,submitMethod:r,retryBody:`<div><p>Retry deleting the ${U.get("firewall")} and revoke any dependent ingress rules?</p><p>Any instance or load balancer associations will have to removed manually.</p></div>`})})},r.isStandalone&&(r.securityGroups={refresh:c})}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/editSecurityGroup.html",'<ng-form role="form" name="form" novalidate>\n <v2-modal-wizard\n heading="Edit {{securityGroup.name}}: {{securityGroup.region}}: {{securityGroup.accountName}}"\n task-monitor="taskMonitor"\n dismiss="$dismiss()"\n >\n <v2-wizard-page key="Ingress" label="Ingress" done="true">\n <ng-include src="pages.ingress"></ng-include>\n </v2-wizard-page>\n </v2-modal-wizard>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <submit-button\n is-disabled="form.$invalid || !wizard.isComplete() || state.submitting || !customComponentIsvalid"\n submitting="state.submitting"\n on-click="ctrl.upsert()"\n is-new="state.isNew"\n ></submit-button>\n </div>\n</ng-form>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/clone/cloneSecurityGroup.html",'<ng-form role="form" name="form" novalidate>\n <v2-modal-wizard heading="Clone {{ctrl.firewallLabel}}" task-monitor="taskMonitor" dismiss="$dismiss()">\n <v2-wizard-page key="Location" label="Location">\n <ng-include src="pages.location"></ng-include>\n </v2-wizard-page>\n <v2-wizard-page key="Ingress" label="Ingress" done="true" mark-clean-on-view="false">\n <ng-include src="pages.ingress"></ng-include>\n </v2-wizard-page>\n </v2-modal-wizard>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <submit-button\n is-disabled="form.$invalid || !wizard.isComplete() || state.submitting || state.removedRules.length > 0 || !customComponentIsvalid || state.regionError"\n submitting="state.submitting"\n on-click="ctrl.upsert()"\n is-new="isNew"\n ></submit-button>\n </div>\n</ng-form>\n')}]);var dl=Object.getOwnPropertyDescriptor;let ul=class extends Vt.Component{render(){const e=this.props.ipRules||[],t=`IP Range Rules (${e.length})`;return Vt.createElement(x,{heading:t},e.map(e=>Vt.createElement(W,{className:"horizontal-when-filters-collapsed"},Vt.createElement(B,{label:"IP Range",value:e.address}),Vt.createElement(B,{label:"Port Ranges",value:e.rules.map(t=>"-1"===t.protocol?Vt.createElement("span",null,"All ports and protocols",e.rules.length>1?Vt.createElement("div",null,Vt.createElement("em",null,"Additional port ranges are specified, but redundant:")):null):Vt.createElement("div",null,Vt.createElement("span",null,t.protocol,":",t.startPort," → ",t.endPort)))}))))}};ul=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?dl(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("aws.securityGroup.ip.rules")],ul);const pl="spinnaker.amazon.securityGroups.details.securityGroups.component";t(pl,[]).component("ipRangeRules",Ja(L(ul,"ipRangeRules"),["ipRules"]));class ml{resolveIndexedSecurityGroup(e,t,a){return ml.resolveIndexedSecurityGroup(e,t,a)}static resolveIndexedSecurityGroup(e,t,a){return e[t.account][t.region][a]}}const gl="spinnaker.amazon.securityGroup.reader";t(gl,[]).service("awsSecurityGroupReader",ml);const hl="spinnaker.amazon.securityGroup.transformer";t(hl,[]).factory("awsSecurityGroupTransformer",function(){return{normalizeSecurityGroup:function(e){return Wn.listVpcs().then(function(e){return function(t){const a=t.filter(function(t){return t.id===e.vpcId});e.vpcName=a.length?a[0].name:""}}(e))},compress:function(e){const t=ra(e,"vpcId");return Object.keys(t).forEach(e=>{t[e]=t[e].map(e=>[e.name,e.id])}),t},decompress:function(e){const t=[];return Object.keys(e).forEach(a=>{e[a].forEach(e=>{t.push({name:e[0],id:e[1],vpcId:a})})}),t},supportsCompression:!0}});const fl="spinnaker.amazon.securityGroup";t(fl,[gl,tl,il,el,al,nl,cl,hl,pl,ol]);class vl extends Vt.Component{constructor(e){super(e),this.state={templateSelectionText:{copied:["account, region, subnet, cluster name (stack, details)","load balancers",U.get("firewalls"),"instance type","all fields on the Advanced Settings page"],notCopied:["the following suspended scaling processes: Launch, Terminate, AddToLoadBalancer"],additionalCopyText:"If a server group exists in this cluster at the time of deployment, its scaling policies will be copied over to the new server group."}},e.command.viewState.disableStrategySelection||this.state.templateSelectionText.notCopied.push("the deployment strategy (if any) used to deploy the most recent server group")}render(){const{app:e,command:t,onDismiss:a,onTemplateSelected:n}=this.props,{templateSelectionText:r}=this.state;return Vt.createElement(ot,{cloudProvider:"aws",application:e,command:t,onDismiss:a,onTemplateSelected:n,templateSelectionText:r})}}class yl extends Vt.Component{constructor(){super(...arguments),this.state={errorMessage:null,selectionMode:"packageImages",searchString:"",searchResults:null,isSearching:!1,packageImages:null,isLoadingPackageImages:!0},this.awsImageReader=new ar,this.props$=new Ta,this.searchInput$=new Ta,this.destroy$=new Ta,this.sortImagesBy$=new Aa("ts"),this.buildImageMenu=e=>{const{ImageMenuHeading:t,ImageLabel:a}=this,{options:n}=e;return Vt.createElement("div",{className:"Select-menu-outer"},Vt.createElement("div",{className:"Select-menu",role:"listbox"},n.length>0&&Vt.createElement(t,null),n.map(t=>Vt.createElement(a,{key:t.imageName,option:t,params:e}))))},this.ImageMenuHeading=()=>{const e=this.sortImagesBy$.value;return Vt.createElement("div",{className:"sp-padding-s-xaxis sp-padding-xs-yaxis small",style:{borderBottom:"1px solid var(--color-silver)",position:"sticky",top:0,backgroundColor:"var(--color-white)"}},Vt.createElement("b",null,"Sort by: "),Vt.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("ts")},"ts"===e?Vt.createElement("b",null,"timestamp (newest first)"):"timestamp (newest first)"),Vt.createElement("span",null," | "),Vt.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("name")},"name"===e?Vt.createElement("b",null,"name (A-Z)"):"name (A-Z)"))},this.ImageLabel=e=>{const{credentials:t,region:a}=this.props,{option:n,params:r}=e,i=n.amis[a]&&n.amis[a][0]?n.amis[a][0]:` - not found in ${t}/${a}`;return Vt.createElement("div",{key:n.imageName,onClick:()=>r.selectValue(n),onMouseOver:()=>r.focusOption(n),className:"Select-option "+(r.focusedOption&&r.focusedOption.imageName===n.imageName?"is-focused":""),role:"option"},Vt.createElement("div",null,n.imageName),Vt.createElement("div",{className:"small"},Vt.createElement("b",null,"Created: "),n.attributes.creationDate,Vt.createElement("b",{className:"sp-padding-s-left"},"AMI: "),i))}}static makeFakeImage(e,t,a){if(!e&&!t)return null;return{imageName:e,amis:{[a]:[t]},attributes:{virtualizationType:"*",architecture:"*",creationDate:(new Date).toISOString()}}}loadImagesFromApplicationName(e){const t=e.name.replace(/_/g,"[_\\-]")+"*";return this.awsImageReader.findImages({q:t})}buildQueryForSimilarImages(e){let t=!1,a=e.split("_")[0];const n=a.split("-");n.length>3&&(a=n.slice(0,-3).join("-"),t=!0);return!a||a.length<3?null:a+(t?"-*":"*")}loadImageById(e,t,a){return e?this.awsImageReader.getImage(e,t,a).catch(()=>null):Xa.when(null)}searchForImages(e){return e&&e.length>=3?this.awsImageReader.findImages({q:e}):Xa.when([])}fetchPackageImages(e,t,a,n){const r=e&&e.amis&&e.amis[t]&&e.amis[t][0];return this.loadImageById(r,t,a).then(e=>e?this.searchForImages(this.buildQueryForSimilarImages(e.imageName)).then(t=>t.find(t=>t.imageName===e.imageName)?t:t.concat(e)):this.loadImagesFromApplicationName(n))}selectImage(e){this.props.value!==e&&this.props.onChange(e)}findMatchingImage(e,t){return e.find(e=>t&&t.imageName===e.imageName)}componentDidMount(){const e=this.props$.pipe(Da(e=>e.region),Ba()),{value:t,region:a,credentials:n,application:r}=this.props;this.setState({isLoadingPackageImages:!0});const i=this.fetchPackageImages(t,a,n,r),s=Ia(i).pipe(Oa(e=>(console.error(e),this.setState({errorMessage:"Unable to load package images"}),xa([]))),La(()=>this.setState({isLoadingPackageImages:!1}))),l=Ga([s,e,this.sortImagesBy$]).pipe(Da(([e,t,a])=>{const n=e.filter(e=>!!e.amis[t]);return this.sortImages(n,a)})),o=this.searchInput$.pipe(La(e=>this.setState({searchString:e})),Ba(),Va(250)).pipe(La(()=>this.setState({isSearching:!0})),Fa(e=>this.searchForImages(e)),Oa(e=>(console.error(e),this.setState({errorMessage:"Unable to search for images"}),xa([]))),La(()=>this.setState({isSearching:!1})));Ga([o,e,this.sortImagesBy$]).pipe(Da(([e,t,a])=>{const{searchString:n}=this.state;if(0===e.length&&/ami-[0-9a-f]{8,17}/.exec(n)){return[yl.makeFakeImage(n,n,t)].filter(e=>!!e)}const r=e.filter(e=>!!e.amis[t]);return this.sortImages(r,a)})).pipe($a(this.destroy$)).subscribe(e=>this.setState({searchResults:e})),l.pipe($a(this.destroy$)).subscribe(e=>{this.setState({packageImages:e}),this.selectImage(this.findMatchingImage(e,this.props.value))}),e.pipe(Fa(e=>{const t=this.props.value;if("packageImages"===this.state.selectionMode)return l.pipe(Da(e=>this.findMatchingImage(e,t)));{const a=!!(t&&t.amis&&t.amis[e]);return xa(a?t:void 0)}}),$a(this.destroy$)).subscribe(e=>this.selectImage(e))}setSortImagesBy(e){this.sortImagesBy$.next(e)}sortImages(e,t){return e.slice().sort((e,a)=>"ts"===t?a.attributes.creationDate.localeCompare(e.attributes.creationDate):e.imageName.localeCompare(a.imageName))}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}render(){const{value:e,credentials:t,region:a,onChange:r}=this.props,{isLoadingPackageImages:i,isSearching:s,selectionMode:l,packageImages:o,searchResults:c,searchString:d}=this.state,u=!!o,p=e=>{const n=e.amis||{},r=n[a]&&n[a][0],i=r?`(${r})`:` - not found in ${t}/${a}`;return Vt.createElement(Vt.Fragment,null,Vt.createElement("span",null,e.imageName),Vt.createElement("span",null,i))},m={clearable:!1,required:!0,valueKey:"imageName",optionRenderer:p,valueRenderer:p,onSelectResetsInput:!1,onBlurResetsInput:!1,onCloseResetsInput:!1,value:e},g=this.state.errorMessage?Vt.createElement(pe,{message:this.state.errorMessage,type:"error"}):null,h=`No results found in ${t}/${a}`;if("searchAllImages"===l){const e=!d||d.length<3?"Please enter at least 3 characters":s?"Searching...":h;return Vt.createElement("div",{className:"col-md-9"},Vt.createElement(f,{...m,menuRenderer:this.buildImageMenu,isLoading:s,placeholder:"Search for an image...",filterOptions:!1,noResultsText:e,options:c,onInputChange:e=>(this.searchInput$.next(e),e),onChange:r}),g)}return u?Vt.createElement("div",{className:"col-md-9"},Vt.createElement(f,{...m,menuRenderer:this.buildImageMenu,isLoading:i,placeholder:"Pick an image",noResultsText:h,options:o,onChange:r}),g,Vt.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Vt.createElement(n,{id:"aws.serverGroup.allImages"})):Vt.createElement("div",{className:"col-md-9"},Vt.createElement(f,{...m,isLoading:i,disabled:!0,options:[e].filter(e=>!!e)}),g,Vt.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Vt.createElement(n,{id:"aws.serverGroup.allImages"}))}}const bl=e=>e&&e.includes("${");class El extends Vt.Component{constructor(e){super(e),this.imageChanged=e=>{var t,n;const{setFieldValue:r,values:i}=this.props.formik;this.setState({selectedImage:e});const s=e&&e.attributes.virtualizationType,l=e&&e.attributes.architecture,o=e&&e.imageName;if(i.virtualizationType=s,i.amiArchitecture=l,i.amiName=o,r("amiArchitecture",l),r("virtualizationType",s),r("amiName",o),i.imageChanged(i),e&&(null==(t=a.disabledImages)?void 0:t.length)&&(null==(n=kn.serverGroups)?void 0:n.enableIPv6)){a.disabledImages.some(t=>e.imageName.includes(t))&&r("associateIPv6Address",!1)}this.props.formik.validateForm()},this.accountUpdated=e=>{var t,a,n,r,i,s,l,o,c,d,u;const{setFieldValue:p,values:m}=this.props.formik;m.credentials=e,m.credentialsChanged(m),m.subnetChanged(m),p("credentials",e);const g=m.backingData.credentialsKeyedByAccount[e];if(p("associateIPv6Address",(null==(a=null==(t=kn)?void 0:t.serverGroups)?void 0:a.enableIPv6)&&(null==(r=null==(n=kn)?void 0:n.serverGroups)?void 0:r.setIPv6InTest)&&"test"===g.environment),null==(i=kn.serverGroups)?void 0:i.enableIMDSv2){const t=!(null==(o=null==(l=null==(s=kn)?void 0:s.serverGroups)?void 0:l.accountDenyListIMDSv2)?void 0:o.includes(e)),a=null==(c=kn.serverGroups)?void 0:c.defaultIMDSv2AppAgeLimit,n=null==(u=null==(d=this.props.app)?void 0:d.attributes)?void 0:u.createTs;p("requireIMDSv2",t&&a&&n&&Number(n)>a)}},this.regionUpdated=e=>{const{values:t,setFieldValue:a}=this.props.formik;t.region=e,t.regionChanged(t),a("region",e)},this.subnetUpdated=()=>{const{setFieldValue:e,values:t}=this.props.formik;t.subnetChanged(t),e("subnetType",t.subnetType)},this.clientRequestsChanged=()=>{const{values:e,setFieldValue:t}=this.props.formik;e.toggleSuspendedProcess(e,"AddToLoadBalancer"),t("suspendedProcesses",e.suspendedProcesses),this.setState({})},this.navigateToLatestServerGroup=()=>{const{values:e}=this.props.formik,{latestServerGroup:t}=this.state,a={provider:e.selectedProvider,accountId:t.account,region:t.region,serverGroup:t.name},{$state:n}=h;n.is("home.applications.application.insight.clusters")?n.go(".serverGroup",a):n.go("^.serverGroup",a)},this.stackChanged=e=>{const{setFieldValue:t,values:a}=this.props.formik;a.stack=e,t("stack",e),a.clusterChanged(a)},this.handleReasonChanged=e=>{this.props.formik.setFieldValue("reason",e)},this.strategyChanged=(e,t)=>{e.onStrategyChange(e,t),this.props.formik.setFieldValue("strategy",t.key)},this.onStrategyFieldChange=(e,t)=>{this.props.formik.setFieldValue(e,t)};const{amiName:t,region:n,viewState:{imageId:r}}=e.formik.values,i=yl.makeFakeImage(t,r,n);this.state={...this.getStateFromProps(e),selectedImage:i}}getStateFromProps(e){const{app:t}=e,{values:a}=e.formik,n=re.getClusterName(t.name,a.stack,a.freeFormDetails),r=!t.clusters.find(e=>e.name===n),i=t.serverGroups.data.filter(e=>e.cluster===n&&e.account===a.credentials&&e.region===a.region).sort((e,t)=>e.createdTime-t.createdTime),s=i.length?i.pop():null;return{namePreview:n,createsNewCluster:r,latestServerGroup:s}}validate(e){const t={};var a,n;return a=e.stack,bl(a)||/^([a-zA-Z_0-9._${}]*(\${.+})*)*$/.test(a)||(t.stack="Only dot(.) and underscore(_) special characters are allowed in the Stack field."),n=e.freeFormDetails,bl(n)||/^([a-zA-Z_0-9._${}-]*(\${.+})*)*$/.test(n)||(t.freeFormDetails="Only dot(.), underscore(_), and dash(-) special characters are allowed in the Detail field."),e.viewState.disableImageSelection||e.amiName||(t.amiName="Image required."),e.resourceSummary&&(t.resourceSummary={id:"Cluster is managed"}),t}componentWillReceiveProps(e){this.setState(this.getStateFromProps(e))}render(){const{app:e,formik:t}=this.props,{errors:a,values:r}=t,{createsNewCluster:i,latestServerGroup:s,namePreview:l}=this.state,o=r.backingData.accounts,c=r.viewState.readOnlyFields||{};return Vt.createElement("div",{className:"container-fluid form-horizontal"},r.regionIsDeprecated(r)&&Vt.createElement("div",{className:"form-group row"},Vt.createElement("div",{className:"col-md-12 error-message"},Vt.createElement("div",{className:"alert alert-danger"},"You are deploying into a deprecated region within the ",r.credentials," account!"))),Vt.createElement(ct,{app:e,formik:t}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Vt.createElement("div",{className:"col-md-7"},Vt.createElement(Se,{value:r.credentials,onChange:e=>this.accountUpdated(e.target.value),readOnly:c.credentials,accounts:o,provider:"aws"}))),Vt.createElement(ke,{readOnly:c.region,labelColumns:3,component:r,field:"region",account:r.credentials,regions:r.backingData.filtered.regions,onChange:this.regionUpdated}),Vt.createElement(si,{readOnly:c.subnet,labelColumns:3,helpKey:"aws.serverGroup.subnet",component:r,field:"subnetType",region:r.region,application:e,subnets:r.backingData.filtered.subnetPurposes,onChange:this.subnetUpdated,showSubnetWarning:!0}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Vt.createElement(n,{id:"aws.serverGroup.stack"})),Vt.createElement("div",{className:"col-md-7"},Vt.createElement("input",{type:"text",className:"form-control input-sm no-spel",value:r.stack,onChange:e=>this.stackChanged(e.target.value)}))),a.stack&&Vt.createElement("div",{className:"form-group row slide-in"},Vt.createElement("div",{className:"col-sm-9 col-sm-offset-2 error-message"},Vt.createElement("span",null,a.stack))),Vt.createElement(dt,{app:e,formik:t}),r.viewState.imageSourceText&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Image Source"),Vt.createElement("div",{className:"col-md-7",style:{marginTop:"5px"}},Vt.createElement(Ce,{tag:"span",message:r.viewState.imageSourceText}))),!r.viewState.disableImageSelection&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Image ",Vt.createElement(n,{id:"aws.serverGroup.imageName"})),bl(r.amiName)?Vt.createElement(un,{name:"amiName"}):Vt.createElement(yl,{onChange:e=>this.imageChanged(e),value:this.state.selectedImage,application:e,credentials:r.credentials,region:r.region})),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Traffic ",Vt.createElement(n,{id:"aws.serverGroup.traffic"})),Vt.createElement("div",{className:"col-md-9 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",onChange:this.clientRequestsChanged,checked:!r.processIsSuspended(r,"AddToLoadBalancer"),disabled:""!==r.strategy&&"custom"!==r.strategy}),"Send client requests to new instances"))),!r.viewState.disableStrategySelection&&r.selectedProvider&&Vt.createElement(ut,{command:r,onFieldChange:this.onStrategyFieldChange,onStrategyChange:this.strategyChanged}),!r.viewState.hideClusterNamePreview&&Vt.createElement(pt,{createsNewCluster:i,latestServerGroupName:null==s?void 0:s.name,mode:r.viewState.mode,namePreview:l,navigateToLatestServerGroup:this.navigateToLatestServerGroup}),Vt.createElement(mt,{reason:r.reason,onChange:this.handleReasonChanged}))}}class wl extends Vt.Component{constructor(){super(...arguments),this.preferSourceCapacityOptions=[{label:"fail the stage",value:!1},{label:"use fallback values",value:!0}],this.useSourceCapacityUpdated=e=>{const t="true"===e.target.value,{command:a}=this.props;this.props.setFieldValue("useSourceCapacity",t),t||(delete a.preferSourceCapacity,this.props.setFieldValue("preferSourceCapacity",void 0)),this.setState({})},this.simpleInstancesChanged=e=>{this.setMinMax(e)},this.preferSourceCapacityChanged=e=>{this.props.setFieldValue("preferSourceCapacity",!(!e||!e.value)||void 0),this.setState({})},this.capacityFieldChanged=(e,t)=>{const{command:a,setFieldValue:n}=this.props;a.capacity={...a.capacity},a.capacity[e]=t,n("capacity",a.capacity)}}setSimpleCapacity(e){const{command:t}=this.props,a={...t.viewState,useSimpleCapacity:e};this.props.setFieldValue("useSourceCapacity",!1),this.props.setFieldValue("viewState",a),this.setMinMax(t.capacity.desired),this.setState({})}setMinMax(e){const{command:t}=this.props;t.viewState.useSimpleCapacity&&(t.capacity={min:e,max:e,desired:e},this.props.setFieldValue("useSourceCapacity",!1),this.props.setFieldValue("capacity",t.capacity)),this.setState({})}render(){const{command:e,MinMaxDesired:t}=this.props,a=e.viewState.readOnlyFields||{};return!e.viewState.useSimpleCapacity||e.useSourceCapacity?Vt.createElement("div",null,Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("p",null,"Sets up auto-scaling constraints for this server group."),Vt.createElement("p",null,"To set min, max, and desired instance counts to the same value use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!0)},"Simple Mode"),"."))),!a.useSourceCapacity&&"editPipeline"===e.viewState.mode&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Capacity"),Vt.createElement("div",{className:"col-md-9 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:e.useSourceCapacity,value:"true",id:"useSourceCapacityTrue",onChange:this.useSourceCapacityUpdated}),"Copy the capacity from the current server group",Vt.createElement(n,{id:"serverGroupCapacity.useSourceCapacityTrue"}))),e.useSourceCapacity&&Vt.createElement("div",{className:"col-md-9 col-md-offset-3 radio",style:{paddingLeft:"35px"}},Vt.createElement("div",null,"If no current server group is found,",Vt.createElement(rn,{clearable:!1,value:!!e.preferSourceCapacity,options:this.preferSourceCapacityOptions,onChange:this.preferSourceCapacityChanged})),e.preferSourceCapacity&&Vt.createElement("div",null,Vt.createElement("b",null,"Fallback values"),Vt.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged}))),Vt.createElement("div",{className:"col-md-9 col-md-offset-3 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:!e.useSourceCapacity,value:"false",id:"useSourceCapacityFalse",onChange:this.useSourceCapacityUpdated}),"Let me specify the capacity",Vt.createElement(n,{id:"serverGroupCapacity.useSourceCapacityFalse"})))),(!e.useSourceCapacity||"editPipeline"!==e.viewState.mode)&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-9 col-md-offset-3"},Vt.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged})))):Vt.createElement("div",null,Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("p",null,"Sets the min, max, and desired instance counts to the same value."),Vt.createElement("p",null," ","To set capacity for auto-scaling, use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!1)},"Advanced Mode"),"."))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Number of Instances"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:e.capacity.desired,min:0,onChange:this.simpleInstancesChanged}))))}}class Cl extends Vt.Component{render(){const{command:{capacity:{min:e,max:t,desired:a}},fieldChanged:n}=this.props;return Vt.createElement("div",null,Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-2"},"Min"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:e,min:0,max:"number"==typeof t?t:void 0,onChange:e=>n("min",e),required:!0}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-2"},"Max"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:t,min:"number"==typeof e?e:void 0,onChange:e=>n("max",e),required:!0}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-2"},"Desired"),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(ve,{value:a,min:"number"==typeof e?e:void 0,max:"number"==typeof t?t:void 0,onChange:e=>n("desired",e),required:!0}))))}}class Sl extends Vt.Component{validate(e){const t={};(gt(e.capacity.min)<0||gt(e.capacity.max)<0||gt(e.capacity.desired)<0)&&(t.capacity="Capacity min, max, and desired all have to be non-negative values.");const a=e;return void 0!==a.targetHealthyDeployPercentage&&null!==a.targetHealthyDeployPercentage||(t.targetHealthyDeployPercentage="Target Healthy Deploy Percentage required."),t}render(){const{setFieldValue:e,values:t}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"row"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement(wl,{command:t,setFieldValue:e,MinMaxDesired:Cl}))),Vt.createElement("div",{className:"row"},Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"form-group form-inline",style:{marginTop:"20px"}},Vt.createElement("div",{className:"col-md-12"},"Consider deployment successful when"," ",Vt.createElement(un,{type:"number",name:"targetHealthyDeployPercentage",min:"0",max:"100",className:"form-control input-sm inline-number",required:!0})," ","percent of instances are healthy.")))))}}function kl(e){return Vt.createElement("div",null,Vt.createElement("h4",{style:{marginTop:"10px"}},"This application is"),e.instanceProfileList.map(t=>Vt.createElement("div",{key:t.type,className:"instance-profile-header profile-button"},Vt.createElement("button",{type:"button",onClick:()=>e.handleProfileChange(t.type),className:e.currentProfile===t.type?"instance-profile active":"instance-profile"},e.currentProfile===t.type&&Vt.createElement("span",{className:"far fa-check-circle selected-indicator"}),Vt.createElement("div",{className:"panel-heading"},Vt.createElement("h4",null,Vt.createElement("span",{className:`glyphicon glyphicon-${t.icon}`}),Vt.createElement("div",null,t.label)))))))}function Nl(e){const{selectedInstanceTypes:t,currentProfile:a}=e,n=Xn.awsInstanceTypeService.isBurstingSupportedForAllTypes(t),r=!!Xn.awsInstanceTypeService.getInstanceTypesInCategory(t,a).length,[i,s]=Ut(!1);return qt(()=>{t&&t.length&&(n||e.setUnlimitedCpuCredits(void 0),s(n)),a&&s(t&&t.length>0&&n&&r)},[a,t]),Vt.createElement("div",{className:"row",style:{fontSize:"110%"}},i&&Vt.createElement("div",null,Vt.createElement(ht,{toggleSize:ft.XSMALL,propLabel:"Unlimited CPU credits ",propHelpFieldId:"aws.serverGroup.unlimitedCpuCredits",tooltipPropOffBtn:"Toggle to turn OFF unlimited CPU credits",displayTextPropOffBtn:"Off",tooltipPropOnBtn:"Toggle to turn ON unlimited CPU credits",displayTextPropOnBtn:"On",onClick:t=>e.setUnlimitedCpuCredits(t),isPropertyActive:e.unlimitedCpuCredits})))}function Tl(e){var t,a,n,r,i,s,l,o,c,d,u,p,m,g,h,f,v,y,b,E,w,C,S,k,N;const T=(null==(a=null==(t=e.instanceType)?void 0:t.supportedUsageClasses)?void 0:a.includes("spot"))?"| SPOT supported":"",I=`${null==(n=e.instanceType)?void 0:n.defaultVCpus} vCPU | ${null==(r=e.instanceType)?void 0:r.memoryInGiB} Gib Memory ${T}`,G=(null==(i=e.instanceType)?void 0:i.instanceStorageSupported)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},`Instance Storage: ${Ht.toUpper(null==(l=null==(s=e.instanceType)?void 0:s.instanceStorageInfo)?void 0:l.storageTypes)} | ${null==(c=null==(o=e.instanceType)?void 0:o.instanceStorageInfo)?void 0:c.totalSizeInGB} Gib total size`)),A=(null==(d=e.instanceType)?void 0:d.ebsInfo)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},`EBS: optimization ${null==(p=null==(u=e.instanceType)?void 0:u.ebsInfo)?void 0:p.ebsOptimizedSupport} | NVMe ${null==(g=null==(m=e.instanceType)?void 0:m.ebsInfo)?void 0:g.nvmeSupport} | Encryption ${null==(f=null==(h=e.instanceType)?void 0:h.ebsInfo)?void 0:f.encryptionSupport}`)),x=(null==(v=e.instanceType)?void 0:v.gpuInfo)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},`GPU: ${null==(b=null==(y=e.instanceType)?void 0:y.gpuInfo)?void 0:b.totalGpuMemoryInMiB} MiB total memory`,null==(w=null==(E=e.instanceType)?void 0:E.gpuInfo)?void 0:w.gpus.map(e=>` | ${e.count} ${e.manufacturer} ${e.name} GPUs, size: ${e.gpuSizeInMiB} MiB`))),P=void 0!==(null==(C=e.instanceType)?void 0:C.currentGeneration)&&null!==(null==(S=e.instanceType)?void 0:S.currentGeneration)&&Vt.createElement("span",null,Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},(null==(k=e.instanceType)?void 0:k.currentGeneration)?"Current Generation":"Previous Generation"));return Vt.createElement("span",null,Vt.createElement("span",{className:"select-option-label"},null==(N=e.instanceType)?void 0:N.name),Vt.createElement("br",null),Vt.createElement("span",{className:"select-option-label-attributes"},I),G,A,x,P)}Ar(".advanced-mode-selector .instance-profile-header {\n display: inline-block;\n}\n.advanced-mode-selector .instance-profile-header button {\n width: 100%;\n}\n.advanced-mode-selector .instance-profile-header h4 {\n min-height: 52px;\n}\n.advanced-mode-selector .instance-profile-header .panel-heading {\n padding: 0 0 0 0;\n}\n.advanced-mode-selector .instance-profile-header.profile-button {\n width: calc(25% - 20px);\n margin: 0 10px 15px 10px;\n}\n.advanced-mode-selector .sub-section {\n padding: 0 15px;\n margin-bottom: 5px;\n}\n.advanced-mode-selector .sub-section .description {\n padding: 0 10px;\n}\n.advanced-mode-selector .sub-section tr.unavailable {\n opacity: 0.5;\n}\n.advanced-mode-selector .sub-section tr.sortable .instance-type-drag-handle {\n display: inline-block;\n opacity: 0.9;\n font-size: 100%;\n padding-top: 8px;\n}\n.advanced-mode-selector .sub-section th {\n font-size: 110%;\n}\n.custom-profile .select {\n width: 97%;\n display: inline-flex;\n}\n.custom-profile .select-option-label {\n font-size: 100%;\n font-weight: bold;\n}\n.custom-profile .select-option-label-attributes {\n font-size: 90%;\n font-weight: normal;\n font-style: italic;\n}\n.instance-profile {\n vertical-align: top;\n text-align: left;\n min-height: 100px;\n font-size: 90%;\n border: 1px solid var(--color-silver);\n border-radius: 3px;\n color: var(--color-mineshaft);\n background-color: transparent;\n}\n.instance-profile:hover,\n.instance-profile:focus {\n color: var(--color-mineshaft);\n text-decoration: none;\n}\n.instance-profile .selected-indicator {\n display: flex;\n width: 100%;\n text-align: right;\n padding-right: 5px;\n font-size: 150%;\n color: var(--color-accent);\n}\n.instance-profile .selected-indicator.custom {\n margin-top: 5px;\n}\n.instance-profile h4 {\n margin-top: 0;\n text-align: center;\n word-spacing: 300px;\n}\n.instance-profile ul {\n font-size: 95%;\n padding-left: 20px;\n}\n.instance-profile .panel-heading {\n padding-top: 0;\n padding-bottom: 0;\n}\n.instance-profile:hover,\n.instance-profile:focus,\n.instance-profile.active {\n outline: 0;\n}\n.instance-profile.active {\n box-shadow: inset 0 0 3px 2px var(--color-accent);\n border-color: var(--color-accent);\n}\n.instance-profile:hover,\n.instance-profile:focus {\n box-shadow: 0 0 8px 2px var(--color-accent);\n}\n");const Il=({min:e,max:t})=>{const a=Vt.createElement(Vt.Fragment,null,Vt.createElement("span",{className:"cost"},"$".repeat(e)),"$".repeat(4-e)),n=Vt.createElement(Vt.Fragment,null,Vt.createElement("span",{className:"cost"},"$".repeat(Math.min(4,t))),"$".repeat(4-Math.min(4,t)));return Vt.createElement("span",{className:"cost-factor"},a,t?` - ${n}`:"")};function Gl(e){var t,a;const n=!!e.selectedType,[r,i]=Ut(""),s=n?e.selectedType.instanceType:e.instanceTypeDetails.name,o=!n&&e.instanceTypeDetails.unavailable,c=(t,a)=>{o||e.addOrUpdateInstanceType(t,a),i("")},d=e=>{i(e.target.value),n?c(s,e.target.value):document.getElementById(`selectInstanceType-${s}`).focus()};let u;if(e.isCustom){const a=Vt.createElement(Tl,{instanceType:e.selectedTypeInfo});u=Vt.createElement("tr",{key:s,className:"sortable clickable"},Vt.createElement("td",null,Vt.createElement(Al,null)),Vt.createElement("td",null,`${s} `,Vt.createElement(ne,{placement:"right",template:a,className:"custom-profile"},Vt.createElement("span",{className:"clickable help-field"},Vt.createElement("i",{className:"small glyphicon glyphicon-info-sign"})))),Vt.createElement("td",{title:"Enter optional weight (allowed values: 1 to 999)."},Vt.createElement(l,{className:"form-control input input-sm",pattern:"[0-9]*",placeholder:"Enter optional weight (allowed values: 1 to 999).",value:(null==(t=e.selectedType)?void 0:t.weightedCapacity)||"",onChange:e=>c(s,e.target.value)})),Vt.createElement("td",null,Vt.createElement("div",null,Vt.createElement("span",null,Vt.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeInstanceType(s),style:{padding:"5px"}},Vt.createElement(_,{value:"Remove instance type"},Vt.createElement("span",{className:"glyphicon glyphicon-trash"})))))))}else{const{cpu:t,memory:i,cpuCreditsPerHour:p,storage:m,costFactor:g}=e.instanceTypeDetails;u=Vt.createElement("tr",{key:s,className:n?"sortable clickable":"non-sortable "+(o?"unavailable":"clickable"),title:n?"Click to unselect instance type":o?"This instance type is not available for the selected configuration":"Click to select instance type",onClick:t=>{$(t.target).is("input")||(n?e.removeInstanceType(s):c(s,r))}},n?Vt.createElement("td",null,Vt.createElement(Al,null)):Vt.createElement("td",null),Vt.createElement("td",null,Vt.createElement(_a,{id:`selectInstanceType-${s}`,checked:!!n,disabled:o,onChange:()=>{n?e.removeInstanceType(s):c(s,r)}})),Vt.createElement("td",null,s),Vt.createElement("td",null,t),Vt.createElement("td",null,i),p?Vt.createElement("td",null,p):Vt.createElement("td",{title:"Cpu credits not applicable to instance type."},"-"),"EBS"===m.type&&Vt.createElement("td",null,"EBS Only"),"SSD"===m.type&&Vt.createElement("td",null,m.count+"x"+m.size),Vt.createElement("td",null,Vt.createElement(Il,{min:g})),Vt.createElement("td",{title:o?"":"Enter optional weight (allowed values: 1 to 999)."},Vt.createElement(l,{inputClassName:"form-control input input-sm",id:`weightedCapacity-${s}`,pattern:"[0-9]*",placeholder:"Enter optional weight (allowed values: 1 to 999).",disabled:o,value:(null==(a=e.selectedType)?void 0:a.weightedCapacity)||r||"",onChange:d})))}return u}const Al=sn(()=>Vt.createElement(_,{value:"Drag to change priority"},Vt.createElement("span",{className:"instance-type-drag-handle glyphicon glyphicon-resize-vertical"})));function xl(e){return Vt.createElement(Pl,{isCustom:e.isCustom,selectedInstanceTypesMap:e.selectedInstanceTypesMap,selectedInstanceTypesInfo:e.selectedInstanceTypesInfo,removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType,instanceTypeDetails:e.isCustom?null:new Map(Object.entries(ya(Kt(e.profileFamiliesDetails.map(e=>e.instanceTypes)),"name"))),onSortEnd:t=>e.handleSortEnd(t),distance:1})}const Pl=cn(e=>{const{isCustom:t,selectedInstanceTypesMap:a}=e;let n,r;if(t)n=a.size>0&&Array.from(a.values()).sort((e,t)=>e.priority-t.priority).map((t,a)=>Vt.createElement(Dl,{key:`${t.instanceType}-${a}`,index:a,isCustom:!0,selectedType:t,selectedTypeInfo:e.selectedInstanceTypesInfo.find(e=>e.name===t.instanceType),removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType}));else{const{instanceTypeDetails:t}=e,i=Array.from(null==t?void 0:t.keys()),s=la(i,Array.from(a.keys())),l=Array.from(a.values()).filter(e=>i.includes(e.instanceType)).sort((e,t)=>e.priority-t.priority);n=l&&l.length>0&&l.map((a,n)=>Vt.createElement(Dl,{key:`${a.instanceType}-${n}`,index:n,isCustom:!1,selectedType:a,instanceTypeDetails:t,removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType})),r=s&&s.length>0&&s.map(a=>Vt.createElement(Gl,{key:a,isCustom:!1,instanceTypeDetails:t.get(a),addOrUpdateInstanceType:e.addOrUpdateInstanceType}))}return Vt.createElement("tbody",null,n,t?null:r)}),Dl=on(e=>Vt.createElement(Gl,{key:e.selectedType.instanceType,isCustom:e.isCustom,selectedType:e.selectedType,selectedTypeInfo:e.selectedTypeInfo,instanceTypeDetails:e.isCustom?null:e.instanceTypeDetails.get(e.selectedType.instanceType),removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType}));function Bl(e){return Vt.createElement("div",{className:"custom-profile"},Vt.createElement(rn,{className:"select",clearable:!1,multi:!1,placeholder:"Filter like 16vcpu, 32gib, spot, oldGen or Select an instance type to add",removeSelected:!0,searchable:!0,options:e.availableInstanceTypesList,optionRenderer:e=>Vt.createElement(Tl,{instanceType:e}),filterOption:(e,t)=>{const{name:a,defaultVCpus:n,memoryInGiB:r,instanceStorageInfo:i,ebsInfo:s,gpuInfo:l,supportedUsageClasses:o,currentGeneration:c}=e;return t.split(",").every(e=>{const t=Ht.toLower(e.trim());return t.match(/\d+\s*vcpu/)&&n>=Ht.toNumber(t.split("vcpu")[0].trim())||t.match(/\d+\s*gib/)&&r>=Ht.toNumber(t.split("gib")[0].trim())||t.match(/\b(ssd|hdd)\b/)&&(null==i?void 0:i.storageTypes.includes(t))||"spot"===t&&(null==o?void 0:o.includes(t))||"ebs"===t&&s||"gpu"===t&&l||"currentgen"===t&&c||"oldgen"===t&&!c||a.match(t)})},valueRenderer:e=>Vt.createElement(Vt.Fragment,null,e.name),onChange:t=>e.addOrUpdateInstanceType(t.name,void 0)})," ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypesSelect"}))}function zl(e){let t;return t=e.isCustom?Vt.createElement("p",null,"Choose the instance types that best suit the needs of your application."):Vt.createElement(Vt.Fragment,null,Vt.createElement("p",null,Vt.createElement("b",null,e.profileLabel)),Vt.createElement("ul",null,e.profileDescriptionArr.map((e,t)=>Vt.createElement("li",{key:t},e)))),Vt.createElement("div",{className:"row sub-section"},Vt.createElement("h4",null,"Instance Types"),Vt.createElement("div",{className:"description"},t,Vt.createElement("p",null,"Learn about AWS recommended best practices in"," ",Vt.createElement("a",{target:"_blank",href:"https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates/#create-a-server-group-with-aws-recommended-best-practices-for-ec2-spot"},"examples and docs"),"."),Vt.createElement("i",null,Vt.createElement("b",null,"Note:"),Vt.createElement("ul",null,Vt.createElement("li",null,"The order of instance types sets their priority when On-Demand capacity is launched; instance type at the top is prioritized the highest."),Vt.createElement("li",null,"Some instance types might not be available for the selected configuration.")))))}function Fl(e){let t,a,r,i;return e.isCustom?(t=Vt.createElement("th",null),a=Vt.createElement("th",null,"Instance Type ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypes"})),r=null,i=Vt.createElement("th",null)):(t=Vt.createElement(Vt.Fragment,null,Vt.createElement("th",null),Vt.createElement("th",null)),a=Vt.createElement("th",null,"InstanceType"),r=Vt.createElement(Vt.Fragment,null,Vt.createElement("th",null,"vCPU"),Vt.createElement("th",null,"Mem (GiB)"),e.showCpuCredits&&Vt.createElement("th",null,"CPU Credits"),Vt.createElement("th",null,"Storage (GB)",Vt.createElement(n,{id:"aws.serverGroup.storageType"})),Vt.createElement("th",null,"Cost")),i=null),Vt.createElement("thead",null,Vt.createElement("tr",null,t,a,r,Vt.createElement("th",null,"Weight ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})),i))}function Ml(e){return e.isCustom?Vt.createElement("tfoot",null,Vt.createElement("tr",null,Vt.createElement("td",null,Vt.createElement("span",{className:"glyphicon glyphicon-plus-sign",style:{paddingTop:"8px"}})),Vt.createElement("td",{colSpan:2},Vt.createElement(Bl,{availableInstanceTypesList:e.availableInstanceTypesList,addOrUpdateInstanceType:e.addOrUpdateInstanceType})),Vt.createElement("td",null))):null}function $l(e){return e.dirty.instanceType||e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0?Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),e.dirty.instanceType&&"The following instance type was found incompatible with the selected image/region and was removed:",e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0&&"The following instance type(s) were found incompatible with the selected image/region and were removed:"),Vt.createElement("ul",null,e.dirty.instanceType&&Vt.createElement("li",{key:e.dirty.instanceType},e.dirty.instanceType),e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0&&e.dirty.launchTemplateOverridesForInstanceType.map(e=>Vt.createElement("li",{key:e.instanceType},e.instanceType,e.weightedCapacity?" with weight "+e.weightedCapacity:""))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>e.clearWarnings()},"Okay")))):null}function Ll(e){var t;const{currentProfile:a,selectedInstanceTypesMap:n}=e,r=e=>{const t=Array.from(n.values()).sort((e,t)=>e.priority-t.priority).map(e=>e.instanceType),a=ln(t,e.oldIndex,e.newIndex);i(a)},i=t=>{n.forEach((e,a)=>{const n=1+t.indexOf(a);e.priority!==n&&(e.priority=n)}),e.handleInstanceTypesChange(Array.from(n.values()))},s=t=>{const a=new Map(n);a.delete(t),e.handleInstanceTypesChange(Array.from(a.values()))},l=(t,a)=>{const r=Number(a),i=isNaN(r)||0===r?void 0:r.toString(),s=n.has(t)?{...n.get(t),weightedCapacity:i}:{instanceType:t,weightedCapacity:i,priority:1+Array.from(n.values()).reduce((e,t)=>t.priority>e?t.priority:e,0)};n.set(t,s),e.handleInstanceTypesChange(Array.from(n.values()))},o=null==(t=kn.serverGroups)?void 0:t.enableCpuCredits,c=Array.from(n.keys()),d=Vt.createElement("div",null,Vt.createElement(Nl,{unlimitedCpuCredits:e.unlimitedCpuCreditsInCmd,currentProfile:a,selectedInstanceTypes:c,setUnlimitedCpuCredits:e.setUnlimitedCpuCredits}));if(a&&"custom"!==a){const{label:t,descriptionListOverride:a,families:i,showCpuCredits:c}=e.profileDetails,u=!1;return Vt.createElement("div",{className:"row sub-section"},Vt.createElement(zl,{isCustom:u,profileLabel:t,profileDescriptionArr:a||i.map(e=>e.description)}),Vt.createElement($l,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Vt.createElement("table",{className:"table table-hover"},Vt.createElement(Fl,{isCustom:u,showCpuCredits:c}),Vt.createElement(xl,{isCustom:u,profileFamiliesDetails:i,selectedInstanceTypesMap:n,addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r})))}{const t=!0;return Vt.createElement("div",{className:"row sub-section"},Vt.createElement(zl,{isCustom:t}),Vt.createElement($l,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Vt.createElement("table",{className:"table table-hover"},Vt.createElement(Fl,{isCustom:t}),Vt.createElement(xl,{isCustom:t,selectedInstanceTypesMap:n,selectedInstanceTypesInfo:e.availableInstanceTypesList.filter(e=>c.includes(e.name)),addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r}),Vt.createElement(Ml,{isCustom:t,availableInstanceTypesList:e.availableInstanceTypesList.filter(e=>!c.includes(e.name)),addOrUpdateInstanceType:l})))}}function Rl(e,t,a){const n=ia(e.values,t);Vt.useEffect(()=>{void 0===n&&void 0!==a&&e.setFieldValue(t,a)},[t,a,n])}function Ol(e){const{values:t,setFieldValue:a}=e.formik,r=[{label:"capacity-optimized (recommended)",value:"capacity-optimized"},{label:"capacity-optimized-prioritized",value:"capacity-optimized-prioritized"},{label:"lowest-price",value:"lowest-price"}];return Vt.useEffect(()=>{"lowest-price"!==t.spotAllocationStrategy?a("spotInstancePools",void 0):void 0===t.spotInstancePools&&a("spotInstancePools",2)},[t.spotAllocationStrategy]),Rl(e.formik,"spotAllocationStrategy","capacity-optimized"),Rl(e.formik,"onDemandAllocationStrategy","prioritized"),Rl(e.formik,"onDemandBaseCapacity",0),Rl(e.formik,"onDemandPercentageAboveBaseCapacity",100),Vt.createElement("div",{className:"InstancesDistribution row sub-section form-group"},Vt.createElement("h4",null,"Instances Distribution"),Vt.createElement("div",{className:"description"},"Diversify and distribute instance types across purchase options."," ",Vt.createElement(n,{id:"aws.serverGroup.instancesDistribution"})),Vt.createElement("br",null),Vt.createElement(s,{label:"Spot Allocation Strategy",name:"spotAllocationStrategy",help:Vt.createElement(n,{id:"aws.serverGroup.spotAllocationStrategy"}),input:e=>Vt.createElement(c,{...e,mode:"PLAIN",options:r})}),"lowest-price"===e.formik.values.spotAllocationStrategy&&Vt.createElement(s,{label:"Spot Instance Pools Count",name:"spotInstancePools",help:Vt.createElement(n,{id:"aws.serverGroup.spotInstancePoolCount"}),input:e=>Vt.createElement(p,{...e})}),Vt.createElement(s,{label:"On-Demand Allocation Strategy",name:"onDemandAllocationStrategy",help:Vt.createElement(n,{id:"aws.serverGroup.odAllocationStrategy"}),input:e=>Vt.createElement(l,{...e,disabled:!0})}),Vt.createElement(s,{label:"On-Demand Base Capacity",name:"onDemandBaseCapacity",help:Vt.createElement(n,{id:"aws.serverGroup.odBase"}),input:e=>Vt.createElement(p,{...e})}),Vt.createElement(s,{label:"On-Demand Percentage Above Base Capacity",name:"onDemandPercentageAboveBaseCapacity",help:Vt.createElement(n,{id:"aws.serverGroup.odPercentAboveBase"}),input:e=>Vt.createElement(p,{...e})}),Vt.createElement(s,{label:"Spot Max Price",name:"spotPrice",help:Vt.createElement(n,{id:"aws.serverGroup.spotMaxPrice"}),input:e=>Vt.createElement(_,{value:"Recommended to leave empty and use AWS default i.e. On-Demand price"},Vt.createElement(l,{...e,placeholder:"Recommended to leave empty and use AWS default i.e. On-Demand price"}))}))}function Vl(e){const{instanceTypeDetails:t,setUnlimitedCpuCredits:a}=e,{values:n,setFieldValue:r}=e.formik,{instanceType:i,launchTemplateOverridesForInstanceType:s}=n;qt(()=>{!s&&i&&e.formik.setFieldValue("launchTemplateOverridesForInstanceType",[{instanceType:n.instanceType,priority:1}])});const l=n.launchTemplateOverridesForInstanceType?n.launchTemplateOverridesForInstanceType:void 0,o=new Map(Object.entries(ya(l,"instanceType"))),[c,d]=Ut(n.viewState.instanceProfile||"custom"),u=vt(c);return t&&t.length>0?Vt.createElement("div",{className:"advanced-mode-selector"},Vt.createElement(kl,{currentProfile:c,handleProfileChange:e=>{d(e),r("viewState",{...n.viewState,instanceProfile:e});const t=u&&e&&u!==e,a="custom"!==e&&l&&l.length;if(t&&a){const t=Xn.awsInstanceTypeService.getInstanceTypesInCategory(l.map(e=>e.instanceType),e),a=l.filter(e=>t.includes(e.instanceType));r("launchTemplateOverridesForInstanceType",a),n.launchTemplateOverridesChanged(n)}},instanceProfileList:t}),Vt.createElement(Ol,{formik:e.formik}),Vt.createElement(Ll,{currentProfile:c,selectedInstanceTypesMap:o,unlimitedCpuCreditsInCmd:n.unlimitedCpuCredits,profileDetails:t.find(e=>e.type===c),availableInstanceTypesList:n.backingData&&n.backingData.filtered&&n.backingData.filtered.instanceTypesInfo||[],handleInstanceTypesChange:e=>{r("launchTemplateOverridesForInstanceType",e),n.launchTemplateOverridesChanged(n)},setUnlimitedCpuCredits:a,viewState:n.viewState,clearWarnings:e.clearWarnings})):null}function Ul(e){var t,a;const{command:n}=e,{InstanceArchetypeSelector:r,InstanceTypeSelector:i}=yt,s=null==(t=kn.serverGroups)?void 0:t.enableLaunchTemplates,l=null==(a=kn.serverGroups)?void 0:a.enableCpuCredits,o=t=>{n.instanceTypeChanged(n),e.setFieldValue("instanceType",t)};return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"row"},Vt.createElement(r,{command:n,onTypeChanged:o,onProfileChanged:t=>{e.setFieldValue("viewState",{...n.viewState,instanceProfile:t})}}),Vt.createElement($l,{dirty:n.viewState.dirty,clearWarnings:e.clearWarnings}),Vt.createElement("div",{style:{padding:"0 15px"}},n.viewState.instanceProfile&&"custom"!==n.viewState.instanceProfile&&Vt.createElement(i,{command:n,onTypeChanged:o}))),s&&l&&Vt.createElement("div",{className:"row"},Vt.createElement(Nl,{unlimitedCpuCredits:n.unlimitedCpuCredits,selectedInstanceTypes:[n.instanceType],currentProfile:n.viewState.instanceProfile,setUnlimitedCpuCredits:e.setUnlimitedCpuCredits})))}function ql(e){var t;const{instanceTypeDetails:a}=e,{values:r,setFieldValue:i}=e.formik,s=null==(t=kn.serverGroups)?void 0:t.enableLaunchTemplates,l=r.viewState.useSimpleInstanceTypeSelector,[o,c]=Ut(r.unlimitedCpuCredits);qt(()=>{r.unlimitedCpuCredits!==o&&i("unlimitedCpuCredits",o)},[o]);const d=()=>{const{formik:t}=e;t.values.viewState.dirty.instanceType=null,t.values.viewState.dirty.launchTemplateOverridesForInstanceType=null,t.validateForm()},u=e=>{if(l!==e)if(i("viewState",{...r.viewState,useSimpleInstanceTypeSelector:e}),e){const e=r.launchTemplateOverridesForInstanceType,t=r.viewState.dirty.launchTemplateOverridesForInstanceType;if(null==e?void 0:e.length){const t=e.reduce((e,t)=>e.priority<t.priority?e:t).instanceType;i("instanceType",t),i("launchTemplateOverridesForInstanceType",[]),r.instanceTypeChanged(r)}if(null==t?void 0:t.length){const e=t.reduce((e,t)=>e.priority<t.priority?e:t).instanceType;i("viewState.dirty.instanceType",e),i("viewState.dirty.launchTemplateOverridesForInstanceType",[])}}else if(!e){const e=r.instanceType,t=r.viewState.dirty.instanceType;if(e){const t=[{instanceType:e,priority:1}];i("instanceType",void 0),i("launchTemplateOverridesForInstanceType",t),r.launchTemplateOverridesChanged(r)}if(t){const e=[{instanceType:t,priority:1}];i("viewState.dirty.instanceType",void 0),i("viewState.dirty.launchTemplateOverridesForInstanceType",e)}}};return s&&!l?Vt.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Vt.createElement("div",null,Vt.createElement("p",null,"Switch to",Vt.createElement("a",{className:"clickable",onClick:()=>u(!0)},Vt.createElement("span",null," Simple Mode")),"."),Vt.createElement("i",null,Vt.createElement("b",null,"Note:")," If multiple instance types are already selected in advanced mode, the instance type with highest priority will be preserved in simple mode.")),Vt.createElement(Vl,{formik:e.formik,instanceTypeDetails:a,setUnlimitedCpuCredits:c,clearWarnings:d})):Vt.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Vt.createElement("div",null,Vt.createElement("span",null,"To configure mixed server groups and/or multiple instance types,"),!s&&Vt.createElement("span",null,Vt.createElement("a",{href:"https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates-setup/"},Vt.createElement("span",null," enable launch templates")),Vt.createElement("span",null," and")),Vt.createElement("span",null,Vt.createElement("a",{className:s?"clickable":"disabled",onClick:s?()=>u(!1):()=>{}},Vt.createElement("span",null," use Advanced Mode ")),Vt.createElement(n,{id:"aws.serverGroup.advancedMode"}),"."),Vt.createElement("p",null),s&&Vt.createElement("i",null,Vt.createElement("b",null,"Note:")," If an instance type is already selected in simple mode, it will be preserved in advanced mode.")),Vt.createElement(Ul,{command:r,setUnlimitedCpuCredits:c,setFieldValue:i,clearWarnings:d}))}Ar(".InstancesDistribution .StandardFieldLayout_Label {\n min-width: 300px;\n}\n");class Hl extends Vt.Component{constructor(){super(...arguments),this.state={instanceTypeDetails:[]},this.props$=new Ta,this.destroy$=new Ta}validate(e){const t={};if(e.viewState.useSimpleInstanceTypeSelector)e.viewState.dirty.instanceType?t.instanceType="You must confirm removed instance type and pick a compatible instance type.":e.instanceType||(t.instanceType="Instance Type required.");else{const a=e.viewState.dirty.launchTemplateOverridesForInstanceType;if(a&&a.length>0)t.instanceType="You must confirm removed instance types and/or pick more instance types.";else{const a=this.validateAdvancedModeFields(e,t);Object.assign(t,{...a})}}return t}validateAdvancedModeFields(e,t){e.launchTemplateOverridesForInstanceType.length||(t.instanceType="At least one instance type required."),e.launchTemplateOverridesForInstanceType.length>40&&(t.instanceType="Maximum of 40 instance types are allowed.");const a=e.launchTemplateOverridesForInstanceType.filter(e=>void 0!==e.weightedCapacity);if(a.length!==e.launchTemplateOverridesForInstanceType.length&&0!==a.length&&(t.instanceType="Weighted capacity must be specified for all instance types selected or none."),oa(a,function(e){const t=Number(e.weightedCapacity);return t<1||t>999})&&(t.instanceType="Weighted capacity must be a number between 1 and 999."),e.onDemandBaseCapacity<0&&(t.onDemandBaseCapacity="On-Demand base capacity must be non-negative."),e.onDemandBaseCapacity>gt(e.capacity.max)&&(t.onDemandBaseCapacity="On-Demand base capacity must be less than or equal to max capacity."),(e.onDemandPercentageAboveBaseCapacity<0||e.onDemandPercentageAboveBaseCapacity>100)&&(t.onDemandPercentageAboveBaseCapacity="On-Demand percentage above base capacity must be a number between 0 and 100."),e.spotPrice){const a=Number(e.spotPrice);Number.isNaN(a)&&(t.spotPrice="Spot Max Price must be a number or empty string, used to unset previous max price."),a<=0&&(t.spotPrice="Spot Max Price must be greater than 0, if specified.")}return e.spotInstancePools&&"lowest-price"!==e.spotAllocationStrategy&&(t.spotInstancePools="Spot Instance Pools is only supported for 'lowest-price' Spot Allocation Strategy."),(e.spotInstancePools<=0||e.spotInstancePools>20)&&(t.spotInstancePools="Spot Instance Pools count must be a number between 1 and 20, when applicable."),t}componentDidMount(){Promise.resolve(Xn.awsInstanceTypeService.getCategories()).then(e=>{this.setState({instanceTypeDetails:e})})}componentDidUpdate(){this.props$.next(this.props)}componentWillUnmount(){this.destroy$.next()}render(){var e,t,a;const{values:n}=this.props.formik,r=!(!n.viewState.disableImageSelection&&!n.amiName),i=null!=(a=null==(t=null==(e=n.backingData)?void 0:e.filtered)?void 0:t.instanceTypes)?a:[],s=Array.from(this.state.instanceTypeDetails);return!n.viewState.disableImageSelection&&i.length&&s.forEach(e=>{e.families.forEach(e=>{e.instanceTypes.forEach(e=>{e.unavailable=!i.includes(e.name)})})}),r&&n?Vt.createElement(ql,{formik:this.props.formik,instanceTypeDetails:s}):Vt.createElement("h5",{className:"text-center"},"Please select an image.")}}class Wl extends Vt.Component{constructor(){super(...arguments),this.handleAvailabilityZonesChanged=e=>{const{values:t,setFieldValue:a}=this.props.formik;t.usePreferredZonesChanged(t),a("availabilityZones",e)},this.rebalanceToggled=()=>{const{values:e,setFieldValue:t}=this.props.formik;e.toggleSuspendedProcess(e,"AZRebalance"),t("suspendedProcesses",e.suspendedProcesses),this.setState({})}}validate(e){const t={};return e.availabilityZones&&0!==e.availabilityZones.length||(t.availabilityZones="You must select at least one availability zone."),t}render(){const{values:e}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement(ri,{credentials:e.credentials,region:e.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:e.availabilityZones,allZones:e.backingData.filtered.availabilityZones,usePreferredZones:e.viewState.usePreferredZones}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},Vt.createElement("b",null,"AZ Rebalance")),Vt.createElement("div",{className:"col-md-7 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",onChange:this.rebalanceToggled,checked:!e.processIsSuspended(e,"AZRebalance")}),"Keep instances evenly distributed across zones"))))}}const jl=e=>({value:e,label:e});class Zl extends Vt.Component{constructor(){super(...arguments),this.state={refreshing:!1,refreshed:!1,showVpcLoadBalancers:!1},this.refreshLoadBalancers=()=>{const{values:e}=this.props.formik;this.setState({refreshing:!0});h.providerServiceDelegate.getDelegate(e.cloudProvider||e.selectedProvider,"serverGroup.configurationService").refreshLoadBalancers(e).then(()=>{this.setState({refreshing:!1,refreshed:!0})})},this.targetGroupsChanged=e=>{const t=e.map(e=>e.value);this.props.formik.setFieldValue("targetGroups",t)},this.loadBalancersChanged=e=>{const t=e.map(e=>e.value);this.props.formik.setFieldValue("loadBalancers",t)},this.vpcLoadBalancersChanged=e=>{const t=e.map(e=>e.value);this.props.formik.setFieldValue("vpcLoadBalancers",t)}}validate(e){const t={};return e.viewState.dirty.targetGroups&&(t.targetGroups="You must confirm the removed target groups."),e.viewState.dirty.loadBalancers&&(t.loadBalancers="You must confirm the removed load balancers."),t}clearWarnings(e){this.props.formik.values.viewState.dirty[e]=null,this.props.formik.validateForm()}render(){var e;const{hideLoadBalancers:t,hideTargetGroups:a}=this.props,{values:r}=this.props.formik,{dirty:i}=r.viewState,{refreshed:s,refreshing:l,showVpcLoadBalancers:o}=this.state;let c=null;if(!a){const t=(r.backingData.filtered.targetGroups||[]).concat(r.viewState.spelTargetGroups||[]).map(jl);c=Vt.createElement(Vt.Fragment,null,i.targetGroups&&Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following target groups could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,i.targetGroups.map(e=>Vt.createElement("li",{key:e},e))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("targetGroups")},"Okay")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Target Groups "),Vt.createElement(n,{id:"aws.loadBalancer.targetGroups"})),Vt.createElement("div",{className:"col-md-7"},0===t.length&&Vt.createElement("div",{className:"form-control-static"},"No ",Vt.createElement("b",null,null!=(e=this.props.targetGroupTypeHelpText)?e:"instance")," target groups found in the selected account/region/VPC"),t.length>0&&Vt.createElement(f,{multi:!0,options:t,value:r.targetGroups,onChange:this.targetGroupsChanged}))))}let d=null;if(!t){const e=(r.backingData.filtered.loadBalancers||[]).concat(r.viewState.spelLoadBalancers||[]).map(jl),t=(r.backingData.filtered.vpcLoadBalancers||[]).map(jl),a=r.vpcLoadBalancers&&r.vpcLoadBalancers.length>0;d=Vt.createElement(Vt.Fragment,null,i.loadBalancers&&Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following load balancers could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,i.loadBalancers.map(e=>Vt.createElement("li",{key:e},e))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("loadBalancers")},"Okay")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"Classic Load Balancers "),Vt.createElement(n,{id:"aws.loadBalancer.loadBalancers"})),Vt.createElement("div",{className:"col-md-7"},0===e.length&&Vt.createElement("div",{className:"form-control-static"},"No load balancers found in the selected account/region/VPC"),e.length>0&&Vt.createElement(f,{multi:!0,options:e,value:r.loadBalancers,onChange:this.loadBalancersChanged}))),!r.vpcId&&Vt.createElement("div",{className:"form-group"},!a&&!o&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-8 col-md-offset-3"},Vt.createElement("a",{className:"clickable",onClick:()=>this.setState({showVpcLoadBalancers:!0})},"Add VPC Load Balancers"))),a&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-4 sm-label-right"},Vt.createElement("b",null,"VPC Load Balancers")),Vt.createElement("div",{className:"col-md-8"},t.length>0&&Vt.createElement(f,{multi:!0,options:t,value:r.vpcLoadBalancers,onChange:this.vpcLoadBalancersChanged})))),!s&&Vt.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Vt.createElement("div",{className:"col-md-8 col-md-offset-4"},l&&Vt.createElement("p",null,Vt.createElement("span",{className:"fa fa-sync-alt fa-spin"}),Vt.createElement("span",null," refreshing...")),!l&&Vt.createElement("p",null,"If you are looking for a load balancer or target group from a different application, ",Vt.createElement("br",null),Vt.createElement("a",{className:"clickable",onClick:this.refreshLoadBalancers},"click here")," ","to load all load balancers."))))}return Vt.createElement("div",{className:"container-fluid form-horizontal"},c,d)}}class _l extends Vt.Component{constructor(e){super(e),this.refreshSecurityGroups=()=>{this.setState({refreshing:!0}),this.props.refresh?this.props.refresh().then(()=>this.setState({refreshing:!1})):h.providerServiceDelegate.getDelegate(this.props.command.selectedProvider,"serverGroup.configurationService").refreshSecurityGroups(this.props.command).then(()=>{this.setState({refreshing:!1,refreshTime:Ne.get("securityGroups").getStats().ageMax})})},this.onChange=e=>{const t=e.map(e=>e.value);this.props.onChange(t)},this.state={refreshing:!1,refreshTime:Ne.get("securityGroups").getStats().ageMax}}render(){const{availableGroups:e,groupsToEdit:t,helpKey:a,hideLabel:r}=this.props,{refreshing:i,refreshTime:s}=this.state,l=e.map(e=>({label:`${e.name} (${e.id})`,value:e.id}));return Vt.createElement(Vt.Fragment,null,Vt.createElement("div",{className:"form-group"},!r&&Vt.createElement("div",{className:"col-md-3 sm-label-right"},Vt.createElement("b",null,U.get("Firewalls")),a&&Vt.createElement(n,{key:a})),Vt.createElement("div",{className:"col-md-8"},Vt.createElement(pn,{ignoreAccents:!0,options:l,onChange:this.onChange,value:t,multi:!0}))),Vt.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Vt.createElement("div",{className:`col-md-${r?12:9} col-md-offset-${r?0:3}`},Vt.createElement("p",null,i&&Vt.createElement("span",null,Vt.createElement("span",{className:"fa fa-sync-alt fa-spin"})),U.get("Firewalls"),!i&&Vt.createElement("span",null," last refreshed ",z(s)),i&&Vt.createElement("span",null," refreshing...")),Vt.createElement("p",null,"If you're not finding a ",U.get("firewall")," that was recently added,"," ",Vt.createElement("a",{className:"clickable",onClick:this.refreshSecurityGroups},"click here")," ","to refresh the list."))))}}class Kl extends Vt.Component{render(){const{command:e,onClear:t,removed:a}=this.props,n=(e&&e.viewState.dirty.securityGroups||[]).concat(a||[]);return 0===n.length?null:Vt.createElement("div",{className:"col-md-12"},Vt.createElement("div",{className:"alert alert-warning"},Vt.createElement("p",null,Vt.createElement("i",{className:"fa fa-exclamation-triangle"}),"The following ",U.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Vt.createElement("ul",null,n.map(e=>Vt.createElement("li",{key:e},e))),Vt.createElement("p",{className:"text-right"},Vt.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:t},"Okay"))))}}Kl.defaultProps={onClear:C};class Yl extends Vt.Component{constructor(){super(...arguments),this.onChange=e=>{this.props.formik.setFieldValue("securityGroups",e)},this.acknowledgeRemovedGroups=()=>{const{viewState:e}=this.props.formik.values;e.dirty.securityGroups=null,this.props.formik.setFieldValue("viewState",e)}}validate(e){const t={};return e.viewState.dirty.securityGroups&&(t.securityGroups="You must acknowledge removed security groups."),t}render(){const{values:e}=this.props.formik;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement(Kl,{command:e,onClear:this.acknowledgeRemovedGroups}),Vt.createElement(_l,{command:e,availableGroups:e.backingData.filtered.securityGroups,groupsToEdit:e.securityGroups,onChange:this.onChange}))}}class Xl extends Vt.Component{constructor(){super(...arguments),this.duplicateKeys=!1,this.validate=e=>{const t={};return e.keyPair||(t.keyPair="Key Name is required"),this.duplicateKeys&&(t.tags="Tags have duplicate keys."),t},this.selectBlockDeviceMappingsSource=e=>{const{values:t}=this.props.formik;t.selectBlockDeviceMappingsSource(t,e),this.setState({})},this.toggleSuspendedProcess=e=>{const{values:t,setFieldValue:a}=this.props.formik;t.toggleSuspendedProcess(t,e),a("suspendedProcesses",t.suspendedProcesses),this.setState({})},this.platformHealthOverrideChanged=e=>{this.props.formik.setFieldValue("interestingHealthProviderNames",e)},this.tagsChanged=(e,t)=>{this.duplicateKeys=t,this.props.formik.setFieldValue("tags",e)}}render(){const{app:e}=this.props,{setFieldValue:t,values:a}=this.props.formik,r=a.getBlockDeviceMappingsSource(a),i=a.backingData.filtered.keyPairs||[],s=kn.serverGroups;return Vt.createElement("div",{className:"container-fluid form-horizontal"},Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Cooldown")),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(un,{type:"text",required:!0,name:"cooldown",className:"form-control input-sm no-spel"}))," ","seconds"),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Enabled Metrics "),Vt.createElement(n,{id:"aws.serverGroup.enabledMetrics"})),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{multi:!0,value:a.enabledMetrics,options:a.backingData.enabledMetrics.map(e=>({label:e,value:e})),onChange:e=>t("enabledMetrics",e.map(e=>e.value))}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Health Check Type")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{value:a.healthCheckType,clearable:!1,placeholder:"Select...",options:a.backingData.healthCheckTypes.map(e=>({label:e,value:e})),onChange:e=>t("healthCheckType",e.value)}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Health Check Grace Period")),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(un,{type:"text",required:!0,className:"form-control input-sm no-spel",name:"healthCheckGracePeriod"}))," ","seconds"),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Termination Policies")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{multi:!0,value:a.terminationPolicies,options:a.backingData.terminationPolicies.map(e=>({label:e,value:e})),onChange:e=>t("terminationPolicies",e.map(e=>e.value))}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Key Name")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(rn,{value:a.keyPair,required:!0,clearable:!1,options:i.map(e=>({label:e,value:e})),onChange:e=>t("keyPair",e.value)}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Ramdisk Id (optional)")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(un,{type:"text",name:"ramdiskId",className:"form-control input-sm no-spel"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"IAM Instance Profile (optional)")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(un,{type:"text",className:"form-control input-sm no-spel",name:"iamRole"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"UserData (optional) "),Vt.createElement(n,{id:"aws.serverGroup.base64UserData"})),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(un,{type:"text",className:"form-control input-sm no-spel",name:"base64UserData"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Instance Monitoring "),Vt.createElement(n,{id:"aws.serverGroup.instanceMonitoring"})),Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:a.instanceMonitoring,onChange:e=>t("instanceMonitoring",e.target.checked)})," ","Enforce Instance Monitoring"," "))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"EBS Optimized")),Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:a.ebsOptimized,onChange:e=>t("ebsOptimized",e.target.checked)})," ","Optimize Instances for EBS"))),(null==s?void 0:s.enableIMDSv2)&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"IMDSv2 "),Vt.createElement(n,{id:"aws.serverGroup.imdsv2"})),Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:!0===a.requireIMDSv2,onChange:e=>t("requireIMDSv2",e.target.checked)})," ","Require IMDSv2"," "))),!kn.disableSpotPricing&&a.viewState.useSimpleInstanceTypeSelector&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Spot Instances Price (optional)")," ",Vt.createElement(n,{id:"aws.serverGroup.spotMaxPrice"})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(un,{type:"text",className:"form-control input-sm",name:"spotPrice"}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"AMI Block Device Mappings")),Vt.createElement("div",{className:"col-md-6 radio"},Vt.createElement("div",null,Vt.createElement("label",null,Vt.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("source"),checked:"source"===r,name:"blockDeviceMappingsSource"}),"Copy from current server group ",Vt.createElement(n,{id:"aws.blockDeviceMappings.useSource"}))),Vt.createElement("div",null,Vt.createElement("label",null,Vt.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("ami"),checked:"ami"===r,name:"blockDeviceMappingsSource"}),"Prefer AMI block device mappings ",Vt.createElement(n,{id:"aws.blockDeviceMappings.useAMI"}))),Vt.createElement("div",null,Vt.createElement("label",null,Vt.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("default"),checked:"default"===r,name:"blockDeviceMappingsSource"}),"Defaults for selected instance type ",Vt.createElement(n,{id:"aws.blockDeviceMappings.useDefaults"}))))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,`Associate ${(null==s?void 0:s.enableIPv6)?"IPv6 (Recommended)":"Public IPv4"} Address`),Vt.createElement(n,{id:"serverGroup.ipv6"})),(null==s?void 0:s.enableIPv6)&&Vt.createElement("div",{className:"col-md-6 checkbox"},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",checked:!0===a.associateIPv6Address,onChange:e=>t("associateIPv6Address",e.target.checked),id:"associateIPv6AddressToggle"})," ","Assign an IPv6 address to instances"," ")),!(null==s?void 0:s.enableIPv6)&&Vt.createElement("div",null,Vt.createElement("div",{className:"col-md-2 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:!0===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!0),id:"associatePublicIpAddressTrue"}),"Yes")),Vt.createElement("div",{className:"col-md-2 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:!1===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!1),id:"associatePublicIpAddressFalse"}),"No")),Vt.createElement("div",{className:"col-md-2 radio"},Vt.createElement("label",null,Vt.createElement("input",{type:"radio",checked:null===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",null),id:"associatePublicIpAddressDefault"}),"Default")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Scaling Processes")),Vt.createElement("div",{className:"col-md-6 checkbox"},a.backingData.scalingProcesses.map(e=>Vt.createElement("div",{key:e.name},Vt.createElement("label",null,Vt.createElement("input",{type:"checkbox",onChange:()=>this.toggleSuspendedProcess(e.name),checked:!a.suspendedProcesses.includes(e.name)})," ",e.name," ",Vt.createElement(n,{content:e.description})))))),e.attributes.platformHealthOnlyShowOverride&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-5 sm-label-right"},Vt.createElement("b",null,"Task Completion")),Vt.createElement("div",{className:"col-md-6"},Vt.createElement(bt,{interestingHealthProviderNames:a.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"sm-label-left"},Vt.createElement("b",null,"Tags (optional)"),Vt.createElement(n,{id:"aws.serverGroup.tags"})),Vt.createElement(Et,{model:a.tags,allowEmpty:!0,onChange:this.tagsChanged})))}}var Jl=Object.getOwnPropertyDescriptor;let Ql=class extends Vt.Component{constructor(){super(...arguments),this.validators=new Map,this.validate=e=>{const t={};return this.validators.forEach(a=>{const n=a(e);Object.assign(t,{...n})}),t},this.handleRef=e=>{e?this.validators.set("common",e.validate):this.validators.delete("common")}}render(){const{formik:e,app:t}=this.props;return Vt.createElement(Xl,{formik:e,app:t,ref:this.handleRef})}};Ql=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Jl(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("aws.serverGroup.advancedSettings")],Ql);class eo extends Vt.Component{constructor(){super(...arguments),this.ref=Vt.createRef()}validate(e){return this.ref&&this.ref.current?this.ref.current.validate(e):{}}render(){const{app:e,formik:t}=this.props;return Vt.createElement(Ql,{formik:t,app:e,ref:this.ref})}}const to=class e extends Vt.Component{constructor(e){super(e),this._isUnmounted=!1,this.templateSelected=()=>{this.setState({requiresTemplateSelection:!1}),this.configureCommand()},this.onTaskComplete=()=>{this.props.application.serverGroups.refresh(),this.props.application.serverGroups.onNextRefresh(null,this.onApplicationRefresh)},this.onApplicationRefresh=()=>{if(this._isUnmounted)return;const{command:e}=this.props,{taskMonitor:t}=this.state,a=t.task.execution.stages.find(e=>"cloneServerGroup"===e.type);if(a&&a.context["deploy.server.groups"]){const t=a.context["deploy.server.groups"][e.region];if(t){const a={serverGroup:t,accountId:e.credentials,region:e.region,provider:"aws"};let n="^.^.^.clusters.serverGroup";h.$state.includes("**.clusters.serverGroup")&&(n="^.serverGroup"),h.$state.includes("**.clusters.cluster.serverGroup")&&(n="^.^.serverGroup"),h.$state.includes("**.clusters")&&(n=".serverGroup"),h.$state.go(n,a)}}},this.initializeCommand=()=>{const{command:e}=this.props;e.credentialsChanged(e),e.regionChanged(e),Xn.awsServerGroupConfigurationService.configureSubnetPurposes(e)},this.configureCommand=()=>{const{application:e,command:t}=this.props;Xn.awsServerGroupConfigurationService.configureCommand(e,t).then(()=>{this.initializeCommand(),this.setState({loaded:!0,requiresTemplateSelection:!1})})},this.normalizeCommand=({tags:e})=>{e&&Object.keys(e).forEach(t=>{t.length||e[t].length||delete e[t]})},this.submit=e=>{this.normalizeCommand(e);"editPipeline"===e.viewState.mode||"createPipeline"===e.viewState.mode?this.props.closeModal&&this.props.closeModal(e):this.state.taskMonitor.submit(()=>h.serverGroupWriter.cloneServerGroup(e,this.props.application))};const t=ia(e,"command.viewState.requiresTemplateSelection",!1);t||this.configureCommand(),this.state={firewallsLabel:U.get("Firewalls"),loaded:!1,requiresTemplateSelection:t,taskMonitor:new v({application:e.application,title:"Creating your server group",modalInstance:v.modalInstanceEmulation(()=>this.props.dismissModal()),onTaskComplete:this.onTaskComplete})}}static show(t){return b.show(e,t,{dialogClassName:"wizard-modal modal-lg"})}componentWillUnmount(){this._isUnmounted=!0,this.refreshUnsubscribe&&this.refreshUnsubscribe()}render(){const{application:e,command:t,dismissModal:a,title:n}=this.props,{loaded:r,taskMonitor:i,requiresTemplateSelection:s}=this.state;return s?Vt.createElement(vl,{app:e,command:t,onDismiss:a,onTemplateSelected:this.templateSelected}):Vt.createElement(E,{heading:n,initialValues:t,loading:!r,taskMonitor:i,dismissModal:a,closeModal:this.submit,submitButtonLabel:t.viewState.submitButtonLabel,render:({formik:a,nextIdx:n,wizard:r})=>Vt.createElement(Vt.Fragment,null,Vt.createElement(w,{label:"Basic Settings",wizard:r,order:n(),render:({innerRef:t})=>Vt.createElement(El,{ref:t,formik:a,app:e})}),Vt.createElement(w,{label:"Load Balancers",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Zl,{ref:e,formik:a})}),Vt.createElement(w,{label:U.get("Firewalls"),wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Yl,{ref:e,formik:a})}),Vt.createElement(w,{label:t.viewState.useSimpleInstanceTypeSelector?"Instance Type":"Instance Types",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Hl,{ref:e,formik:a})}),Vt.createElement(w,{label:"Capacity",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Sl,{ref:e,formik:a})}),Vt.createElement(w,{label:"Availability Zones",wizard:r,order:n(),render:({innerRef:e})=>Vt.createElement(Wl,{ref:e,formik:a})}),Vt.createElement(w,{label:"Advanced Settings",wizard:r,order:n(),render:({innerRef:t})=>Vt.createElement(eo,{ref:t,formik:a,app:e})}))})}};to.defaultProps={closeModal:C,dismissModal:C};let ao=to;class no extends Vt.Component{constructor(){super(...arguments),this.state={verified:!1,requireVerification:!1},this.handleVerification=e=>{this.setState({verified:e})}}componentDidMount(){o.accounts$.pipe(Ua(1),Da(e=>e.find(e=>e.name===this.props.account))).subscribe(e=>{this.setState({requireVerification:!!e&&e.challengeDestructiveActions})})}render(){const{account:e,onCancel:t,onSubmit:a,isValid:n}=this.props,{verified:r,requireVerification:i}=this.state;return Vt.createElement(Ka,null,Vt.createElement("form",{onSubmit:()=>(this.props.onSubmit(),!1)},i&&Vt.createElement(wt,{expectedValue:e,onValidChange:this.handleVerification})),Vt.createElement("button",{className:"btn btn-default",onClick:t},"Cancel"),Vt.createElement("button",{type:"submit",className:"btn btn-primary",onClick:a,disabled:!n||i&&!r},"Submit"))}}no.defaultProps={isValid:!0};const ro=class e extends Vt.Component{constructor(e){super(e),this.formikRef=Vt.createRef(),this.validate=e=>{const{min:t,max:a,desired:n}=e,r={};return this.state.advancedMode?(t>a&&t>n?r.min="Min cannot be larger than Max/Desired":a<t&&a<n?r.max="Max cannot be smaller than Min/Desired":(t>a&&(r.min="Min cannot be larger than Max"),this.isDesiredControlledByAutoscaling()||(n<t&&(r.desired="Desired cannot be smaller than Min"),n>a&&(r.desired="Desired cannot be larger than Max"))),r):r},this.toggleAdvancedMode=()=>{const{desired:e}=this.formikRef.current.getFormikContext().values;this.formikRef.current.setFieldValue("min",e),this.formikRef.current.setFieldValue("max",e),this.setState({advancedMode:!this.state.advancedMode})},this.close=e=>{this.props.dismissModal.apply(null,e)},this.platformHealthOverrideChanged=e=>{this.setState({interestingHealthProviderNames:e})},this.isDesiredControlledByAutoscaling=()=>{const{serverGroup:e}=this.props,{suspendedProcesses:t}=e.asg,{advancedMode:a}=this.state;return(e.scalingPolicies||[]).length&&a&&t.every(e=>"AlarmNotification"!==e.processName)},this.submit=e=>{const{min:t,max:a,desired:n,enforceCapacityConstraints:r,reason:i}=e,{interestingHealthProviderNames:s}=this.state,{serverGroup:l,application:o}=this.props,{asg:c}=l,d={capacity:na({min:t!==c.minSize?t:void 0,max:a!==c.maxSize?a:void 0,desired:n!==c.desiredCapacity?n:void 0},e=>void 0!==e),reason:i,interestingHealthProviderNames:s};r&&(d.constraints={capacity:{min:c.minSize,max:c.maxSize,desired:c.desiredCapacity}}),this.state.taskMonitor.submit(()=>h.serverGroupWriter.resizeServerGroup(l,o,d))};const{minSize:t,maxSize:a,desiredCapacity:n}=e.serverGroup.asg,{attributes:r}=e.application;this.state={advancedMode:t!==a,initialValues:{min:t,max:a,desired:n,enforceCapacityConstraints:!1},taskMonitor:new v({application:e.application,title:"Resizing your server group",modalInstance:v.modalInstanceEmulation(()=>this.props.dismissModal()),onTaskComplete:()=>this.props.application.serverGroups.refresh()}),platformHealthOnlyShowOverride:r.platformHealthOnlyShowOverride,interestingHealthProviderNames:r.platformHealthOnlyShowOverride&&r.platformHealthOnly?["Amazon"]:null}}static show(t){const a={},{serverGroup:n,application:r}=t;return lt(n,r).then(n=>{n&&b.show(e,t,a)})}autoIncrementDesiredIfNeeded(){if(!this.isDesiredControlledByAutoscaling())return;const e=this.formikRef.current.getFormikContext(),{asg:t}=this.props.serverGroup,{min:a,max:n,desired:r}=e.values,i=Math.min(n,Math.max(a,t.desiredCapacity));r!==i&&e.setFieldValue("desired",i)}renderSimpleMode(e){const{serverGroup:t}=this.props,{asg:a}=t;return Vt.createElement("div",null,Vt.createElement("p",null,"Sets min, max, and desired instance counts to the same value."),Vt.createElement("p",null,"To allow autoscaling, use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Current size"),Vt.createElement("div",{className:"col-md-4"},Vt.createElement("div",{className:"horizontal middle"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:a.desiredCapacity,disabled:!0}),Vt.createElement("div",{className:"sp-padding-xs-xaxis"},"instances")))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Vt.createElement("div",{className:"col-md-4"},Vt.createElement("div",{className:"horizontal middle"},Vt.createElement(s,{name:"desired",input:e=>Vt.createElement(p,{...e,min:0}),touched:!0,onChange:t=>{e.setFieldValue("min",t),e.setFieldValue("max",t)}}),Vt.createElement("div",{className:"sp-padding-xs-xaxis"},"instances")))))}renderAdvancedMode(e){const{serverGroup:t}=this.props,{errors:a}=e,{asg:n}=t,r=a.min||a.max||a.desired;return Vt.createElement("div",null,Vt.createElement("p",null,"Sets up autoscaling for this server group."),Vt.createElement("p",null,"To disable autoscaling, use the"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Simple Mode"),"."),Vt.createElement("div",{className:"form-group bold"},Vt.createElement("div",{className:"col-md-2 col-md-offset-3"},"Min"),Vt.createElement("div",{className:"col-md-2"},"Max"),Vt.createElement("div",{className:"col-md-2"},"Desired")),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Current"),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:n.minSize,disabled:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:n.maxSize,disabled:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement("input",{type:"number",className:"NumberInput form-control",value:n.desiredCapacity,disabled:!0}))),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(s,{name:"min",input:e=>Vt.createElement(p,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Vt.createElement(Vt.Fragment,null,e),touched:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(s,{name:"max",input:e=>Vt.createElement(p,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Vt.createElement(Vt.Fragment,null,e),touched:!0})),Vt.createElement("div",{className:"col-md-2"},Vt.createElement(s,{name:"desired",input:e=>Vt.createElement(p,{...e,min:0,disabled:this.isDesiredControlledByAutoscaling()}),layout:({input:e})=>Vt.createElement(Vt.Fragment,null,e),touched:!0}))),!!r&&Vt.createElement("div",{className:"col-md-offset-3 col-md-9"},Vt.createElement(pe,{message:r,type:"error"})))}renderCapacityConstraintSelector(){return Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement(s,{name:"enforceCapacityConstraints",input:e=>Vt.createElement(Vt.Fragment,null,Vt.createElement(d,{...e,text:"Enforce Capacity Constraints"}),Vt.createElement(n,{id:"aws.serverGroup.capacityConstraint"}))})))}renderScalingPolicyWarning(e){const{serverGroup:t}=this.props,{min:a,max:n}=e.values,{advancedMode:r}=this.state,i=t.scalingPolicies||[];return i.length&&a===n?Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-7 col-md-offset-3"},Vt.createElement("div",{className:"well-compact alert alert-warning"},Vt.createElement("b",null,"Warning"),": this server group has",1===i.length&&Vt.createElement("span",null," a scaling policy. "),i.length>1&&Vt.createElement("span",null," scaling policies. "),!r&&Vt.createElement("span",null,"Scaling policies will not take effect in Simple Mode. Switch to"," ",Vt.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),r&&Vt.createElement("span",null,"Scaling policies will not take effect when ",Vt.createElement("b",null,"Min")," is the same as ",Vt.createElement("b",null,"Max"),".")))):this.isDesiredControlledByAutoscaling()?Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-8 col-md-offset-1"},Vt.createElement("div",{className:"well-compact alert alert-warning"},Vt.createElement("p",null,Vt.createElement("b",null,"Desired")," capacity is managed by Autoscaling Policies."),Vt.createElement("p",null,"If you need to scale ",Vt.createElement("b",null,"down")," this server group, set ",Vt.createElement("b",null,"Max")," to the new desired size."),Vt.createElement("p",null,"If you need to scale ",Vt.createElement("b",null,"up")," this server group, set ",Vt.createElement("b",null,"Min")," to the new desired size.")))):null}render(){const{serverGroup:e}=this.props,{advancedMode:t,initialValues:a,platformHealthOnlyShowOverride:n}=this.state;return Vt.createElement(Vt.Fragment,null,Vt.createElement(Ct,{monitor:this.state.taskMonitor}),Vt.createElement(le,{ref:this.formikRef,initialValues:a,validate:this.validate,onSubmit:this.submit,render:a=>{const{asg:r}=e,i={min:r.minSize,max:r.maxSize,desired:r.desiredCapacity},s=a.values;return Vt.createElement(Vt.Fragment,null,Vt.createElement(oe,{dismiss:this.close}),Vt.createElement(Ha.Header,null,Vt.createElement(Ha.Title,null,"Resize ",e.name)),Vt.createElement(Ha.Body,null,Vt.createElement(dn,{className:"form-horizontal"},t&&this.renderAdvancedMode(a),!t&&this.renderSimpleMode(a),this.renderScalingPolicyWarning(a),this.renderCapacityConstraintSelector(),n&&Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-8 col-md-offset-3"},Vt.createElement(bt,{interestingHealthProviderNames:this.state.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged,showHelpDetails:!0}))),Vt.createElement(mt,{reason:a.values.reason,onChange:e=>a.setFieldValue("reason",e)}),Vt.createElement("div",{className:"form-group"},Vt.createElement("div",{className:"col-md-3 sm-label-right"},"Changes"),Vt.createElement("div",{className:"col-md-9 sm-control-field"},Vt.createElement(St,{current:i,next:s}))))),Vt.createElement(no,{onSubmit:()=>this.submit(a.values),onCancel:this.close,isValid:a.isValid,account:e.account}))}}))}};ro.defaultProps={closeModal:C,dismissModal:C};let io=ro;var so=Object.getOwnPropertyDescriptor;let lo=class extends Vt.Component{constructor(){super(...arguments),this.resizeServerGroup=()=>{io.show(this.props)}}render(){return Vt.createElement(Ya,{onClick:this.resizeServerGroup},"Resize")}};lo=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?so(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("AmazonServerGroupActions.resize")],lo);class oo extends Vt.Component{constructor(){super(...arguments),this.destroyServerGroup=()=>{const{app:e,serverGroup:t}=this.props,a={application:e,title:"Destroying "+t.name,onTaskComplete:()=>{h.$state.includes("**.serverGroup",n)&&h.$state.go("^")}},n={name:t.name,accountId:t.account,region:t.region},r={header:"Really destroy "+t.name+"?",buttonText:"Destroy "+t.name,account:t.account,taskMonitorConfig:a,interestingHealthProviderNames:void 0,submitMethod:a=>h.serverGroupWriter.destroyServerGroup(t,e,a),askForReason:!0,platformHealthOnlyShowOverride:e.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon"};kt.addDestroyWarningMessage(e,t,r),e.attributes.platformHealthOnlyShowOverride&&e.attributes.platformHealthOnly&&(r.interestingHealthProviderNames=["Amazon"]),S.confirm(r)},this.disableServerGroup=()=>{const{app:e,serverGroup:t}=this.props,a={application:e,title:"Disabling "+t.name},n={header:"Really disable "+t.name+"?",buttonText:"Disable "+t.name,account:t.account,interestingHealthProviderNames:void 0,taskMonitorConfig:a,platformHealthOnlyShowOverride:e.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon",submitMethod:a=>h.serverGroupWriter.disableServerGroup(t,e.name,a),askForReason:!0};kt.addDisableWarningMessage(e,t,n),e.attributes.platformHealthOnlyShowOverride&&e.attributes.platformHealthOnly&&(n.interestingHealthProviderNames=["Amazon"]),S.confirm(n)},this.enableServerGroup=()=>{if(!this.isRollbackEnabled())return void this.showEnableServerGroupModal();const e={header:"Rolling back?",body:"Spinnaker provides an orchestrated rollback feature to carefully restore a different version of this\n server group. Do you want to use the orchestrated rollback?",buttonText:"Yes, take me to the rollback settings modal",cancelButtonText:"No, I just want to enable the server group"};S.confirm(e).then(()=>new Promise(e=>setTimeout(e,500))).then(()=>this.rollbackServerGroup()).catch(e=>{"footer"===(null==e?void 0:e.source)&&this.showEnableServerGroupModal()})},this.rollbackServerGroup=()=>{const{app:e}=this.props;let t,a=this.props.serverGroup,n=e.getDataSource("serverGroups").data.filter(e=>e.cluster===a.cluster&&e.region===a.region&&e.account===a.account);a.isDisabled&&(t=a,a=Xt(n.filter(e=>e.name!==t.name&&!e.isDisabled),["instanceCounts.total","createdTime"],["desc","desc"])[0]),n=n.filter(e=>e.name!==a.name),1!==n.length||t||(t=n[0]),Nt.modalService.open({templateUrl:h.overrideRegistry.getTemplate("aws.rollback.modal","amazon/src/serverGroup/details/rollback/rollbackServerGroup.html"),controller:"awsRollbackServerGroupCtrl as ctrl",resolve:{serverGroup:()=>a,previousServerGroup:()=>t,disabledServerGroups:()=>{const t=ba(e.clusters,{name:a.cluster,account:a.account,serverGroups:[]});return ea(t.serverGroups,{isDisabled:!0,region:a.region})},allServerGroups:()=>n,application:()=>e}})},this.cloneServerGroup=()=>{const{app:e,serverGroup:t}=this.props;Xn.awsServerGroupCommandBuilder.buildServerGroupCommandFromExisting(e,t).then(a=>{const n=`Clone ${t.name}`;ao.show({title:n,application:e,command:a})})}}isEnableLocked(){if(this.props.serverGroup.isDisabled){if((this.props.serverGroup.runningTasks||[]).filter(e=>ia(e,"execution.stages",[]).some(e=>"resizeServerGroup"===e.type)).length)return!0}return!1}isRollbackEnabled(){const{app:e,serverGroup:t}=this.props;return!t.isDisabled||e.getDataSource("serverGroups").data.some(e=>e.cluster===t.cluster&&e.region===t.region&&e.account===t.account&&!e.isDisabled)}hasDisabledInstances(){return this.props.serverGroup.isDisabled||ia(this.props.serverGroup,"instanceCounts.outOfService",0)>0}showEnableServerGroupModal(){const{app:e,serverGroup:t}=this.props,a={application:e,title:"Enabling "+t.name},n={header:"Really enable "+t.name+"?",buttonText:"Enable "+t.name,account:t.account,interestingHealthProviderNames:void 0,taskMonitorConfig:a,platformHealthOnlyShowOverride:e.attributes.platformHealthOnlyShowOverride,platformHealthType:"Amazon",submitMethod:a=>h.serverGroupWriter.enableServerGroup(t,e,a),askForReason:!0};e.attributes.platformHealthOnlyShowOverride&&e.attributes.platformHealthOnly&&(n.interestingHealthProviderNames=["Amazon"]),S.confirm(n)}render(){const{app:e,serverGroup:t}=this.props,n=a.feature&&a.feature.entityTags,r=Tt.buildClusterTargets(t);return Vt.createElement(Vt.Fragment,null,kn.adHocInfraWritesEnabled&&Vt.createElement(qa,{className:"dropdown",id:"server-group-actions-dropdown"},Vt.createElement(qa.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},"Server Group Actions"),Vt.createElement(qa.Menu,{className:"dropdown-menu"},this.isRollbackEnabled()&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.rollbackServerGroup},"Rollback"),this.isRollbackEnabled()&&Vt.createElement("li",{role:"presentation",className:"divider"}),Vt.createElement(lo,{application:e,serverGroup:t}),!t.isDisabled&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.disableServerGroup},"Disable"),this.hasDisabledInstances()&&!this.isEnableLocked()&&Vt.createElement(Ie,{resource:t,application:e,onClick:this.enableServerGroup},"Enable"),this.isEnableLocked()&&Vt.createElement("li",{className:"disabled"},Vt.createElement(ja,{value:"Cannot enable this server group until resize operation completes",placement:"left"},Vt.createElement("a",null,Vt.createElement("span",{className:"small glyphicon glyphicon-lock"})," Enable"))),Vt.createElement(Ie,{resource:t,application:e,onClick:this.destroyServerGroup},"Destroy"),Vt.createElement("li",null,Vt.createElement("a",{className:"clickable",onClick:this.cloneServerGroup},"Clone")),n&&Vt.createElement(N,{component:t,application:e,entityType:"serverGroup",ownerOptions:r,onUpdate:()=>e.serverGroups.refresh()}))))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/rollback/rollbackServerGroup.html",'<div modal-page class="confirmation-modal">\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Rollback {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body confirmation-modal">\n <div class="row">\n <div class="col-sm-3 sm-label-right">Restore to</div>\n <div class="col-md-7">\n <ui-select\n ng-model="command.rollbackContext.restoreServerGroupName"\n class="form-control input-sm"\n ng-if="command.rollbackType === \'EXPLICIT\'"\n >\n <ui-select-match placeholder="Select...">{{ctrl.label($select.selected)}}</ui-select-match>\n <ui-select-choices group-by="ctrl.group" repeat="serverGroup.name as serverGroup in allServerGroups">\n <span ng-bind-html="ctrl.label(serverGroup)"></span>\n </ui-select-choices>\n </ui-select>\n <div ng-if="command.rollbackType === \'PREVIOUS_IMAGE\'" style="margin-top: 5px">\n {{ previousServerGroup.name }} <span class="small">(no longer deployed)</span><br />\n <span class="small">\n <strong>Image</strong>: {{ previousServerGroup.imageName}}\n <span ng-if="previousServerGroup.imageId">({{ previousServerGroup.imageId }})</span><br />\n </span>\n <span class="small" ng-if="previousServerGroup.buildNumber">\n <strong>Build</strong> #{{ previousServerGroup.buildNumber }}\n </span>\n </div>\n </div>\n </div>\n\n <div class="row" ng-if="command.platformHealthOnlyShowOverride">\n <div class="col-sm-10 col-sm-offset-1">\n <platform-health-override\n command="command"\n platform-health-type="\'Amazon\'"\n show-help-details="true"\n field-columns="12"\n >\n </platform-health-override>\n </div>\n </div>\n\n <task-reason command="command"></task-reason>\n\n <div class="row">\n <div class="col-sm-11 col-sm-offset-1">\n Wait\n <input\n placeholder="0"\n min="0"\n type="number"\n ng-model="command.rollbackContext.delayBeforeDisableSeconds"\n class="form-control input-sm inline-number"\n />\n seconds before disabling <em>{{ ctrl.label(serverGroup) }}</em>.\n </div>\n </div>\n\n <div class="row">\n <div class="col-sm-11 col-sm-offset-1">\n Consider rollback successful when\n <input\n type="number"\n min="0"\n max="100"\n ng-model="command.rollbackContext.targetHealthyRollbackPercentage"\n class="form-control input-sm inline-number"\n />\n percent of instances are healthy.\n </div>\n </div>\n\n <div class="row">\n <div class="col-sm-4 sm-label-right">Rollback Operations</div>\n </div>\n <div class="row" ng-if="command.rollbackType === \'EXPLICIT\'">\n <div class="col-sm-11 col-sm-offset-1">\n <ol>\n <li>Enable <em>{{ command.rollbackContext.restoreServerGroupName || \'previous server group\' }}</em></li>\n <li>\n Resize <em>{{ command.rollbackContext.restoreServerGroupName || \'previous server group\' }}</em> to [\n <strong>min</strong>: {{serverGroup.capacity.desired}}, <strong>max</strong>: {{ serverGroup.capacity.max\n }}, <strong>desired</strong>: {{ serverGroup.capacity.desired }} ] <br />(minimum capacity pinned at\n {{serverGroup.capacity.desired}} to prevent autoscaling down during rollback)\n </li>\n\n <li ng-if="command.rollbackContext.targetHealthyRollbackPercentage < 100">\n Wait for at least {{minHealthy(command.rollbackContext.targetHealthyRollbackPercentage)}} instances to\n report as healthy\n </li>\n <li ng-if="command.rollbackContext.delayBeforeDisableSeconds > 0">\n Wait {{ command.rollbackContext.delayBeforeDisableSeconds }} seconds\n </li>\n <li>Disable <em>{{ serverGroup.name }}</em></li>\n <li>\n Restore minimum capacity of\n <em>{{ command.rollbackContext.restoreServerGroupName || \'previous server group\' }}</em> [\n <strong>min</strong>: {{ serverGroup.capacity.min }} ]\n </li>\n </ol>\n <p>This rollback will affect server groups in {{ serverGroup.account }} ({{ serverGroup.region }}).</p>\n </div>\n </div>\n <div class="row" ng-if="command.rollbackType === \'PREVIOUS_IMAGE\'">\n <div class="col-sm-11 col-sm-offset-1">\n <ol>\n <li>\n Deploy <em>{{ previousServerGroup.imageId }}</em> [ <strong>min</strong>:\n {{serverGroup.capacity.desired}}, <strong>max</strong>: {{ serverGroup.capacity.max }},\n <strong>desired</strong>: {{ serverGroup.capacity.desired }} ] <br />(minimum capacity pinned at\n {{serverGroup.capacity.desired}} to prevent autoscaling down during deploy)\n </li>\n <li ng-if="command.rollbackContext.targetHealthyRollbackPercentage < 100">\n Wait for at least {{minHealthy(command.rollbackContext.targetHealthyRollbackPercentage)}} instances to\n report as healthy\n </li>\n <li>Disable {{ serverGroup.name }}</li>\n <li>\n Restore minimum capacity of <em>new server group</em> [ <strong>min</strong>: {{ serverGroup.capacity.min\n }} ]\n </li>\n </ol>\n <p>This rollback will affect server groups in {{ serverGroup.account }} ({{ serverGroup.region }}).</p>\n </div>\n </div>\n </div>\n <aws-footer\n action="ctrl.rollback()"\n cancel="ctrl.cancel()"\n is-valid="ctrl.isValid()"\n account="serverGroup.account"\n verification="verification"\n ></aws-footer>\n </form>\n</div>\n')}]);class co{static getDisabledDate(e){if(e.isDisabled){const t=this.normalizeScalingProcesses(e).find(e=>"AddToLoadBalancer"===e.name&&!e.enabled);if(t)return t.suspensionDate}return null}static normalizeScalingProcesses(e){if(!e.asg||!e.asg.suspendedProcesses)return[];const t=e.asg.suspendedProcesses;return this.listProcesses().map(e=>{const a=t.find(t=>t.processName===e.name),n={name:e.name,enabled:!a,description:e.description};if(a){const e=a.suspensionReason.replace("User suspended at ","");n.suspensionDate=new Date(e).getTime()}return n})}static listProcesses(){return[{name:"Launch",description:"Controls if new instances should be launched into the ASG. If this is disabled, scale-up events will not produce new instances."},{name:"Terminate",description:"Controls if instances should be terminated during a scale-down event."},{name:"AddToLoadBalancer",description:"Controls if new instances should be added to the ASG’s ELB."},{name:"AlarmNotification",description:"This disables autoscaling."},{name:"AZRebalance",description:"Controls whether AWS should attempt to maintain an even distribution of instances across all healthy Availability Zones configured for the ASG."},{name:"HealthCheck",description:"If disabled, the instance’s health will no longer be reported to the autoscaling processor."},{name:"ReplaceUnhealthy",description:"Controls whether instances should be replaced if they failed the health check."},{name:"ScheduledActions",description:"Controls whether scheduled actions should be executed."}]}}function uo(e,t){const{app:a,serverGroup:n}=e;return new Pa(r=>{(function(e){const{app:t,serverGroup:a}=e;return t.ready().then(()=>{let e=t.serverGroups.data.find(e=>e.name===a.name&&e.account===a.accountId&&e.region===a.region);return e||t.loadBalancers.data.some(t=>t.account===a.accountId&&t.region===a.region&&t.serverGroups.some(t=>t.name===a.name&&(e=t,!0))),e})})(e).then(e=>{It.getServerGroup(a.name,n.accountId,n.region,n.name).then(a=>{Object.assign(a,e,{account:n.accountId});const i=Xn.awsServerGroupTransformer.normalizeServerGroupDetails(a);if(o.getAccountDetails(i.account).then(e=>{i.accountDetails=e,r.next(i)}),Wt(i))t();else{const e=i.asg?i.asg.vpczoneIdentifier:"";if(""!==e){const t=e.split(",")[0];g.listSubnets().then(e=>{const a=e.find(e=>e.id===t);i.subnetType=a.purpose,r.next(i)})}i.disabledDate=co.getDisabledDate(i),r.next(i)}},t)},t)})}function po(e){const t=Ot.useRef(),a=Ot.useRef(),{lines:n,className:r="",style:i={}}=e;return Ot.useEffect(()=>t?(a.current=function(e){const t={type:"line",data:{labels:[],datasets:[{data:[]}]},options:{plugins:{tooltip:{mode:"index",itemSort:(e,t)=>{var a,n;const r=e.chart.data.datasets.map(e=>e.label),i=null!=(a=e.dataset.label)?a:r[0],s=null!=(n=t.dataset.label)?n:r[0];return r.indexOf(s)-r.indexOf(i)}}},hover:{mode:"index"},elements:{point:{hitRadius:12,radius:1,hoverRadius:5}},scales:{x:{type:"time",display:!0,scaleLabel:{labelString:"Date"},ticks:{major:{enabled:!0}}},y:{min:0,stacked:!0}}}};return new mn(e,t)}(t.current),()=>{var e;return null==(e=a.current)?void 0:e.destroy()}):null,[t.current]),Ot.useEffect(()=>{const e=a.current;e&&n&&(e.options.animation=!1,e.data.datasets=n,e.update())},[a.current,n]),Ot.createElement("canvas",{ref:t,...i,className:r})}function mo(e){return e.serverGroup&&e.alarm?Ot.createElement(go,{...e}):null}function go(e){var t,a;const n=null!=(t=e.alarm)?t:{},r=null!=(a=e.serverGroup)?a:{},{account:i,awsAccount:s,region:l,type:o}=r,{metricName:c,namespace:d,statistic:u,period:p}=n,{status:m,result:g}=F(async()=>{var t;const a={namespace:d,statistics:u,period:p};n.dimensions.forEach(e=>a[e.name]=e.value);const r="aws"===o?i:s,m=await Gt.getMetricStatistics("aws",r,l,c,a);return m.datapoints=m.datapoints||[],null==(t=e.onChartLoaded)||t.call(e,m),m},{datapoints:[],unit:""},[d,u,p,o,i,l,c,n.dimensions]);if("PENDING"===m)return Ot.createElement("div",{className:"flex-container-v middle center sp-margin-xl"},Ot.createElement(ae,null));if("REJECTED"===m)return Ot.createElement(Ot.Fragment,null,Ot.createElement("div",null,"no data"),Ot.createElement("div",null,"something went wrong fetching stats"));if(0===g.datapoints.length)return Ot.createElement(Ot.Fragment,null,"no data");const h=new Date,f=new Date(Date.now()-864e5),v={label:c,fill:"stack",borderColor:"green",borderWidth:2,data:g.datapoints.map(e=>({x:new Date(e.timestamp),y:ia(e,[n.statistic.toLowerCase()],void 0)}))},y={label:"threshold",borderWidth:1,borderColor:"red",data:[{x:f,y:n.threshold},{x:h,y:n.threshold}]};return Ot.createElement(po,{lines:[v,y]})}mn.register(gn,hn,fn,vn,yn,bn,En,wn,Cn);const ho={ASGAverageCPUUtilization:"CPUUtilization",ASGAverageNetworkIn:"NetworkIn",ASGAverageNetworkOut:"NetworkOut",ALBRequestCountPerTarget:"RequestCountPerTarget"},fo=({config:e,serverGroup:t,updateUnit:a})=>{const[n,r]=Ot.useState({alarmName:null,alarmArn:null,metricName:null,namespace:null,statistic:"Average",dimensions:[],period:60,threshold:e.targetValue,comparisonOperator:"GreaterThanThreshold",okactions:[],insufficientDataActions:[],alarmActions:[],evaluationPeriods:null,alarmDescription:null,unit:null});Ot.useEffect(()=>{(()=>{const a=null==e?void 0:e.customizedMetricSpecification,i=null==e?void 0:e.predefinedMetricSpecification,s={...n,dimensions:(null==a?void 0:a.dimensions)||[{name:"AutoScalingGroupName",value:t.name}],metricName:(null==a?void 0:a.metricName)||ho[null==i?void 0:i.predefinedMetricType],namespace:(null==a?void 0:a.namespace)||"AWS/EC2",threshold:null==e?void 0:e.targetValue};if(a&&(s.statistic=null==a?void 0:a.statistic),i&&"ALBRequestCountPerTarget"===i.predefinedMetricType&&(s.statistic="Sum",s.namespace="AWS/ApplicationELB",null==i?void 0:i.resourceLabel)){const e=null==i?void 0:i.resourceLabel.split("/"),t=e.slice(0,3).join("/"),a=e.slice(3).join("/");s.dimensions=[{name:"LoadBalancer",value:t},{name:"TargetGroup",value:a}]}r(s)})()},[e]);return Ot.createElement(mo,{alarm:n,onChartLoaded:e=>{a&&a(e.unit)},serverGroup:t})};Ar("dimensions-editor {\n display: block;\n padding-left: 5px;\n}\ndimensions-editor h5 {\n margin-bottom: 0;\n}\ndimensions-editor .dimensions-row {\n margin-top: 5px;\n margin-left: -20px;\n}\ndimensions-editor .add-new {\n margin-left: 0;\n padding: 4px;\n width: 100%;\n}\n");const vo=({alarm:e,serverGroup:t,updateAvailableMetrics:a})=>{const n=e.dimensions||[],{result:r}=F(()=>Gt.listMetrics("aws",t.account,t.region,{namespace:e.namespace}).then(e=>{const t=Ea(e,e=>e.dimensions);return sa(t.filter(e=>e).map(e=>e.name)).sort()}).catch(()=>[]),[],[e.namespace,t.name]),i=(e,t,r)=>{const i=[...n];i[r][e]=t,a(i)};return Ot.createElement("div",null,Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12 small"},Ot.createElement("h5",null,"Dimensions"))),n.map((t,n)=>Ot.createElement("div",{key:`dimension-${n}`,className:"row dimensions-row horizontal middle"},Ot.createElement("div",{className:"col-md-6"},Ot.createElement(c,{onChange:e=>i("name",e.target.value,n),value:t.name,stringOptions:r})),Ot.createElement(l,{onChange:e=>i("value",e.target.value,n),value:t.value}),!e.disableEditingDimensions&&Ot.createElement("div",{className:"col-md-1",onClick:()=>(t=>{const n=e.dimensions.filter((e,a)=>a!==t);a(n)})(n)},Ot.createElement("a",null,Ot.createElement("i",{className:"glyphicon glyphicon-trash clickable"}))))),!e.disableEditingDimensions&&Ot.createElement("div",{className:"row"},Ot.createElement("div",null,Ot.createElement("button",{type:"button",className:"btn btn-block btn-xs add-new",onClick:()=>{const e=[...n,{}];a(e)}},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign sp-margin-xs-left"}),"Add dimension"))))},yo=["AWS/ApplicationELB","AWS/AutoScaling","AWS/AmazonMQ","AWS/Billing","AWS/CloudFront","AWS/CloudSearch","AWS/Events","AWS/DynamoDB","AWS/ECS","AWS/ElastiCache","AWS/EBS","AWS/EC2","AWS/ELB","AWS/ElasticMapReduce","AWS/ES","AWS/Kinesis","AWS/Lambda","AWS/ML","AWS/OpsWorks","AWS/Redshift","AWS/RDS","AWS/Route53","AWS/SNS","AWS/SQS","AWS/S3","AWS/SWF","AWS/StorageGateway","AWS/WAF","AWS/WorkSpaces"];Ar(".MetricSelector {\n font-size: 12px;\n}\n.MetricSelector .simple-input {\n width: 216px;\n}\n.MetricSelector .advanced-input-namespace {\n width: 138px;\n}\n.MetricSelector .advanced-input-metric {\n width: 300px;\n}\n");const bo=({alarm:e,updateAlarm:t,serverGroup:a})=>{var r,i;const s=((null==(i=null==(r=kn)?void 0:r.metrics)?void 0:i.customNamespaces)||[]).concat(yo),[l,o]=Ot.useState(!1),d=((null==e?void 0:e.dimensions)||[]).reduce((e,t)=>(e[t.name]=t.value,e),{}),{result:u}=F(()=>{const t="aws"===a.cloudProvider?a.account:null==a?void 0:a.awsAccount,n=l?{namespace:null==e?void 0:e.namespace}:{AutoScalingGroupName:a.name};return Gt.listMetrics("aws",t,a.region,n).then(e=>(e||[]).map(e=>{return{label:`(${e.namespace}) ${e.name}`,dimensions:[],dimensionValues:(t=e.dimensions||[],t.sort((e,t)=>{var a;return null==(a=e.name)?void 0:a.localeCompare(t.name)}).map(e=>e.value).join(", ")),value:e,...e};var t}).sort((e,t)=>{var a;return null==(a=e.label)?void 0:a.localeCompare(t.label)})).catch(()=>[])},[],[a,null==e?void 0:e.namespace]),p=(u||[]).filter(t=>t.namespace===(null==e?void 0:e.namespace)),m=p.find(t=>t.name===(null==e?void 0:e.metricName)&&t.namespace===(null==e?void 0:e.namespace))||p.find(e=>e.name.match("CPUUtilization"))||p[0],{name:g,namespace:h}=m||{},f=()=>{const n=!l;if(n)d.namespace=null==e?void 0:e.namespace;else{const n={...e,dimension:[{name:"AutoScalingGroupName",value:a.name}]};t(n)}o(n)},v=a=>{const n={...e,metricName:a.name,namespace:a.namespace,dimensions:a.dimensions};t(n)},y=(a,n)=>{const r={...e,metricName:n,namespace:a};t(r)};return Ot.useEffect(()=>{m&&v(m)},[m]),l?Ot.createElement("div",{className:"MetricSelector"},Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(c,{value:h,onChange:t=>y(t.target.value,null==e?void 0:e.metricName),stringOptions:s,inputClassName:"advanced-input-namespace sp-margin-m-right"}),Ot.createElement(c,{value:g,onChange:t=>y(null==e?void 0:e.namespace,t.target.value),stringOptions:u.map(e=>e.name),placeholder:"name",searchable:!0,inputClassName:"advanced-input-metric"})),Ot.createElement("div",{className:"vertical"},!Boolean(u.length)&&Ot.createElement("span",{className:"input-label"},Ot.createElement("b",null,"Note:")," no metrics found for selected namespace + dimensions"),Ot.createElement("a",{className:"clickable",onClick:f},Ot.createElement("span",{className:"sp-margin-s-yaxis sp-margin-xs-right"},"Only show metrics for this auto scaling group"),Ot.createElement(n,{id:"aws.scalingPolicy.search.restricted"}))),Ot.createElement(vo,{alarm:e,serverGroup:a,updateAvailableMetrics:a=>{const n={...e,dimensions:a};t(n)}})):Ot.createElement("div",{className:"MetricSelector horizontal middle"},Ot.createElement(c,{value:m,onChange:e=>v(e.target.value),options:u,clearable:!1,inputClassName:"sp-margin-s-right simple-input"}),Ot.createElement("a",{className:"clickable",onClick:f},Ot.createElement("span",{className:"sp-margin-xs-right"},"Search all metrics"),Ot.createElement(n,{id:"aws.scalingPolicy.search.all"})))};Ar(".TargetMetricFields .metric-select-input {\n font-size: 12px;\n width: 180px;\n}\n.TargetMetricFields .target-input {\n width: 120px;\n}\n");const Eo=({allowDualMode:e,cloudwatch:t,command:a,isCustomMetric:n,app:r,serverGroup:i,toggleMetricType:s,updateCommand:l})=>{var o,d,u,m;const[g,h]=Ot.useState(null),f=(e,t)=>{const n=_t(a);da(n,e,t),l(n)};return Ot.createElement("div",{className:"TargetMetricFields sp-margin-l-xaxis"},Ot.createElement("p",null,"With target tracking policies, Amazon will automatically adjust the size of your ASG to keep the selected metric as close as possible to the selected value."),t&&Ot.createElement("p",null,Ot.createElement("b",null,"Note:"),' metrics must be sent to Amazon CloudWatch before they can be used in auto scaling. If you do not see a metric below, click "Configure available metrics" in the server group details to set up forwarding from Atlas to CloudWatch.'),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Metric"),Ot.createElement("div",{className:"col-md-10 content-fields"},!n&&Ot.createElement(c,{value:null==(o=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:o.predefinedMetricType,stringOptions:["ASGAverageCPUUtilization","ASGAverageNetworkOut","ASGAverageNetworkIn","ALBRequestCountPerTarget"],onChange:e=>f("targetTrackingConfiguration.predefinedMetricSpecification.predefinedMetricType",e.target.value),inputClassName:"metric-select-input"}),n&&Ot.createElement(bo,{alarm:a.targetTrackingConfiguration.customizedMetricSpecification,serverGroup:i,updateAlarm:e=>{f("targetTrackingConfiguration.customizedMetricSpecification",e)}}),e&&Ot.createElement("a",{className:"clickable",onClick:()=>{const e=_t(a);n?(da(e,"targetTrackingConfiguration.predefinedMetricSpecification",{predefinedMetricType:"ASGAverageCPUUtilization"}),da(e,"targetTrackingConfiguration.customizedMetricSpecification",null)):(da(e,"targetTrackingConfiguration.predefinedMetricSpecification",null),da(e,"targetTrackingConfiguration.customizedMetricSpecification",{metricName:"CPUUtilization",namespace:"AWS/EC2",dimensions:[{name:"AutoScalingGroupName",value:i.name}],statistic:"Average"})),l(e),s(n?"predefined":"custom")}},n?"Use a predefined metric":"Select a custom metric"))),!n&&"ALBRequestCountPerTarget"===(null==(d=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:d.predefinedMetricType)&&Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Target Group"),Ot.createElement("div",{className:"col-md-10 content-fields horizontal"},Ot.createElement(c,{value:null==(u=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:u.resourceLabel,options:r.loadBalancers.data.filter(e=>e.account===i.account&&e.region===i.region).flatMap(e=>e.targetGroups.filter(e=>i.targetGroups.some(t=>t===e.name)).map(t=>({...t,loadBalancerArn:e.loadBalancerArn}))).map(e=>({label:e.name,value:`${e.loadBalancerArn.substring(e.loadBalancerArn.indexOf("app"))}/${e.targetGroupArn.substring(e.targetGroupArn.indexOf("targetgroup"))}`})),onChange:e=>f("targetTrackingConfiguration.predefinedMetricSpecification.resourceLabel",e.target.value),inputClassName:"metric-select-input"}))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Target"),Ot.createElement("div",{className:"col-md-10 content-fields horizontal"},n&&Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(c,{value:null==(m=a.targetTrackingConfiguration.customizedMetricSpecification)?void 0:m.statistic,stringOptions:["Average","Maximum","Minimum","SampleCount","Sum"],onChange:e=>f("targetTrackingConfiguration.customizedMetricSpecification.statistic",e.target.value),inputClassName:"form-control input-sm target-input"}),Ot.createElement("span",{className:"sp-margin-xs-xaxis"},"of")),Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(p,{value:a.targetTrackingConfiguration.targetValue,onChange:e=>f("targetTrackingConfiguration.targetValue",Number.parseInt(e.target.value)),inputClassName:"form-control input-sm sp-margin-xs-right"}),Ot.createElement("span",null,g)))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement(fo,{config:a.targetTrackingConfiguration,serverGroup:i,unit:g,updateUnit:e=>h(e)}))))};Ar(".TargetTrackingAdditionalSettings {\n font-size: 14px;\n}\n.TargetTrackingAdditionalSettings .row {\n margin-bottom: 10px;\n}\n.TargetTrackingAdditionalSettings .number-input-sm {\n width: 120px;\n}\n");const wo=({command:e,cooldowns:t,policyName:a,updateCommand:r})=>{var i;const s=(t,a)=>{const n={...e};da(n,t,a),r(n)},l=null==(i=e.targetTrackingConfiguration)?void 0:i.disableScaleIn;return Ot.createElement("div",{className:"section-body TargetTrackingAdditionalSettings"},a&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},a)),Boolean(e.estimatedInstanceWarmup)&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static"},"Instances need"),Ot.createElement(p,{value:e.estimatedInstanceWarmup,onChange:e=>s("estimatedInstanceWarmup",Number.parseInt(e.target.value)),inputClassName:"form-control number-input-sm sp-margin-xs-xaxis"}),Ot.createElement("span",{className:"input-label"}," seconds to warm up "))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Scale In"),Ot.createElement("div",{className:"col-md-9"},Ot.createElement("div",{className:"checkbox"},Ot.createElement(d,{text:"Disable Scale-downs",checked:l,onChange:e=>s("targetTrackingConfiguration.disableScaleIn",e.target.checked)}),Ot.createElement("div",{className:"small"},Ot.createElement("p",null,"This option disables scale-downs for the target tracking policy, while keeping the scale-ups. This means that ASG will not scale down unless you explicitly set up a separate step policy to scale it down."),Ot.createElement("p",null,"This is useful when you have special requirements, such as gradual or delayed scale-down."))))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},l&&Ot.createElement("div",{className:"well"},"This policy will not scale down. Make sure you have another policy (either TT or Step) that will scale down this ASG."),!1===l&&Ot.createElement("div",{className:"well"},"This policy will scale both up and down. Make sure you don't have other scaling policies, as they will likely interfere with each other."))),t&&!l&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("span",{className:"sp-margin-xs-right"},"Scale In Cooldown"),Ot.createElement(n,{id:"titus.autoscaling.scaleIn.cooldown"})),Ot.createElement("div",{className:"col-md-9 horizontal middle"},Ot.createElement(p,{value:e.targetTrackingConfiguration.scaleInCooldown,onChange:e=>s("targetTrackingConfiguration.scaleInCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds "))),t&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("span",{className:"sp-margin-xs-right"},"Scale Out Cooldown"),Ot.createElement(n,{id:"titus.autoscaling.scaleOut.cooldown"})),Ot.createElement("div",{className:"col-md-9 horizontal middle"},Ot.createElement(p,{value:e.targetTrackingConfiguration.scaleOutCooldown,onChange:e=>s("targetTrackingConfiguration.scaleOutCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds "))))},Co={buildAlarm:(e,t,a)=>{const n=(null==e?void 0:e.alarms)?e.alarms[0]:{};return{name:n.alarmName,actionsEnabled:!0,alarmActionArns:n.alarmActions,alarmDescription:n.alarmDescription,asgName:a,comparisonOperator:n.comparisonOperator,dimensions:n.dimensions,evaluationPeriods:n.evaluationPeriods,insufficientDataActionArns:n.insufficientDataActions,metricName:n.metricName,namespace:n.namespace,okActionArns:n.okactions,period:n.period,region:t,statistic:n.statistic,threshold:n.threshold,unit:n.unit}},buildStepPolicy:(e,t,a)=>{var n,r;const i=e.stepAdjustments.map(e=>{const a={scalingAdjustment:Math.abs(e.scalingAdjustment)};return void 0!==e.metricIntervalUpperBound&&(a.metricIntervalUpperBound=e.metricIntervalUpperBound+t),void 0!==e.metricIntervalLowerBound&&(a.metricIntervalLowerBound=e.metricIntervalLowerBound+t),a});return{estimatedInstanceWarmup:null!=(r=null!=(n=e.estimatedInstanceWarmup)?n:a)?r:600,metricAggregationType:"Average",stepAdjustments:i}},buildSimplePolicy:e=>{var t,a;return{cooldown:null!=(t=e.cooldown)?t:600,scalingAdjustment:null!=(a=Math.abs(e.scalingAdjustment))?a:1}},buildNewCommand:(e,t,a)=>{var n,r,i;const s={name:a.policyName,adjustmentType:"Step"===e?a.adjustmentType:null,cloudProvider:t.cloudProvider,credentials:t.account,provider:t.type,region:t.region,serverGroupName:t.name};return"Step"===e&&(s.alarm=Co.buildAlarm(a,t.region,t.name),s.minAdjustmentMagnitude=null!=(n=a.minAdjustmentMagnitude)?n:1,(null==(r=a.stepAdjustments)?void 0:r.length)?s.step=Co.buildStepPolicy(a,s.alarm.threshold,s.cooldown):s.simple=Co.buildSimplePolicy(a)),"TargetTracking"===e&&(s.estimatedInstanceWarmup=null!=(i=a.estimatedInstanceWarmup)?i:600,s.targetTrackingConfiguration={...a.targetTrackingConfiguration}),s},prepareCommandForUpsert:(e,t)=>{const a=_t(e);return"PercentChangeInCapacity"!==a.adjustmentType&&delete a.minAdjustmentMagnitude,a.step?a.step.stepAdjustments.forEach(e=>{t&&(e.scalingAdjustment=0-e.scalingAdjustment,delete a.step.estimatedInstanceWarmup),void 0!==e.metricIntervalLowerBound&&(e.metricIntervalLowerBound-=a.alarm.threshold),void 0!==e.metricIntervalUpperBound&&(e.metricIntervalUpperBound-=a.alarm.threshold)}):t&&(e.simple.scalingAdjustment=0-e.simple.scalingAdjustment),a}},So=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i;const[s,l]=Ot.useState(Boolean(null==(i=n.targetTrackingConfiguration)?void 0:i.customizedMetricSpecification)),[o,c]=Ot.useState({});Ot.useEffect(()=>{const e=Co.buildNewCommand("TargetTracking",r,n);c(e)},[]);const d=n.policyName?"Update":"Create";return Ot.createElement(At,{closeModal:t,dismissModal:a,title:`${d} scaling policy`,application:e,description:`${d} scaling policy for ${r.name}`,initialValues:o,mapValuesToTask:()=>({application:e,job:[{type:"upsertScalingPolicy",...o}]}),render:()=>Ot.createElement("div",{className:"modal-body"},Ot.createElement("h4",{className:"section-heading"},"Target Metric"),Ot.createElement(Eo,{allowDualMode:!0,cloudwatch:!1,command:o,isCustomMetric:s,app:e,serverGroup:r,toggleMetricType:e=>l("custom"===e),updateCommand:c}),Ot.createElement("h4",{className:"section-heading"},"Additional Settings"),Ot.createElement(wo,{command:o,cooldowns:!1,policyName:n.policyName,updateCommand:c}))})};function ko(e){const[t,a]=Vt.useState(null),r=e=>{a(e.currentTarget.id)},i="step"===t?"card active":"card",s="targetTracking"===t?"card active":"card",l="aws.scalingPolicy.additionalHelp",o=!!P.getHelpField(l);return Vt.createElement(Ha,{show:!0,onHide:e.showCallback},Vt.createElement(Ha.Header,{closeButton:!0},Vt.createElement("h3",null,"Select a policy type")),Vt.createElement(Ha.Body,null,Vt.createElement("div",{className:"card-choices"},Vt.createElement("div",{className:s,onClick:r,id:"targetTracking"},Vt.createElement("h3",null,"Target Tracking"),Vt.createElement("div",null,"Continuously adjusts the size of the ASG to keep a specified metric at the target value")),Vt.createElement("div",{className:i,onClick:r,id:"step"},Vt.createElement("h3",null,"Step"),Vt.createElement("div",null,"Rule-based scaling, with the ability to define different scaling amounts depending on the magnitude of the alarm breach"))),o&&Vt.createElement(pe,{type:"info",message:Vt.createElement(n,{id:l,expand:!0})}),e.warnOnMinMaxCapacity&&Vt.createElement(pe,{type:"warning",message:Vt.createElement(Vt.Fragment,null,Vt.createElement("p",null,"This server group's ",Vt.createElement("em",null,"min")," and ",Vt.createElement("em",null,"max")," capacity are identical, so scaling policies will have ",Vt.createElement("b",null,"no effect.")),Vt.createElement("p",null,"Scaling policies work by adjusting the server group's ",Vt.createElement("em",null,"desired")," capacity to a value between the min and max."))})),Vt.createElement(Ha.Footer,null,Vt.createElement("button",{className:"btn btn-default",onClick:e.showCallback},"Cancel"),Vt.createElement("button",{className:"btn btn-primary",disabled:!t,onClick:()=>{e.typeSelectedCallback(t)}},"Next")))}Ar(".ScalingPolicyAdditionalSettings .section-additional-settings .row {\n margin-bottom: 10px;\n}\n.ScalingPolicyAdditionalSettings .section-additional-settings .number-input-sm {\n width: 60px;\n}\n");const No=({command:e,isInstanceType:t,isNew:a,operator:r,updateCommand:i})=>{var s,l,o,c;const d=(t,a)=>{const n={...e};da(n,t,a),i(n)};return Ot.createElement("div",{className:"ScalingPolicyAdditionalSettings"},Ot.createElement("h4",{className:"section-heading"},"Additional Settings"),Ot.createElement("div",{className:"section-body section-additional-settings"},!a&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"},e.name))),!t&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Adjustment Step"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"},`${r} instances in increments of at least `),Ot.createElement(p,{value:e.minAdjustmentMagnitude,onChange:e=>d("minAdjustmentMagnitude",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," instance(s) "))),Boolean(e.simple)&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Cooldown"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"}," Wait at least "),Ot.createElement(p,{value:null==(s=e.simple)?void 0:s.cooldown,onChange:e=>d("simple.cooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds before another scaling event "))),Boolean(null==(l=e.step)?void 0:l.estimatedInstanceWarmup)&&"Remove"!==r&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement("span",{className:"form-control-static select-placeholder"},"Instances need"),Ot.createElement(p,{value:e.step.estimatedInstanceWarmup,onChange:e=>d("step.estimatedInstanceWarmup",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds to warm up after each step "))),Boolean(null==(o=e.step)?void 0:o.cooldown)&&"Remove"!==r&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},Ot.createElement("span",{className:"sp-margin-xs-right"},"Cooldown"),Ot.createElement(n,{id:`${e.cloudProvider||e.provider}.autoscaling.cooldown`})),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement(p,{value:null==(c=e.step)?void 0:c.cooldown,onChange:e=>d("step.cooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Ot.createElement("span",{className:"input-label"}," seconds ")))))};Ar(".AlarmConfigurer {\n font-size: 12px;\n margin: 0px;\n}\n.AlarmConfigurer .configurer-field-lg {\n width: 90px;\n}\n.AlarmConfigurer .configurer-field-small {\n width: 32px;\n}\n.AlarmConfigurer .configurer-field-med {\n width: 60px;\n}\n.AlarmConfigurer .number-input-field {\n margin: 0px;\n}\n");const To=["Average","Maximum","Minimum","SampleCount","Sum"],Io=[{label:">=",value:"GreaterThanOrEqualToThreshold"},{label:">",value:"GreaterThanThreshold"},{label:"<=",value:"LessThanOrEqualToThreshold"},{label:"<",value:"LessThanThreshold"}],Go=[{label:"1 minute",value:60},{label:"5 minutes",value:300},{label:"15 minutes",value:900},{label:"1 hour",value:3600},{label:"4 hours",value:14400},{label:"1 day",value:86400}],Ao=({alarm:e,multipleAlarms:t,serverGroup:a,stepAdjustments:n,stepsChanged:r,updateAlarm:i})=>{var s,l;const o=0===(null==(s=e.comparisonOperator)?void 0:s.indexOf("Greater"))?"max":"min",[d,u]=Ot.useState(null==e?void 0:e.unit),m=vt(o);Ot.useEffect(()=>{if(n&&void 0!==m){const t="max"===o?"metricIntervalLowerBound":"metricIntervalUpperBound",a={scalingAdjustment:1,[t]:e.threshold};r([a])}},[o]),Ot.useEffect(()=>{const t="max"===o?"metricIntervalLowerBound":"metricIntervalUpperBound";if(null==n?void 0:n.length){const a=[...n];a[0][t]=e.threshold,r(a)}},[e.threshold]);const g=(t,a)=>{const n={...e,[t]:a};i(n)};return Ot.createElement("div",{className:"AlarmConfigurer"},t&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"})," This scaling policy is configured with multiple alarms. You are only editing the first alarm."),Ot.createElement("p",null,"To edit or remove the additional alarms, you will need to use the AWS console.")))),(null==(l=e.alarmActionArns)?void 0:l.length)>1&&Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"})," This alarm is used in multiple scaling policies. Any changes here will affect those other scaling policies.")))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"Whenever"),Ot.createElement("div",{className:"col-md-10 horizontal"},Ot.createElement(c,{value:e.statistic,onChange:e=>g("statistic",e.target.value),stringOptions:To,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}),Ot.createElement("span",{className:"input-label sp-margin-xs-right sp-margin-s-top"}," of "),Ot.createElement(bo,{alarm:e,serverGroup:a,updateAlarm:e=>{i(e)}}))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"is"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement(c,{value:e.comparisonOperator,onChange:e=>g("comparisonOperator",e.target.value),options:Io,clearable:!1,inputClassName:"sp-margin-s-right configurer-field-small"}),Ot.createElement("div",{className:"sp-margin-xl-left"},Ot.createElement(p,{value:e.threshold,onChange:e=>g("threshold",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-right configurer-field-lg"})),Ot.createElement("span",{className:"input-label"},d))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-2 sm-label-right"},"for at least"),Ot.createElement("div",{className:"col-md-10 horizontal middle"},Ot.createElement(p,{value:e.evaluationPeriods,onChange:e=>g("evaluationPeriods",Number.parseInt(e.target.value)),inputClassName:"configurer-field-med number-input-field"}),Ot.createElement("span",{className:"input-label sp-margin-s-xaxis"}," consecutive period(s) of "),Ot.createElement(c,{value:e.period,onChange:e=>g("period",e.target.value),options:Go,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}))),Ot.createElement("div",{className:"row sp-margin-s-yaxis"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},e&&Ot.createElement("div",null,Ot.createElement(mo,{alarm:e,serverGroup:a,onChartLoaded:e=>u(e.unit)})))))};Ar(".SimplePolicyAction .action-input {\n width: 65px;\n}\n.SimplePolicyAction .adjustment-type-input {\n width: 110px;\n}\n");const xo=({adjustmentType:e,adjustmentTypeChanged:t,operator:a,scalingAdjustment:n,updateScalingAdjustment:r})=>{const i="Set to"===a?["instances"]:["instances","percent of group"],[s,l]=Ot.useState(e),[o,d]=Ot.useState(n);return Ot.createElement("div",{className:"SimplePolicyAction row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1 horizontal middle"},Ot.createElement(c,{value:a,stringOptions:["Add","Remove","Set to"],onChange:a=>{return n=a.target.value,void t(n,e);var n},clearable:!1,inputClassName:"action-input"}),Ot.createElement(p,{value:o,min:1,onChange:e=>{return t=Number.parseInt(e.target.value),d(t),void r(t);var t},inputClassName:"action-input"}),Ot.createElement(c,{value:s,stringOptions:i,onChange:e=>{return n=e.target.value,l(n),void t(a,n);var n},clearable:!1,inputClassName:"adjustment-type-input"})))};Ar(".StepPolicyAction .step-policy-row {\n padding: 5px 0;\n border-bottom: 1px solid var(--color-seashell);\n}\n.StepPolicyAction .step-policy-row .action-input {\n width: 65px !important;\n}\n.StepPolicyAction .step-policy-row .adjustment-type-input {\n width: 110px;\n}\n.StepPolicyAction .step-policy-row .remove-step-action-icon {\n margin-left: auto;\n}\n");const Po=({adjustmentType:e,adjustmentTypeChanged:t,alarm:a,isMin:n,operator:r,step:i,stepAdjustments:s,stepsChanged:l})=>{const o=null==a?void 0:a.comparisonOperator.includes("Equal"),d=["Add","Remove","Set to"],u="Set to"===r?["instances"]:["instances","percent of group"],m=(null==i?void 0:i.stepAdjustments)||s,g=(e,t)=>{const a=[...m];a[t]=e,l(a)};return Ot.createElement("div",{className:"StepPolicyAction row"},null==m?void 0:m.map((i,s)=>Ot.createElement("div",{key:`step-adjustment-${s}`,className:"step-policy-row col-md-10 col-md-offset-1 horizontal middle"},Boolean(s)?Ot.createElement("span",{className:"action-input sp-margin-xs-left"},r):Ot.createElement(c,{value:r,stringOptions:d,onChange:a=>{return n=a.target.value,void t(n,e);var n},clearable:!1,inputClassName:"action-input sp-margin-xs-right"}),Ot.createElement(p,{value:i.scalingAdjustment,min:1,onChange:e=>g({...i,scalingAdjustment:Number.parseInt(e.target.value)},s),inputClassName:"action-input"}),Boolean(s)?Ot.createElement("span",{className:"sp-margin-xs-left"},e):Ot.createElement(c,{value:e,stringOptions:u,onChange:e=>{return a=e.target.value,void t(r,a);var a},clearable:!1,inputClassName:"adjustment-type-input sp-margin-xs-left"}),Ot.createElement("span",{className:"sp-margin-xs-xaxis"}," ","when ",Ot.createElement("b",null,null==a?void 0:a.metricName)," is"," "),s===m.length-1&&Ot.createElement("span",null,` ${n?"less":"greater"} than${!Boolean(s)||o?" or equal to":""} ${n?i.metricIntervalUpperBound||"":i.metricIntervalLowerBound||""} `),s<m.length-1&&Ot.createElement(Ot.Fragment,null,Ot.createElement("span",{className:"sp-margin-xs-xaxis"},"between"),n?Ot.createElement(p,{value:i.metricIntervalLowerBound,max:i.metricIntervalUpperBound,step:.1,onChange:e=>g({...i,metricIntervalLowerBound:Number.parseFloat(e.target.value)},s),inputClassName:"action-input"}):Ot.createElement("span",null,i.metricIntervalLowerBound),Ot.createElement("span",{className:"sp-margin-xs-xaxis"},"and"),n?Ot.createElement("span",null,i.metricIntervalUpperBound):Ot.createElement(p,{value:i.metricIntervalUpperBound,min:i.metricIntervalLowerBound,step:.1,onChange:e=>g({...i,metricIntervalUpperBound:Number.parseFloat(e.target.value)},s),inputClassName:"action-input"})),Boolean(s)&&Ot.createElement("a",{className:"glyphicon glyphicon-trash clickable sp-margin-xs-xaxis remove-step-action-icon",onClick:()=>(e=>{const t=m.filter((t,a)=>a!==e);l(t)})(s)}))),Ot.createElement("div",{className:"row sp-margin-s"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement("button",{type:"button",className:"btn btn-block btn-sm add-new",onClick:()=>{const e=[...m,{scalingAdjustment:1}];l(e)}},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),"Add step"))),Ot.createElement("div",{className:"row sp-margin-s-xaxis"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement("a",{href:"http://docs.aws.amazon.com/autoscaling/latest/userguide/as-scale-based-on-demand.html#as-scaling-steps",target:"_blank"},Ot.createElement("i",{className:"far fa-file-alt sp-margin-xs-right"}),"Documentation"))))},Do=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i,s,l;const o={closeModal:t,dismissModal:a},[c,d]=Ot.useState({});Ot.useEffect(()=>{const e=Co.buildNewCommand("Step",r,n);d(e)},[]);const u=(null==(i=n.stepAdjustments)?void 0:i.length)?n.stepAdjustments[0].scalingAdjustment:n.scalingAdjustment,[p,m]=Ot.useState("ExactCapacity"===c.adjustmentType?"Set to":u>0?"Add":"Remove"),g="ExactCapacity"===c.adjustmentType||"ChangeInCapacity"===c.adjustmentType?"instances":"percent of group",h=c.step,f=n.policyARN?"Edit":"Create",v=0===(null==(l=null==(s=null==c?void 0:c.alarm)?void 0:s.comparisonOperator)?void 0:l.indexOf("Greater"))?"max":"min",y=e=>{const t="min"===v?"metricIntervalLowerBound":"metricIntervalUpperBound",a="metricIntervalLowerBound"===t?"metricIntervalUpperBound":"metricIntervalLowerBound",n=e.stepAdjustments;(n||[]).forEach((e,r)=>{n.length>r+1&&(n[r+1][a]=e[t])}),delete n[n.length-1][t]},b=e=>{const t=_t(c);t.simplescalingAdjustment=e,d(t)},E=e=>{const t=_t(c);t.step.stepAdjustments=e,y(t.step),d(t)},w=(e,t)=>{m(e);const a="instances"!==t?"PercentChangeInCapacity":"Set to"===e?"ExactCapacity":"ChangeInCapacity";d({...c,adjustmentType:a})},C=()=>{const e=_t(c),t=c.step?c.step.estimatedInstanceWarmup:c.simple.cooldown;if(c.step)delete e.step,e.simple=Co.buildSimplePolicy({cooldown:t});else{const a=[{scalingAdjustment:c.simple.scalingAdjustment}];"min"===v?a[0].metricIntervalUpperBound=0:a[0].metricIntervalLowerBound=0;const n={estimatedInstanceWarmup:t,stepAdjustments:a};delete e.simple,e.step=Co.buildStepPolicy(n,e.alarm.threshold,t),y(e.step)}d(e)};return Ot.createElement(At,{...o,title:`${f} scaling policy`,application:e,description:`${f} scaling policy for ${r.name}`,initialValues:c,mapValuesToTask:()=>{const t=Co.prepareCommandForUpsert(c,"Remove"===p);return{application:e,job:[{type:t.type||"upsertScalingPolicy",...t}]}},render:()=>{var e,t,a,i,s;return Ot.createElement("div",null,Ot.createElement("h4",{className:"section-heading"},"Conditions"),Ot.createElement("div",{className:"section-body"},Ot.createElement(Ao,{alarm:c.alarm,multipleAlarms:Boolean((null==(e=null==n?void 0:n.alarms)?void 0:e.length)>1),serverGroup:r,stepAdjustments:c.step.stepAdjustments,stepsChanged:E,updateAlarm:e=>d({...c,alarm:e})})),Ot.createElement("h4",{className:"section-heading"},"Actions"),Ot.createElement("div",{className:"section-body"},!(null==(t=c.alarm)?void 0:t.metricName)&&Ot.createElement("h4",{className:"text-center"},"Select a metric"),(null==(a=c.alarm)?void 0:a.metricName)&&!h&&Ot.createElement("div",null,Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-10 col-md-offset-1"},Ot.createElement("p",null,"This is a simple scaling policy. To declare different actions based on the magnitude of the alarm,",Ot.createElement("b",null,"switch to a",Ot.createElement("a",{className:"clickable sp-margin-xs-l",onClick:C},"step policy"),".")))),Ot.createElement(xo,{adjustmentType:g,adjustmentTypeChanged:w,operator:p,scalingAdjustment:null==(i=c.simple)?void 0:i.scalingAdjustment,updateScalingAdjustment:b})),(null==(s=c.alarm)?void 0:s.metricName)&&h&&Ot.createElement(Po,{adjustmentType:g,adjustmentTypeChanged:w,alarm:c.alarm,isMin:"min"===v,operator:p,step:c.step,stepsChanged:E})),Ot.createElement(No,{command:c,isInstanceType:"instances"===g,isNew:Boolean(!n.policyARN),operator:p,updateCommand:d}))}})};class Bo extends Vt.Component{constructor(e){super(e),this.handleClick=()=>{this.setState({showSelection:!0})},this.typeSelected=e=>{this.setState({typeSelection:e,showSelection:!1,showModal:!0}),"step"===e&&this.createStepPolicy(),"targetTracking"===e&&this.createTargetTrackingPolicy()},this.showModalCallback=()=>{this.setState({showSelection:!1,showModal:!1,typeSelection:null})},this.state={showSelection:!1,showModal:!1,typeSelection:null}}createStepPolicy(){const{serverGroup:e,application:t}=this.props,a={app:t,policy:Xn.awsServerGroupTransformer.constructNewStepScalingPolicyTemplate(e),serverGroup:e};b.show(Do,a,{dialogClassName:"wizard-modal modal-lg"})}createTargetTrackingPolicy(){const{serverGroup:e,application:t}=this.props,a={app:t,policy:Xn.awsServerGroupTransformer.constructNewTargetTrackingPolicyTemplate(),serverGroup:e};b.show(So,a,{dialogClassName:"wizard-modal modal-lg"})}render(){const{min:e,max:t}=this.props.serverGroup.capacity;return Vt.createElement("div",null,Vt.createElement("a",{className:"clickable",onClick:this.handleClick},"Create new scaling policy"),this.state.showSelection&&Vt.createElement(ko,{warnOnMinMaxCapacity:e===t,typeSelectedCallback:this.typeSelected,showCallback:this.showModalCallback}))}}class zo{static upsertScalingPolicy(e,t){return t.type=t.type||"upsertScalingPolicy",O.executeTask({application:e,description:"Upsert scaling policy "+(t.name||t.serverGroupName),job:[t]})}static deleteScalingPolicy(e,t,a){return O.executeTask({application:e,description:"Delete scaling policy "+a.policyName,job:[{type:"deleteScalingPolicy",cloudProvider:"aws",credentials:t.account,region:t.region,policyName:a.policyName,serverGroupName:t.name}]})}}const Fo={GreaterThanOrEqualToThreshold:">=",GreaterThanThreshold:">",LessThanOrEqualToThreshold:"<=",LessThanThreshold:"<"},Mo=({alarm:e})=>Ot.createElement("div",null,Ot.createElement("div",null,Ot.createElement("b",null,"Whenever"),` ${e.statistic} of ${e.metricName}`),Ot.createElement("div",null,Ot.createElement("b",null,"for at least"),` ${e.evaluationPeriods} consecutive periods of ${e.period} seconds`)),$o=({policy:e,serverGroup:t})=>{var a;const{adjustmentType:n,alarms:r,cooldown:i,estimatedInstanceWarmup:s,minAdjustmentMagnitude:l,stepAdjustments:o}=e,c=!!i||"decrease"===(null==(a=null==o?void 0:o[0])?void 0:a.operator),d=r[0]||{},u=null==d?void 0:d.comparisonOperator.includes("Greater"),p=e=>"ExactCapacity"===n?`set capacity to ${e.scalingAdjustment} instance${e.scalingAdjustment>1?"s":""}`:`${e.operator} capacity by ${e.absAdjustment}${"PercentChangeInCapacity"===n?"%":" instance"}${"ChangeInCapacity"===n&&e.absAdjustment>1?"s":""}`;return Ot.createElement("div",null,Ot.createElement(W,{className:"dl-horizontal dl-narrow"},Ot.createElement(B,{label:"Whenever",value:`${d.statistic} of ${d.metricName} is ${Fo[d.comparisonOperator]} ${d.threshold}`}),Ot.createElement(B,{label:"for at least",value:`${d.evaluationPeriods} consecutive periods of ${d.period} seconds`}),Boolean(null==o?void 0:o.length)&&Ot.createElement(B,{label:"then",value:o.map((e,t)=>Ot.createElement("div",{key:`step-adjustment-boundary-${t}`},o.length>1&&Ot.createElement("span",null,(e=>{const t=void 0!==e.metricIntervalLowerBound&&void 0!==e.metricIntervalUpperBound?`is between ${d.threshold+e.metricIntervalLowerBound} and ${d.threshold+e.metricIntervalUpperBound} `:"",a=u?e.metricIntervalLowerBound:e.metricIntervalUpperBound,n=`is ${u?"greater":"less"} than ${d.threshold+a}`;return`if ${d.metricName} ${t}${n}`})(e)),Ot.createElement("span",null,p(e))))}),!Boolean(null==o?void 0:o.length)&&Ot.createElement(B,{label:"then",value:p(e)}),Boolean(l)&&Ot.createElement(B,{label:"in",value:`increments of at least ${l} instance${l>1?"s":""}`}),Boolean(c)&&Ot.createElement(B,{label:"wait",value:`${i} seconds before allowing another scaling activity.`}),Boolean(s)&&Ot.createElement(B,{label:"wait",value:`${s} seconds to warm up after each step.`})),Ot.createElement(mo,{alarm:d,serverGroup:t}))};Ar(".StepPolicySummary .HoverablePopover {\n text-decoration: none;\n}\n.StepPolicySummary .actions {\n margin: 0 0 15px 0;\n border-bottom: 1px solid var(--color-alto);\n}\n");const Lo=({application:e,policy:t,serverGroup:a})=>{var n,r;const i=a.type||a.cloudProvider||"aws",s=V.getValue(i,"serverGroup"),l="aws"===i?t.policyName:t.id,o=s.UpsertStepPolicyModal,c=()=>{const n={app:e,policy:t,serverGroup:a};b.show(o,n,{dialogClassName:"wizard-modal modal-lg"})},d=()=>{const n={application:e,title:`Deleting scaling policy ${l}`},r={type:"deleteScalingPolicy",cloudProvider:i,credentials:a.account,region:a.region,scalingPolicyID:t.id,serverGroupName:a.name};"aws"===i&&(delete r.scalingPolicyID,r.policyName=t.policyName),S.confirm({header:`Really delete ${l}?`,buttonText:"Delete scaling policy",account:a.account,taskMonitorConfig:n,submitMethod:()=>O.executeTask({application:e,description:`Delete scaling policy ${l}`,job:[r]})})};return Ot.createElement("div",{className:"StepPolicySummary"},Ot.createElement("div",null,!Boolean(null==(n=t.alarms)?void 0:n.length)&&Ot.createElement("div",null,"No alarms configured for this policy - it's safe to delete."),Boolean(null==(r=t.alarms)?void 0:r.length)&&t.alarms.map(e=>Ot.createElement("div",{key:`step-summary-${t.policyName}`},Ot.createElement(ne,{Component:()=>Ot.createElement($o,{policy:t,serverGroup:a}),placement:"left",title:t.policyName},Ot.createElement("div",null,Ot.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Ot.createElement(Mo,{alarm:e}))),Ot.createElement("div",{className:"actions"},Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:c},Ot.createElement("span",{className:"glyphicon glyphicon-cog"}),Ot.createElement("span",{className:"sr-only"},"Edit policy")),Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:d},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}),Ot.createElement("span",{className:"sr-only"},"Delete policy")))))))};Ar(".TargetTrackingSummary .HoverablePopover {\n min-height: 600px;\n text-decoration: none;\n}\n.TargetTrackingSummary .actions {\n margin: 0 0 15px 0;\n border-bottom: 1px solid var(--color-alto);\n}\n");const Ro=({application:e,policy:t,serverGroup:a})=>{var n,r,i;const s=a.type||a.cloudProvider||"aws",l=V.getValue(s,"serverGroup"),o="aws"===s?t.policyName:t.id,c=l.UpsertTargetTrackingModal,d=l.TargetTrackingChart,u=t.targetTrackingConfiguration;return Ot.createElement("div",{className:"TargetTrackingSummary"},Ot.createElement(ne,{Component:()=>Ot.createElement(d,{config:t.targetTrackingConfiguration,serverGroup:a}),placement:"left",title:o},Ot.createElement("div",null,Ot.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Ot.createElement("div",null,Ot.createElement("b",null,"Target"),Ot.createElement("span",{className:"sp-margin-xs-left"},(null==(n=u.predefinedMetricSpecification)?void 0:n.predefinedMetricType)||(null==(r=u.customizedMetricSpecification)?void 0:r.metricName)),Boolean(null==(i=u.customizedMetricSpecification)?void 0:i.statistic)&&Ot.createElement("span",null,` @ ${u.targetValue}`)))),Ot.createElement("div",{className:"actions"},Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:()=>{const n={app:e,policy:t,serverGroup:a};b.show(c,n,{dialogClassName:"wizard-modal modal-lg"})}},Ot.createElement("span",{className:"glyphicon glyphicon-cog"}),Ot.createElement("span",{className:"sr-only"},"Edit policy")),Ot.createElement("button",{className:"btn btn-xs btn-link",onClick:()=>{const n={application:e,title:`Deleting scaling policy ${o}`},r={type:"deleteScalingPolicy",cloudProvider:s,credentials:a.account,region:a.region,scalingPolicyID:t.id,serverGroupName:a.name};"aws"===s&&(delete r.scalingPolicyID,r.policyName=t.policyName),S.confirm({header:`Really delete ${o}?`,buttonText:"Delete scaling policy",account:a.account,taskMonitorConfig:n,submitMethod:()=>O.executeTask({application:e,description:`Delete scaling policy ${o}`,job:[r]})})}},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}),Ot.createElement("span",{className:"sr-only"},"Delete policy"))))},Oo=({application:e,policy:t,serverGroup:a})=>"TargetTrackingScaling"===(t.policyType?t.policyType:t.targetTrackingConfiguration?"TargetTrackingScaling":"StepScaling")?Ot.createElement(Ro,{application:e,policy:t,serverGroup:a}):Ot.createElement(Lo,{application:e,policy:t,serverGroup:a});class Vo extends Vt.Component{constructor(){super(...arguments),this.editAdvancedSettings=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then(a=>a&&Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/advancedSettings/editAsgAdvancedSettings.modal.html",controller:"EditAsgAdvancedSettingsCtrl as ctrl",resolve:{application:()=>e,serverGroup:()=>t}}))}}render(){const{serverGroup:e}=this.props,t=e.asg;return Vt.createElement(x,{heading:"Advanced Settings"},Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},Vt.createElement("dt",null,"Cooldown"),Vt.createElement("dd",null,t.defaultCooldown," seconds"),t.enabledMetrics.length>0&&[Vt.createElement("dt",{key:"t-metrics"},"Enabled Metrics"),Vt.createElement("dd",{key:"d-metrics"},t.enabledMetrics.map(e=>e.metric).join(", "))],Vt.createElement("dt",null,"Health Check Type"),Vt.createElement("dd",null,t.healthCheckType),Vt.createElement("dt",null,"Grace Period"),Vt.createElement("dd",null,t.healthCheckGracePeriod," seconds"),Vt.createElement("dt",null,"Termination Policies"),Vt.createElement("dd",null,t.terminationPolicies.join(", ")),t.capacityRebalance&&[Vt.createElement("dt",null,"Capacity Rebalance ",Vt.createElement(n,{id:"aws.serverGroup.capacityRebalance"})),Vt.createElement("dd",null,`${t.capacityRebalance}`)]),kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:this.editAdvancedSettings},"Edit Advanced Settings"))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/advancedSettings/editAsgAdvancedSettings.modal.html",'<div modal-page>\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form" name="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Edit Advanced Settings for {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Cooldown</b></div>\n <div class="col-md-2">\n <input type="number" required class="form-control input-sm" ng-model="command.cooldown" />\n </div>\n seconds\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right">\n <b>Enabled Metrics</b>\n <help-field key="aws.serverGroup.enabledMetrics"></help-field>\n </div>\n <div class="col-md-6">\n <ui-select multiple ng-model="command.enabledMetrics" class="form-control input-sm">\n <ui-select-match>{{$item}}</ui-select-match>\n <ui-select-choices\n repeat="enabledMetric in command.backingData.enabledMetrics | filter: $select.search | orderBy: \'toString()\'"\n >\n <span ng-bind-html="enabledMetric | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Health Check Type</b></div>\n <div class="col-md-6">\n <ui-select ng-model="command.healthCheckType" class="form-control input-sm">\n <ui-select-match placeholder="Select...">{{$select.selected}}</ui-select-match>\n <ui-select-choices\n repeat="healthCheckType in command.backingData.healthCheckTypes | filter: $select.search"\n >\n <span ng-bind-html="healthCheckType | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Health Check Grace Period</b></div>\n <div class="col-md-2">\n <input type="text" required class="form-control input-sm" ng-model="command.healthCheckGracePeriod" />\n </div>\n seconds\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right"><b>Termination Policies</b></div>\n <div class="col-md-6">\n <ui-select multiple ng-model="command.terminationPolicies" class="form-control input-sm">\n <ui-select-match>{{$item}}</ui-select-match>\n <ui-select-choices\n repeat="terminationPolicy in command.backingData.terminationPolicies | filter: $select.search | orderBy: \'toString()\'"\n >\n <span ng-bind-html="terminationPolicy | highlight: $select.search"></span>\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n <div class="form-group">\n <div class="col-md-5 sm-label-right">\n <b>Capacity Rebalance</b><help-field key="aws.serverGroup.capacityRebalance" />\n </div>\n <div class="col-md-6">\n <input type="checkbox" ng-model="command.capacityRebalance" /> Enable capacity rebalance\n </div>\n </div>\n </div>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <button type="submit" class="btn btn-primary" ng-disabled="form.$invalid" ng-click="ctrl.submit()">Submit</button>\n </div>\n </form>\n</div>\n')}]);class Uo extends Vt.Component{constructor(e){super(e),this.state={changeConfig:this.getChangeConfig(e.serverGroup)}}getChangeConfig(e){const t={metadata:ia(e.entityTags,"creationMetadata")};return wa(e,"buildInfo.jenkins")&&(t.buildInfo={ancestor:void 0,jenkins:e.buildInfo.jenkins,target:void 0}),t}componentWillReceiveProps(e){this.setState({changeConfig:this.getChangeConfig(e.serverGroup)})}render(){const{serverGroup:e}=this.props,{changeConfig:t}=this.state,n=a.feature&&a.feature.entityTags,r=e.entityTags||{};return Vt.createElement(x,{heading:"Server Group Information",defaultExpanded:!0},Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Created"),Vt.createElement("dd",null,z(e.createdTime)),n&&Vt.createElement(xt,{metadata:r.creationMetadata}),n&&Vt.createElement(Pt,{changeConfig:t,linkText:"view changes",nameItem:e,viewType:"description"}),Vt.createElement("dt",null,"In"),Vt.createElement("dd",null,Vt.createElement(G,{account:e.account}),e.region),Vt.createElement("dt",null,"VPC"),Vt.createElement("dd",null,Vt.createElement(vr,{vpcId:e.vpcId})),e.vpcId&&e.subnetType&&Vt.createElement("dt",null,"Subnet"),e.vpcId&&e.subnetType&&Vt.createElement("dd",null,e.subnetType),e.asg&&Vt.createElement("dt",null,"Zones"),e.asg&&Vt.createElement("dd",null,Vt.createElement("ul",null,e.asg.availabilityZones.map(e=>Vt.createElement("li",{key:e},e))))))}}var qo=Object.getOwnPropertyDescriptor;let Ho=class extends Vt.Component{render(){const{serverGroup:e,app:t}=this.props,a={min:e.asg.minSize,max:e.asg.maxSize,desired:e.asg.desiredCapacity};return Vt.createElement(x,{heading:"Capacity",defaultExpanded:!0},Vt.createElement(Dt,{current:e.instances.length,capacity:a}),Vt.createElement("div",null,kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:()=>io.show({application:t,serverGroup:e})},"Resize Server Group")),Vt.createElement("div",null,Vt.createElement(Bt,{serverGroup:e})))}};Ho=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?qo(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("amazon.serverGroup.CapacityDetailsSection")],Ho);class Wo extends Vt.Component{render(){const{serverGroup:e}=this.props;return e.instanceCounts.total>0?Vt.createElement(x,{heading:"Health",defaultExpanded:!0},Vt.createElement("dl",{className:"dl-horizontal dl-narrow"},Vt.createElement("dt",null,"Instances"),Vt.createElement("dd",null,Vt.createElement(X,{container:e.instanceCounts,className:"pull-left"})))):null}}const jo=({serverGroup:e})=>{if(!e.mixedInstancesPolicy)return null;const t=e.mixedInstancesPolicy.instancesDistribution;return Vt.createElement(x,{heading:"Instances Distribution"},Vt.createElement(W,{className:"horizontal-when-filters-collapsed"},Vt.createElement(B,{label:"On-Demand Allocation Strategy",helpFieldId:"aws.serverGroup.odAllocationStrategy",value:t.onDemandAllocationStrategy}),Vt.createElement(B,{label:"On-Demand Base Capacity",helpFieldId:"aws.serverGroup.odBase",value:t.onDemandBaseCapacity}),Vt.createElement(B,{label:"On-Demand Percentage Above Base Capacity",helpFieldId:"aws.serverGroup.odPercentAboveBase",value:t.onDemandPercentageAboveBaseCapacity}),Vt.createElement(B,{label:"Spot Allocation Strategy",helpFieldId:"aws.serverGroup.spotAllocationStrategy",value:t.spotAllocationStrategy}),t.spotInstancePools&&Vt.createElement(B,{label:"Spot Instance Pools",helpFieldId:"aws.serverGroup.spotInstancePoolCount",value:t.spotInstancePools}),Vt.createElement(B,{label:"Max Spot Price",helpFieldId:"aws.serverGroup.spotMaxPrice",value:t.spotMaxPrice||"on-demand price, default"})))},Zo=e=>{let t;return(e||"").split(", ").forEach(e=>{const a=e.split("=");2===a.length&&"ancestor_name"===a[0]&&(t=a[1])}),t};class _o extends Vt.Component{constructor(e){super(e),this.state={image:this.getImage(e.serverGroup)}}getImage(e){const t=e.image?e.image:void 0;return e.image&&e.image.description&&(t.baseImage=Zo(e.image.description)),t}componentWillReceiveProps(e){this.setState({image:this.getImage(e.serverGroup)})}render(){const{name:e,launchConfig:t}=this.props.serverGroup,{image:a}=this.state;return t?Vt.createElement(x,{heading:"Launch Configuration"},Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},Vt.createElement("dt",null,"Name"),Vt.createElement("dd",null,t.launchConfigurationName),Vt.createElement("dt",null,"Image ID"),Vt.createElement("dd",null,t.imageId),a&&a.imageLocation&&Vt.createElement("dt",null,"Image Name"),a&&a.imageLocation&&Vt.createElement("dd",null,a.imageLocation),a&&a.baseImage&&Vt.createElement("dt",null,"Base Image Name"),a&&a.baseImage&&Vt.createElement("dd",null,a.baseImage),Vt.createElement("dt",null,"Instance Type"),Vt.createElement("dd",null,t.instanceType),Vt.createElement("dt",null,"IAM Profile"),Vt.createElement("dd",null,t.iamInstanceProfile),t.instanceMonitoring&&Vt.createElement(Vt.Fragment,null,Vt.createElement("dt",null,"Instance Monitoring"),Vt.createElement("dd",null,t.instanceMonitoring.enabled?"enabled":"disabled")),t.spotPrice&&Vt.createElement("dt",null,"Spot Price"),t.spotPrice&&Vt.createElement("dd",null,t.spotPrice),t.keyName&&Vt.createElement("dt",null,"Key Name"),t.keyName&&Vt.createElement("dd",null,t.keyName),t.kernelId&&Vt.createElement("dt",null,"Kernel ID"),t.kernelId&&Vt.createElement("dd",null,t.kernelId),t.ramdiskId&&Vt.createElement("dt",null,"Ramdisk ID"),t.ramdiskId&&Vt.createElement("dd",null,t.ramdiskId),Vt.createElement("dt",null,"User Data"),t.userData&&Vt.createElement("dd",null,Vt.createElement(zt,{serverGroupName:e,userData:t.userData})),!t.userData&&Vt.createElement("dd",null,"[none]"))):null}}function Ko(e){return e.instanceTypeOverrides?Vt.createElement(x,{heading:"Instance Types",defaultExpanded:!0,outerDivClassName:"multiple-instance-types-subsection",toggleClassName:"clickable subsection-heading",headingClassName:"collapsible-subheading"},Vt.createElement("table",{className:"table table-condensed packed",id:"MultipleInstanceTypes"},Vt.createElement("thead",null,Vt.createElement("tr",null,Vt.createElement("th",{id:"instanceType"},"Type ",Vt.createElement(n,{id:"aws.serverGroup.multipleInstanceTypes"})),Vt.createElement("th",{id:"weight"},"Weighted Capacity ",Vt.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})))),Vt.createElement("tbody",null,e.instanceTypeOverrides.map(e=>[Vt.createElement("tr",{key:e.instanceType},Vt.createElement("td",{headers:"instanceType"},e.instanceType),Vt.createElement("td",{headers:"weight"},e.weightedCapacity))])))):null}Ar('.multiple-instance-types-subsection {\n padding: 0;\n}\n.multiple-instance-types-subsection a.subsection-heading {\n color: var(--color-black);\n}\n.multiple-instance-types-subsection h4.collapsible-subheading {\n padding: 10px 0px;\n background-color: var(--color-alabaster);\n margin: 0;\n font-size: 103%;\n font-weight: 600;\n text-transform: none;\n}\n.multiple-instance-types-subsection h4.collapsible-subheading .glyphicon {\n font-size: 10px;\n opacity: 0.5;\n margin-right: 4px;\n}\n.multiple-instance-types-subsection .content-body {\n animation: 0.15 ease-in 0 fadeIn;\n animation-iteration-count: 1;\n padding-left: 17px;\n margin: 10px 0 20px 0;\n}\n.multiple-instance-types-subsection .content-body:before,\n.multiple-instance-types-subsection .content-body:after {\n display: table;\n content: " ";\n}\n.multiple-instance-types-subsection .content-body:after {\n clear: both;\n}\n.multiple-instance-types-subsection .content-body ul {\n list-style-type: none;\n padding-left: 0;\n}\n.multiple-instance-types-subsection:last-child {\n border-bottom-width: 0;\n}\n.multiple-instance-types-subsection:first-child {\n padding-top: 0;\n}\n');const Yo=({serverGroup:e})=>{var t,a,n;const{image:r}=e,i=Zo(null==r?void 0:r.description);if(!e.launchTemplate&&!e.mixedInstancesPolicy)return null;const s=!!e.mixedInstancesPolicy,l=s?e.mixedInstancesPolicy.launchTemplates[0]:e.launchTemplate,{launchTemplateData:o}=l,c=s?e.mixedInstancesPolicy.instancesDistribution.spotMaxPrice:null==(a=null==(t=null==o?void 0:o.instanceMarketOptions)?void 0:t.spotOptions)?void 0:a.maxPrice,d=null==(n=null==o?void 0:o.creditSpecification)?void 0:n.cpuCredits,u=s?e.mixedInstancesPolicy.launchTemplateOverridesForInstanceType:null;return Vt.createElement(x,{heading:"Launch Template"},Vt.createElement(W,{className:"horizontal-when-filters-collapsed"},Vt.createElement(B,{label:"Name",value:l.launchTemplateName}),Vt.createElement(B,{label:"Image ID",value:o.imageId}),(null==r?void 0:r.imageLocation)&&Vt.createElement(B,{label:"Image Name",value:null==r?void 0:r.imageLocation}),i&&Vt.createElement(B,{label:"Base Image Name",value:i}),u&&u.length>0?Vt.createElement(Ko,{instanceTypeOverrides:u}):Vt.createElement(B,{label:"Instance Type",value:o.instanceType}),d&&Vt.createElement(B,{label:"CPU Credit Specification",value:d}),Vt.createElement(B,{label:"IAM Profile",value:o.iamInstanceProfile.name}),o.monitoring&&Vt.createElement(B,{label:"Instance Monitoring",value:o.monitoring.enabled?"enabled":"disabled"}),c&&Vt.createElement(B,{label:"Max Spot Price",value:c}),o.keyName&&Vt.createElement(B,{label:"Key Name",value:o.keyName}),o.kernelId&&Vt.createElement(B,{label:"Kernel ID",value:o.kernelId}),o.ramDiskId&&Vt.createElement(B,{label:"Ramdisk ID",value:o.ramDiskId}),o.userData&&Vt.createElement(B,{label:"User Data",value:Vt.createElement(zt,{serverGroupName:e.name,userData:o.userData})})))};class Xo extends Vt.Component{render(){return Vt.createElement(x,{heading:"Logs"},Vt.createElement("ul",null,Vt.createElement("li",null,Vt.createElement(Bt,{serverGroup:this.props.serverGroup}))))}}class Jo extends Vt.Component{constructor(e){super(e),this.state=this.getState(e)}getState(e){const{serverGroup:t}=e,a=t.buildInfo||{};let n=null;a.commit&&(n=t.buildInfo.commit.substring(0,8));let r=null;if(a.buildInfoUrl)r=t.buildInfo.buildInfoUrl;else if(a.jenkins){const e=t.buildInfo.jenkins;r=`${e.host}job/${e.name}/${e.number}`}return{commitHash:n,jenkinsLink:r}}componentWillReceiveProps(e){this.setState(this.getState(e))}render(){const{serverGroup:e}=this.props,{commitHash:t,jenkinsLink:a}=this.state;return e.buildInfo&&e.buildInfo.jenkins?Vt.createElement(x,{heading:"Package"},Vt.createElement("dl",{className:"horizontal-when-filters-collapsed"},Vt.createElement("dt",null,"Job"),Vt.createElement("dd",null,e.buildInfo.jenkins.name),Vt.createElement("dt",null,"Package"),Vt.createElement("dd",null,e.buildInfo.package_name),Vt.createElement("dt",null,"Build"),Vt.createElement("dd",null,e.buildInfo.jenkins.number),Vt.createElement("dt",null,"Commit"),Vt.createElement("dd",null,t),Vt.createElement("dt",null,"Version"),Vt.createElement("dd",null,e.buildInfo.version),Vt.createElement("dt",null,"Build Link"),Vt.createElement("dd",null,Vt.createElement("a",{target:"_blank",href:a},a)))):null}}var Qo=Object.getOwnPropertyDescriptor;let ec=class extends Vt.Component{constructor(e){super(e)}static arePoliciesDisabled(e){const t=co.normalizeScalingProcesses(e);return e.scalingPolicies.length>0&&t.filter(e=>!e.enabled).some(e=>["Launch","Terminate","AlarmNotification"].includes(e.name))}render(){const{app:e,serverGroup:t}=this.props,a=ec.arePoliciesDisabled(t);return Vt.createElement(x,{cacheKey:"Scaling Policies",heading:({chevron:e})=>Vt.createElement("h4",{className:"collapsible-heading"},e,Vt.createElement("span",null,a&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Policies"))},a&&Vt.createElement("div",{className:"band band-warning"},"Some scaling processes are disabled that may prevent scaling policies from working."),t.scalingPolicies.map(a=>Vt.createElement(Oo,{key:a.policyARN,policy:a,serverGroup:t,application:e})),kn.adHocInfraWritesEnabled?Vt.createElement(Bo,{serverGroup:t,application:e}):Vt.createElement("p",null,"Can not create scaling policy, because ad-hoc operations are disabled for AWS providers."))}};ec=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Qo(t,a):t,s=e.length-1;s>=0;s--)(r=e[s])&&(i=r(i)||i);return i})([ie("aws.serverGroup.ScalingPoliciesDetailsSection")],ec);class tc extends Vt.Component{constructor(e){super(e),this.toggleScalingProcesses=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then(a=>a&&Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/scalingProcesses/modifyScalingProcesses.html",controller:"ModifyScalingProcessesCtrl as ctrl",resolve:{serverGroup:()=>t,application:()=>e,processes:()=>this.state.autoScalingProcesses}}))},this.state=this.getState(e)}getState(e){const{serverGroup:t}=e,a=co.normalizeScalingProcesses(t),n=t.scalingPolicies.length>0&&a.filter(e=>!e.enabled).some(e=>["Launch","Terminate","AlarmNotification"].includes(e.name)),r=t.scheduledActions.length>0&&a.filter(e=>!e.enabled).some(e=>["Launch","Terminate","ScheduledAction"].includes(e.name));return{autoScalingProcesses:a,scalingPoliciesDisabled:n,scheduledActionsDisabled:r}}componentWillReceiveProps(e){this.setState(this.getState(e))}render(){const{autoScalingProcesses:e,scalingPoliciesDisabled:t,scheduledActionsDisabled:a}=this.state;return Vt.createElement(x,{cacheKey:"Scaling Processes",heading:({chevron:e})=>Vt.createElement("h4",{className:"collapsible-heading"},e,Vt.createElement("span",null,t&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),a&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Processes"))},Vt.createElement("ul",{className:"scaling-processes"},e.map(e=>Vt.createElement("li",{key:e.name},Vt.createElement("span",{style:{visibility:e.enabled?"visible":"hidden"},className:"fa fa-check small"}),Vt.createElement("span",{className:e.enabled?"":"text-disabled"},e.name," "),Vt.createElement(n,{content:e.description,placement:"bottom"}),e.suspensionDate&&Vt.createElement("div",{className:"text-disabled small",style:{marginLeft:"35px"}},"Suspended ",z(e.suspensionDate))))),kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:this.toggleScalingProcesses},"Edit Scaling Processes"))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/scalingProcesses/modifyScalingProcesses.html",'<div modal-page class="confirmation-modal">\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Modify Scaling Processes for {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-sm-offset-2 col-sm-10">\n <div class="checkbox" ng-repeat="process in command">\n <label>\n <input type="checkbox" ng-model="process.enabled" />\n {{process.name}}\n </label>\n <help-field content="{{process.description}}" placement="right"></help-field>\n </div>\n </div>\n </div>\n </div>\n <task-reason command="command"></task-reason>\n <aws-footer\n action="ctrl.submit()"\n cancel="ctrl.cancel()"\n is-valid="ctrl.isValid()"\n account="serverGroup.account"\n verification="verification"\n ></aws-footer>\n </form>\n</div>\n')}]);class ac extends Vt.Component{render(){const{action:e}=this.props;return Vt.createElement("dl",{className:"horizontal-when-filters-collapsed",style:{marginBottom:"20px"}},Vt.createElement("dt",null,"Schedule"),Vt.createElement("dd",null,e.recurrence),void 0!==e.minSize&&Vt.createElement("dt",null,"Min Size"),void 0!==e.minSize&&Vt.createElement("dd",null,e.minSize),void 0!==e.maxSize&&Vt.createElement("dt",null,"Max Size"),void 0!==e.maxSize&&Vt.createElement("dd",null,e.maxSize),void 0!==e.desiredCapacity&&Vt.createElement("dt",null,"Desired Size"),void 0!==e.desiredCapacity&&Vt.createElement("dd",null,e.desiredCapacity))}}class nc extends Vt.Component{constructor(e){super(e),this.editScheduledActions=()=>{Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/scheduledAction/editScheduledActions.modal.html",controller:"EditScheduledActionsCtrl as ctrl",resolve:{application:()=>this.props.app,serverGroup:()=>this.props.serverGroup}})},this.state=this.getState(e)}getState(e){const{serverGroup:t}=e,a=co.normalizeScalingProcesses(t);return{scheduledActionsDisabled:t.scheduledActions.length>0&&a.filter(e=>!e.enabled).some(e=>["Launch","Terminate","ScheduledAction"].includes(e.name))}}componentWillReceiveProps(e){this.setState(this.getState(e))}render(){const{serverGroup:e}=this.props,{scheduledActionsDisabled:t}=this.state;return Vt.createElement(x,{cacheKey:"Scheduled Actions",heading:({chevron:e})=>Vt.createElement("h4",{className:"collapsible-heading"},e,Vt.createElement("span",null,t&&Vt.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Vt.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scheduled Actions"))},e.scheduledActions.map((e,t)=>Vt.createElement(ac,{key:t,action:e})),e.scheduledActions.length>0&&Vt.createElement("p",null,Vt.createElement("strong",null,"Note:")," Schedules are evaluated in UTC."),0===e.scheduledActions.length&&Vt.createElement("p",null,"No Scheduled Actions are configured for this server group."),kn.adHocInfraWritesEnabled&&Vt.createElement("a",{className:"clickable",onClick:this.editScheduledActions},"Edit Scheduled Actions"))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/scheduledAction/editScheduledActions.modal.html",'<div modal-page>\n <task-monitor monitor="taskMonitor"></task-monitor>\n <form role="form" name="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">Edit Scheduled Actions for {{serverGroup.name}}</h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-md-12">\n <p>You must specify at least one of: Min Size, Max Size, Desired Capacity</p>\n <p><strong>Note:</strong> CRON expressions are evaluated in UTC.</p>\n <table class="table table-condensed packed">\n <thead>\n <tr>\n <th>Recurrence (CRON)</th>\n <th>Min Size</th>\n <th>Max Size</th>\n <th>Desired Capacity</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr ng-repeat="action in command.scheduledActions">\n <td>\n <input\n class="form-control input-sm no-spel"\n type="text"\n ng-model="action.recurrence"\n name="recurrence-{{$index}}"\n required\n />\n \x3c!-- TODO: Add cron-validator when endpoint is fixed --\x3e\n <div class="form-group row slide-in" ng-if="form[\'recurrence-\' + $index].$error.cronExpression">\n <div class="error-message">{{cronErrors[\'action.recurrence.cronExpression\']}}</div>\n </div>\n </td>\n <td>\n <input\n class="form-control input-sm"\n type="number"\n min="0"\n max="{{action.maxSize || Infinity}}"\n ng-model="action.minSize"\n />\n </td>\n <td>\n <input\n class="form-control input-sm"\n type="number"\n min="{{action.minSize || 0}}"\n ng-model="action.maxSize"\n />\n </td>\n <td>\n <input\n class="form-control input-sm"\n type="number"\n ng-model="action.desiredCapacity"\n min="{{command.minSize || 0}}"\n max="{{command.maxSize || Infinity}}"\n />\n </td>\n <td>\n <a href class="sm-label" ng-click="ctrl.removeScheduledAction($index)"\n ><span class="glyphicon glyphicon-trash"></span\n ></a>\n </td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td colspan="5">\n <button class="add-new col-md-12" ng-click="ctrl.addScheduledAction()">\n <span class="glyphicon glyphicon-plus-sign"></span> Add new Scheduled Action\n </button>\n </td>\n </tr>\n </tfoot>\n </table>\n </div>\n </div>\n </div>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <button type="submit" class="btn btn-primary" ng-disabled="form.$invalid" ng-click="ctrl.submit()">Submit</button>\n </div>\n </form>\n</div>\n')}]);class rc extends Vt.Component{constructor(e){super(e),this.updateSecurityGroups=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then(a=>a&&Nt.modalService.open({templateUrl:"amazon/src/serverGroup/details/securityGroup/editSecurityGroups.modal.html",controller:"EditSecurityGroupsCtrl as $ctrl",resolve:{application:()=>e,serverGroup:()=>t,securityGroups:()=>this.state.securityGroups}}))},this.state={securityGroups:this.getSecurityGroups(e)}}tryFindingSecurityGroupInIndex(e,t,a,n){try{return ml.resolveIndexedSecurityGroup(e,{account:t,region:a},n)}catch(e){return}}getSecurityGroups(e){let t;const{app:a,serverGroup:n}=e;return n.securityGroups&&n.securityGroups.length&&(t=ta(n.securityGroups).map(e=>ba(a.securityGroups.data,{accountName:n.account,region:n.region,id:e})||ba(a.securityGroups.data,{accountName:n.account,region:n.region,name:e})||this.tryFindingSecurityGroupInIndex(a.securityGroupsIndex,n.account,n.region,e)||{id:e,name:e}).compact().value()),t}componentWillReceiveProps(e){this.setState({securityGroups:this.getSecurityGroups(e)})}render(){const{serverGroup:e}=this.props,{securityGroups:t}=this.state;return Vt.createElement(x,{heading:U.get("Firewalls")},Vt.createElement("ul",null,Qt(t,"name").map(t=>Vt.createElement("li",{key:t.name},Vt.createElement(Qa,{to:"^.firewallDetails",params:{name:t.name,accountId:t.accountName,region:e.region,vpcId:e.vpcId,provider:e.type}},Vt.createElement("a",null,t.name," (",t.id,")"))))),kn.adHocInfraWritesEnabled&&e.vpcId&&Vt.createElement("a",{className:"clickable",onClick:this.updateSecurityGroups},"Edit ",U.get("Firewalls")))}}window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/serverGroup/details/securityGroup/editSecurityGroups.modal.html",'<div modal-page>\n <task-monitor monitor="$ctrl.taskMonitor"></task-monitor>\n <form role="form" name="form">\n <modal-close dismiss="$dismiss()"></modal-close>\n <div class="modal-header">\n <h4 class="modal-title">\n Edit <firewall-label label="Firewalls"></firewall-label> for {{$ctrl.serverGroup.name}}\n </h4>\n </div>\n <div class="modal-body container-fluid form-horizontal">\n <div class="form-group">\n <div class="col-md-10 col-md-offset-1">\n <ui-select\n multiple\n ng-model="$ctrl.command.securityGroups"\n uis-open-close="$ctrl.resetCurrentItems()"\n class="form-control input-sm"\n >\n <ui-select-match>{{$item.name}} ({{$item.id}})</ui-select-match>\n <ui-select-choices\n repeat="securityGroup as securityGroup in $ctrl.availableSecurityGroups | filter: $select.search | limitTo: $ctrl.infiniteScroll.currentItems"\n infinite-scroll="$ctrl.addMoreItems()"\n infinite-scroll-distance="4"\n >\n <span ng-bind-html="securityGroup.name | highlight: $select.search"></span>\n (<span ng-bind-html="securityGroup.id | highlight: $select.search"></span>)\n </ui-select-choices>\n </ui-select>\n </div>\n </div>\n </div>\n <aws-footer\n action="$ctrl.submit()"\n cancel="$ctrl.cancel()"\n is-valid="$ctrl.isValid()"\n account="$ctrl.serverGroup.account"\n verification="$ctrl.state.verification"\n ></aws-footer>\n </form>\n</div>\n')}]);class ic extends Vt.Component{render(){const{serverGroup:e}=this.props;return Vt.createElement(x,{heading:"Tags"},0===e.asg.tags.length&&Vt.createElement("div",null,"No tags associated with this server group"),e.asg.tags.length>0&&Vt.createElement("dl",null,Qt(e.asg.tags,"key").map(e=>[Vt.createElement("dt",{key:e.key},e.key),Vt.createElement("dd",{key:e.value},e.value)])))}}class sc{static listKeyPairs(){return D("/keyPairs").useCache().get().then(e=>e.sort((e,t)=>e.keyName.localeCompare(t.keyName)))}}class lc{constructor(e,t,a,n,r){this.securityGroupReader=e,this.awsInstanceTypeService=t,this.cacheInitializer=a,this.loadBalancerReader=n,this.serverGroupCommandRegistry=r,this.enabledMetrics=["GroupMinSize","GroupMaxSize","GroupDesiredCapacity","GroupInServiceInstances","GroupPendingInstances","GroupStandbyInstances","GroupTerminatingInstances","GroupTotalInstances"],this.healthCheckTypes=["EC2","ELB"],this.terminationPolicies=["OldestInstance","NewestInstance","OldestLaunchConfiguration","ClosestToNextInstanceHour","Default"]}configureUpdateCommand(e){e.backingData={enabledMetrics:Ca(this.enabledMetrics),healthCheckTypes:Ca(this.healthCheckTypes),terminationPolicies:Ca(this.terminationPolicies)}}configureCommand(e,t){return this.applyOverrides("beforeConfiguration",t),t.toggleSuspendedProcess=(e,t)=>{e.suspendedProcesses=e.suspendedProcesses||[];const a=e.suspendedProcesses.indexOf(t);e.suspendedProcesses=-1===a?e.suspendedProcesses.concat(t):e.suspendedProcesses.filter(e=>e!==t)},t.processIsSuspended=(e,t)=>e.suspendedProcesses.includes(t),t.onStrategyChange=(e,t)=>{var a;(null==(a=kn.serverGroups)?void 0:a.enableLaunchTemplates)&&(e.setLaunchTemplate="rollingpush"===t.key||void 0),""!==t.key&&"custom"!==t.key&&(e.suspendedProcesses=(e.suspendedProcesses||[]).filter(e=>"AddToLoadBalancer"!==e))},t.getBlockDeviceMappingsSource=e=>e.copySourceCustomBlockDeviceMappings?"source":e.useAmiBlockDeviceMappings?"ami":"default",t.selectBlockDeviceMappingsSource=(e,t)=>{"source"===t?(e.copySourceCustomBlockDeviceMappings=!0,e.useAmiBlockDeviceMappings=!1):"ami"===t?(e.copySourceCustomBlockDeviceMappings=!1,e.useAmiBlockDeviceMappings=!0):(e.copySourceCustomBlockDeviceMappings=!1,e.useAmiBlockDeviceMappings=!1)},t.regionIsDeprecated=e=>wa(e,"backingData.filtered.regions")&&e.backingData.filtered.regions.some(t=>t.name===e.region&&t.deprecated),Xa.all([o.getCredentialsKeyedByAccount("aws"),this.securityGroupReader.getAllSecurityGroups(),g.listSubnets(),o.getPreferredZonesByAccount("aws"),sc.listKeyPairs(),this.awsInstanceTypeService.getAllTypesByRegion(),Xa.when(Ca(this.enabledMetrics)),Xa.when(Ca(this.healthCheckTypes)),Xa.when(Ca(this.terminationPolicies))]).then(([a,n,r,i,s,l,o,c,d])=>{var u,p;const m={credentialsKeyedByAccount:a,securityGroups:n,subnets:r,preferredZones:i,keyPairs:s,instanceTypesInfo:l,enabledMetrics:o,healthCheckTypes:c,terminationPolicies:d};let g=Xa.when();if(m.accounts=Sa(m.credentialsKeyedByAccount),m.filtered={},m.scalingProcesses=co.listProcesses(),m.appLoadBalancers=e.getDataSource("loadBalancers").data,m.managedResources=null==(p=null==(u=e.getDataSource("managedResources"))?void 0:u.data)?void 0:p.resources,t.backingData=m,this.configureVpcId(t),m.filtered.securityGroups=this.getRegionalSecurityGroups(t),t.viewState.disableImageSelection&&this.configureInstanceTypes(t),t.securityGroups&&t.securityGroups.length){const e=aa(this.getRegionalSecurityGroups(t),"id");va(t.securityGroups,e).length<t.securityGroups.length&&(g=this.refreshSecurityGroups(t,!0))}return g.then(()=>{this.applyOverrides("afterConfiguration",t),this.attachEventHandlers(t)})})}applyOverrides(e,t){this.serverGroupCommandRegistry.getCommandOverrides("aws").forEach(a=>{a[e]&&a[e](t)})}configureKeyPairs(e){const t={dirty:{}};if(e.credentials&&e.region){const a=oa(e.backingData.credentialsKeyedByAccount,t=>t.defaultKeyPair&&e.keyPair&&0===e.keyPair.indexOf(t.defaultKeyPair.replace("{{region}}",""))),n=ta(e.backingData.keyPairs).filter({account:e.credentials,region:e.region}).map("keyName").value();if(e.keyPair&&n.length&&!n.includes(e.keyPair)){const r=e.backingData.credentialsKeyedByAccount[e.credentials]||{defaultKeyPair:null};if(r.defaultKeyPair){const i=r.defaultKeyPair.replace("{{region}}",e.region);a&&n.includes(i)?e.keyPair=i:(e.keyPair=null,t.dirty.keyPair=!0)}else e.keyPair=null,t.dirty.keyPair=!0}e.backingData.filtered.keyPairs=n}else e.backingData.filtered.keyPairs=[];return t}configureInstanceTypes(e){const t={dirty:{}};if(e.region&&(e.virtualizationType||e.viewState.disableImageSelection)){let a=this.awsInstanceTypeService.getAvailableTypesForRegions(e.backingData.instanceTypesInfo,[e.region]);(e.virtualizationType||e.amiArchitecture)&&(a=this.awsInstanceTypeService.filterInstanceTypes(a,e.virtualizationType,!!e.vpcId,e.amiArchitecture));const n=aa(a,"name");e.instanceType&&!n.includes(e.instanceType)&&(t.dirty.instanceType=e.instanceType,e.instanceType=null);const r=aa(e.launchTemplateOverridesForInstanceType,"instanceType"),i=va(r,n),s=la(r,i);e.launchTemplateOverridesForInstanceType&&s.length>0&&(t.dirty.launchTemplateOverridesForInstanceType=e.launchTemplateOverridesForInstanceType.filter(e=>s.includes(e.instanceType)),e.launchTemplateOverridesForInstanceType=e.launchTemplateOverridesForInstanceType.filter(e=>i.includes(e.instanceType))),e.backingData.filtered.instanceTypes=n,e.backingData.filtered.instanceTypesInfo=a}else e.backingData.filtered.instanceTypes=[],e.backingData.filtered.instanceTypesInfo=[];return ha(e.viewState.dirty,t.dirty),t}configureImages(e){const t={dirty:{}};return e.amiName||(e.virtualizationType=null,e.amiArchitecture=null),e.viewState.disableImageSelection||e.amiName&&!e.region&&(t.dirty.amiName=!0,e.amiName=null),t}configureAvailabilityZones(e){e.backingData.filtered.availabilityZones=ba(e.backingData.credentialsKeyedByAccount[e.credentials].regions,{name:e.region}).availabilityZones}configureSubnetPurposes(e){const t={dirty:{}},a=e.backingData.filtered;return null===e.region||(a.subnetPurposes=ta(e.backingData.subnets).filter({account:e.credentials,region:e.region}).reject({target:"elb"}).reject({purpose:null}).uniqBy("purpose").value(),ta(a.subnetPurposes).some({purpose:e.subnetType}).value()||(e.subnetType=null,t.dirty.subnetType=!0)),t}getRegionalSecurityGroups(e){const t=e.backingData.securityGroups[e.credentials]||{aws:{}};return ta(t.aws[e.region]).filter({vpcId:e.vpcId||null}).sortBy("name").value()}configureSecurityGroupOptions(e){const t={dirty:{}},a=e.backingData.filtered.securityGroups,n=this.getRegionalSecurityGroups(e),r="string"==typeof e.securityGroups&&e.securityGroups.includes("${");if(a&&e.securityGroups&&!r){const r=e.securityGroups.map(e=>{const t=ba(a,{id:e});return t?t.name:e}),i=e.securityGroups.map(e=>{const t=ba(a,{id:e})||ba(a,{name:e});return t?t.name:null}).map(e=>ba(n,{name:e})).filter(e=>e),s=aa(i,"name"),l=ka(r,s);e.securityGroups=aa(i,"id"),l.length&&(t.dirty.securityGroups=l)}return e.backingData.filtered.securityGroups=n.sort((e,t)=>e.name.localeCompare(t.name)),t}refreshSecurityGroups(e,t){return this.cacheInitializer.refreshCache("securityGroups").then(()=>this.securityGroupReader.getAllSecurityGroups().then(a=>{e.backingData.securityGroups=a,t||this.configureSecurityGroupOptions(e)}))}getLoadBalancerMap(e){if(e.backingData.loadBalancers)return ta(e.backingData.loadBalancers).map("accounts").flattenDeep().filter({name:e.credentials}).map("regions").flattenDeep().filter({name:e.region}).map("loadBalancers").flattenDeep().value();return(e.backingData.appLoadBalancers||[]).filter(t=>t.region===e.region&&t.account===e.credentials)}getLoadBalancerNames(e){return this.getLoadBalancerMap(e).filter(t=>(!t.loadBalancerType||"classic"===t.loadBalancerType)&&t.vpcId===e.vpcId).map(e=>e.name).sort()}getVpcLoadBalancerNames(e){return this.getLoadBalancerMap(e).filter(e=>(!e.loadBalancerType||"classic"===e.loadBalancerType)&&e.vpcId).map(e=>e.name).sort()}getTargetGroupNames(e){const t=this.getLoadBalancerMap(e).filter(e=>"classic"!==e.loadBalancerType);return Kt(t.map(e=>e.targetGroups.filter(e=>"instance"===e.targetType))).map(e=>e.name).sort()}getValidMatches(e,t){const a=t.filter(e=>e.includes("${")),n=va(e,t),[r,i]=ua(t,e=>n.includes(e)||a.includes(e));return{valid:r,invalid:i,spel:a}}configureLoadBalancerOptions(e){const t={dirty:{}},a=(e.loadBalancers||[]).concat(e.vpcLoadBalancers||[]),n=e.targetGroups||[],r=this.getLoadBalancerNames(e),i=this.getVpcLoadBalancerNames(e),s=this.getTargetGroupNames(e);if(a&&e.loadBalancers){const n=e.vpcId?r:r.concat(i),{valid:s,invalid:l,spel:o}=this.getValidMatches(n,a);e.loadBalancers=va(r.concat(o),s),e.vpcId?delete e.vpcLoadBalancers:e.vpcLoadBalancers=va(i,s),l.length&&(t.dirty.loadBalancers=l),e.viewState.spelLoadBalancers=o||[]}if(n&&e.targetGroups&&!n.includes("${")){const{valid:a,invalid:r,spel:i}=this.getValidMatches(s,n);e.targetGroups=a,r.length&&(t.dirty.targetGroups=r),e.viewState.spelTargetGroups=i||[]}return e.backingData.filtered.loadBalancers=r,e.backingData.filtered.vpcLoadBalancers=i,e.backingData.filtered.targetGroups=s,t}refreshLoadBalancers(e,t){return this.loadBalancerReader.listLoadBalancers("aws").then(a=>{e.backingData.loadBalancers=a,t||this.configureLoadBalancerOptions(e)})}configureVpcId(e){const t={dirty:{}};if(e.subnetType){const t=ba(e.backingData.subnets,{purpose:e.subnetType,account:e.credentials,region:e.region});e.vpcId=t?t.vpcId:null}else e.vpcId=null,t.dirty.vpcId=!0;return ha(t.dirty,this.configureInstanceTypes(e).dirty),t}attachEventHandlers(e){e.usePreferredZonesChanged=e=>{const t=e.availabilityZones?e.availabilityZones.length:0,a={dirty:{}},n=e.backingData.preferredZones[e.credentials];if(n&&n[e.region]&&e.viewState.usePreferredZones)e.availabilityZones=_t(n[e.region].sort());else{e.availabilityZones=va(e.availabilityZones,e.backingData.filtered.availabilityZones);t!==(e.availabilityZones?e.availabilityZones.length:0)&&(a.dirty.availabilityZones=!0)}return a},e.subnetChanged=e=>{const t=this.configureVpcId(e);return ha(t.dirty,this.configureSecurityGroupOptions(e).dirty),ha(t.dirty,this.configureLoadBalancerOptions(e).dirty),e.viewState.dirty=e.viewState.dirty||{},ha(e.viewState.dirty,t.dirty),t},e.regionChanged=e=>{const t={dirty:{}},a=e.backingData.filtered;return ha(t.dirty,this.configureSubnetPurposes(e).dirty),e.region?(ha(t.dirty,e.subnetChanged(e).dirty),ha(t.dirty,this.configureInstanceTypes(e).dirty),this.configureAvailabilityZones(e),ha(t.dirty,e.usePreferredZonesChanged(e).dirty),ha(t.dirty,this.configureImages(e).dirty),ha(t.dirty,this.configureKeyPairs(e).dirty)):a.regionalAvailabilityZones=null,Mt(e),t},e.clusterChanged=e=>{e.moniker=re.getMoniker(e.application,e.stack,e.freeFormDetails),Mt(e)},e.credentialsChanged=e=>{const t={dirty:{}},a=e.backingData;if(e.credentials){const n=a.credentialsKeyedByAccount[e.credentials]||{regions:[]};a.filtered.regions=n.regions,oa(a.filtered.regions,{name:e.region})?ha(t.dirty,e.regionChanged(e).dirty):(e.region=null,t.dirty.region=!0)}else e.region=null;return Mt(e),t},e.imageChanged=e=>this.configureInstanceTypes(e),e.instanceTypeChanged=e=>{e.ebsOptimized=this.awsInstanceTypeService.isEbsOptimized(e.instanceType)},e.launchTemplateOverridesChanged=e=>{var t;e.ebsOptimized=null==(t=e.launchTemplateOverridesForInstanceType)?void 0:t.every(e=>this.awsInstanceTypeService.isEbsOptimized(e.instanceType))},this.applyOverrides("attachEventHandlers",e)}}lc.$inject=["securityGroupReader","awsInstanceTypeService","cacheInitializer","loadBalancerReader","serverGroupCommandRegistry"];const oc="spinnaker.amazon.serverGroup.configure.service";t(oc,[Ge,gr,Ae,st,Ft]).service("awsServerGroupConfigurationService",lc);const cc="spinnaker.amazon.serverGroupCommandBuilder.service";e.module(cc,[$t,oc]).factory("awsServerGroupCommandBuilder",["$q","instanceTypeService","awsServerGroupConfigurationService",function(t,a,n){function i(e,a){a=a||{};const n=o.getCredentialsKeyedByAccount("aws"),r=a.account||e.defaultCredentials.aws||kn.defaults.account,i=a.region||e.defaultRegions.aws||kn.defaults.region,l=a.subnet||kn.defaults.subnetType||"",c=o.getAvailabilityZonesForAccountAndRegion("aws",r,i);return t.all([c,n]).then(function([t,n]){var o,c,d,u,p,m,g,h;const f=n[r],v=f?f.defaultKeyPair:null,y=null!=(d=null==(c=null==(o=e.attributes)?void 0:o.providerSettings)?void 0:c.aws)?d:{};let b=kn.defaults.iamRole||"BaseIAMRole";b=b.replace("{{application}}",e.name);const E=y.useAmiBlockDeviceMappings||!1,w={application:e.name,credentials:r,region:i,strategy:"",capacity:{min:1,max:1,desired:1},targetHealthyDeployPercentage:100,cooldown:10,enabledMetrics:[],healthCheckType:"EC2",healthCheckGracePeriod:600,instanceMonitoring:!1,ebsOptimized:!1,selectedProvider:"aws",iamRole:b,terminationPolicies:["Default"],vpcId:null,subnetType:l,availabilityZones:t,keyPair:v,suspendedProcesses:[],securityGroups:[],stack:"",freeFormDetails:"",spotPrice:"",tags:{},useAmiBlockDeviceMappings:E,copySourceCustomBlockDeviceMappings:!1,viewState:{instanceProfile:"custom",useSimpleInstanceTypeSelector:!0,useAllImageSelection:!1,useSimpleCapacity:!0,usePreferredZones:!0,mode:a.mode||"create",disableStrategySelection:!0,dirty:{},submitButtonLabel:s(a.mode||"create")}};if((null==(u=e.attributes)?void 0:u.platformHealthOnlyShowOverride)&&(null==(p=e.attributes)?void 0:p.platformHealthOnly)&&(w.interestingHealthProviderNames=["Amazon"]),"test"===r&&(null==(m=kn.serverGroups)?void 0:m.enableIPv6)&&(w.associateIPv6Address=!0),null==(g=kn.serverGroups)?void 0:g.enableIMDSv2){const t=kn.serverGroups.defaultIMDSv2AppAgeLimit,a=null==(h=e.attributes)?void 0:h.createTs;w.requireIMDSv2=t&&a&&Number(a)>t}return w})}function s(e){switch(e){case"createPipeline":return"Add";case"editPipeline":return"Done";case"clone":return"Clone";default:return"Create"}}function l(e){return!(e.onDemandAllocationStrategy||e.onDemandBaseCapacity||e.onDemandPercentageAboveBaseCapacity||e.spotAllocationStrategy||e.spotInstancePools||e.launchTemplateOverridesForInstanceType&&e.launchTemplateOverridesForInstanceType.length>0)}return{buildNewServerGroupCommand:i,buildServerGroupCommandFromExisting:function(n,i,c="clone"){var d,u,p,m;const h=o.getPreferredZonesByAccount("aws"),f=g.listSubnets(),v=re.parseServerGroupName(i.asg.autoScalingGroupName);let y;if(i.mixedInstancesPolicy){const e=null==(d=i.mixedInstancesPolicy)?void 0:d.launchTemplateOverridesForInstanceType;y=e?e.map(e=>e.instanceType):[null==(m=null==(p=null==(u=i.mixedInstancesPolicy)?void 0:u.launchTemplates[0])?void 0:p.launchTemplateData)?void 0:m.instanceType]}else i.launchTemplate?y=[Ht.get(i,"launchTemplate.launchTemplateData.instanceType")]:i.launchConfig&&(y=[Ht.get(i,"launchConfig.instanceType")]);const b=a.getCategoryForMultipleInstanceTypes("aws",y);return t.all([h,f,b]).then(([t,a,o])=>{var d,u,p,m,g,h,f,y,b,E,w,C,S,k;const N=i.asg.availabilityZones.sort();let T=!1;const I=t[i.account];if(I){const e=I[i.region].sort();T=N.join(",")===e.join(",")}const G=["Launch","Terminate","AddToLoadBalancer"],A=(null!=(p=null==(u=null==(d=n.attributes)?void 0:d.providerSettings)?void 0:u.aws)?p:{}).useAmiBlockDeviceMappings||!1,x={},P=["spinnaker:application","spinnaker:stack","spinnaker:details"];i.asg.tags&&i.asg.tags.filter(e=>!P.includes(e.key)).forEach(e=>{x[e.key]=e.value});const D={application:n.name,strategy:"",stack:v.stack,freeFormDetails:v.freeFormDetails,credentials:i.account,cooldown:i.asg.defaultCooldown,enabledMetrics:Ht.get(i,"asg.enabledMetrics",[]).map(e=>e.metric),healthCheckGracePeriod:i.asg.healthCheckGracePeriod,healthCheckType:i.asg.healthCheckType,terminationPolicies:i.asg.terminationPolicies,loadBalancers:i.asg.loadBalancerNames,region:i.region,useSourceCapacity:!1,capacity:{min:i.asg.minSize,max:i.asg.maxSize,desired:i.asg.desiredCapacity},targetHealthyDeployPercentage:100,availabilityZones:N,selectedProvider:"aws",source:{account:i.account,region:i.region,asgName:i.asg.autoScalingGroupName},suspendedProcesses:(i.asg.suspendedProcesses||[]).map(e=>e.processName).filter(e=>!G.includes(e)),tags:Object.assign({},i.tags,x),targetGroups:i.targetGroups,useAmiBlockDeviceMappings:A,copySourceCustomBlockDeviceMappings:"clone"===c,viewState:{instanceProfile:o,useAllImageSelection:!1,useSimpleCapacity:i.asg.minSize===i.asg.maxSize,usePreferredZones:T,mode:c,submitButtonLabel:s(c),isNew:!1,dirty:{}}};if((null==(m=n.attributes)?void 0:m.platformHealthOnlyShowOverride)&&(null==(g=n.attributes)?void 0:g.platformHealthOnly)&&(D.interestingHealthProviderNames=["Amazon"]),"editPipeline"===c){D.useSourceCapacity=!0,D.viewState.useSimpleCapacity=!1,D.strategy="redblack";const e=r.getStrategy("redblack");e.initializationMethod&&e.initializationMethod(D),D.suspendedProcesses=[]}const B=i.asg.vpczoneIdentifier;if(""!==B){const e=B.split(",")[0],t=a.find(t=>t.id===e);D.subnetType=t.purpose,D.vpcId=t.vpcId}else D.subnetType="",D.vpcId=null;if(i.launchConfig&&(e.extend(D,{instanceType:i.launchConfig.instanceType,iamRole:i.launchConfig.iamInstanceProfile,keyPair:i.launchConfig.keyName,associatePublicIpAddress:i.launchConfig.associatePublicIpAddress,ramdiskId:i.launchConfig.ramdiskId,instanceMonitoring:i.launchConfig.instanceMonitoring&&i.launchConfig.instanceMonitoring.enabled,ebsOptimized:i.launchConfig.ebsOptimized,spotPrice:i.launchConfig.spotPrice}),i.launchConfig.userData&&(D.base64UserData=i.launchConfig.userData),D.viewState.imageId=i.launchConfig.imageId,D.viewState.useSimpleInstanceTypeSelector=!0),i.launchTemplate||i.mixedInstancesPolicy){let t,a;if(i.launchTemplate&&(t=i.launchTemplate.launchTemplateData,a=null==(f=null==(h=t.instanceMarketOptions)?void 0:h.spotOptions)?void 0:f.maxPrice,D.instanceType=t.instanceType,D.viewState.useSimpleInstanceTypeSelector=!0,t.userData&&(D.base64UserData=t.userData)),i.mixedInstancesPolicy){const e=i.mixedInstancesPolicy;t=null==(b=null==(y=null==e?void 0:e.launchTemplates)?void 0:y[0])?void 0:b.launchTemplateData,a=null==(E=null==e?void 0:e.instancesDistribution)?void 0:E.spotMaxPrice,D.securityGroups=t.networkInterfaces?(null!=(w=t.networkInterfaces.find(e=>0===e.deviceIndex))?w:{}).groups:t.securityGroups,D.onDemandAllocationStrategy=e.instancesDistribution.onDemandAllocationStrategy,D.onDemandBaseCapacity=e.instancesDistribution.onDemandBaseCapacity,D.onDemandPercentageAboveBaseCapacity=e.instancesDistribution.onDemandPercentageAboveBaseCapacity,D.spotAllocationStrategy=e.instancesDistribution.spotAllocationStrategy,D.spotInstancePools=e.instancesDistribution.spotInstancePools,e.launchTemplateOverridesForInstanceType?D.launchTemplateOverridesForInstanceType=function(e){let t=1;return Ht.sortBy(e,["priority"]).map(e=>{const{instanceType:a,weightedCapacity:n}=e;let r;return e.priority?(r=e.priority,t=e.priority+1):r=t++,{instanceType:a,weightedCapacity:n,priority:r}})}(e.launchTemplateOverridesForInstanceType):D.instanceType=t.instanceType,D.viewState.useSimpleInstanceTypeSelector=l(D)}const n=Ht.get(t,"networkInterfaces[0]"),r=null!=(C=null==n?void 0:n.ipv6AddressCount)?C:0,s=kn.serverGroups,o=i.accountDetails&&"test"===i.accountDetails.environment,c=s&&s.enableIPv6&&s.setIPv6InTest&&o;e.extend(D,{iamRole:t.iamInstanceProfile.name,keyPair:t.keyName,associateIPv6Address:c||Boolean(r),ramdiskId:t.ramdiskId,instanceMonitoring:t.monitoring&&t.monitoring.enabled,ebsOptimized:t.ebsOptimized,spotPrice:a||void 0,requireIMDSv2:Boolean("required"===(null==(S=t.metadataOptions)?void 0:S.httpTokens)),unlimitedCpuCredits:t.creditSpecification?"unlimited"===t.creditSpecification.cpuCredits:void 0}),D.viewState.imageId=t.imageId}if("clone"===c&&i.image&&i.image.name&&(D.amiName=i.image.name),i.launchConfig&&i.launchConfig.securityGroups.length&&(D.securityGroups=i.launchConfig.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.securityGroups.length&&(D.securityGroups=i.launchTemplate.launchTemplateData.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.networkInterfaces){const e=null!=(k=i.launchTemplate.launchTemplateData.networkInterfaces.find(e=>0===e.deviceIndex))?k:{};D.securityGroups=e.groups}return D})},buildNewServerGroupCommandForPipeline:function(){return t.when({viewState:{requiresTemplateSelection:!0}})},buildServerGroupCommandFromPipeline:function(n,r){const s=Ht.cloneDeep(r),o=Object.keys(s.availabilityZones)[0],c=s.launchTemplateOverridesForInstanceType?s.launchTemplateOverridesForInstanceType.map(e=>e.instanceType):[s.instanceType],d=a.getCategoryForMultipleInstanceTypes("aws",c),u={account:s.account,region:o};return t.all([i(n,u),d]).then(function([t,a]){const n=s.availabilityZones[o].join(",")===t.availabilityZones.join(","),r={instanceProfile:a,disableImageSelection:!0,useSimpleCapacity:s.capacity.min===s.capacity.max&&!0!==s.useSourceCapacity,usePreferredZones:n,mode:"editPipeline",submitButtonLabel:"Done",templatingEnabled:!0,existingPipelineCluster:!0,dirty:{},useSimpleInstanceTypeSelector:l(s)},i={region:o,credentials:s.account,availabilityZones:s.availabilityZones[o],iamRole:s.iamRole,viewState:r};return s.strategy=s.strategy||"",e.extend({},t,s,i)})},buildUpdateServerGroupCommand:function(t){var a,r;const i={type:"modifyAsg",asgs:[{asgName:t.name,region:t.region}],cooldown:t.asg.defaultCooldown,enabledMetrics:(null!=(r=null==(a=t.asg)?void 0:a.enabledMetrics)?r:[]).map(e=>e.metric),healthCheckGracePeriod:t.asg.healthCheckGracePeriod,healthCheckType:t.asg.healthCheckType,terminationPolicies:e.copy(t.asg.terminationPolicies),credentials:t.account,capacityRebalance:t.asg.capacityRebalance};return n.configureUpdateCommand(i),i}}}]);const dc="spinnaker.amazon.serverGroup.editAsgAdvancedSettings.modal.controller";t(dc,[cc]).controller("EditAsgAdvancedSettingsCtrl",["$scope","$uibModalInstance","application","serverGroup","awsServerGroupCommandBuilder",function(e,t,a,n,r){e.command=r.buildUpdateServerGroupCommand(n),e.serverGroup=n,e.taskMonitor=new v({application:a,title:"Update Advanced Settings for "+n.name,modalInstance:t,onTaskComplete:()=>a.serverGroups.refresh()}),this.submit=()=>{const t=[e.command];e.taskMonitor.submit(function(){return O.executeTask({job:t,application:a,description:"Update Advanced Settings for "+n.name})})},this.cancel=t.dismiss}]);const uc="spinnaker.amazon.serverGroup.details.rollback.controller";t(uc,[Lt]).controller("awsRollbackServerGroupCtrl",["$scope","$uibModalInstance","serverGroupWriter","application","serverGroup","previousServerGroup","disabledServerGroups","allServerGroups",function(e,t,a,n,r,i,s,l){e.serverGroup=r,e.disabledServerGroups=s.sort((e,t)=>t.name.localeCompare(e.name)),e.allServerGroups=l.sort((e,t)=>t.name.localeCompare(e.name)),e.verification={};const o=r.capacity.desired;let c,d="EXPLICIT";if(0===l.length&&r.entityTags){const t=ia(r,"entityTags.creationMetadata.value.previousServerGroup");if(t){d="PREVIOUS_IMAGE",e.previousServerGroup={name:t.name,imageName:t.imageName},t.imageId&&t.imageId!==t.imageName&&(e.previousServerGroup.imageId=t.imageId);const a=ia(t,"buildInfo.jenkins.number");a&&(e.previousServerGroup.buildNumber=a)}}c=o<10?100:o<20?90:95,e.command={rollbackType:d,rollbackContext:{rollbackServerGroupName:r.name,restoreServerGroupName:i?i.name:void 0,targetHealthyRollbackPercentage:c,delayBeforeDisableSeconds:0}},e.minHealthy=function(e){return Math.ceil(o*e/100)},n&&n.attributes&&(n.attributes.platformHealthOnlyShowOverride&&n.attributes.platformHealthOnly&&(e.command.interestingHealthProviderNames=["Amazon"]),e.command.platformHealthOnlyShowOverride=n.attributes.platformHealthOnlyShowOverride),this.isValid=function(){const t=e.command;return!!e.verification.verified&&("PREVIOUS_IMAGE"===d||void 0!==t.rollbackContext.restoreServerGroupName)},e.taskMonitor=new v({application:n,title:"Rollback "+r.name,modalInstance:t}),this.rollback=function(){if(!this.isValid())return;e.taskMonitor.submit(function(){return a.rollbackServerGroup(r,n,e.command)})},this.cancel=function(){t.dismiss()},this.label=function(e){return e?e.buildInfo&&e.buildInfo.jenkins&&e.buildInfo.jenkins.number?e.name+" (build #"+e.buildInfo.jenkins.number+")":e.name:""},this.group=function(e){return e.isDisabled?"Disabled Server Groups":"Enabled Server Groups"}}]);const pc="spinnaker.amazon.scalingPolicy.scalingPolicySummary.component";t(pc,[]).component("scalingPolicySummary",Ja(L(Oo,"scalingPolicySummary"),["application","policy","serverGroup"]));const mc="spinnaker.amazon.scalingPolicy.module";t(mc,[pc]);const gc="spinnaker.amazon.serverGroup.details.autoscaling.process.controller";e.module(gc,[]).controller("ModifyScalingProcessesCtrl",["$scope","$uibModalInstance","application","serverGroup","processes",function(t,a,n,r,i){t.command=e.copy(i),t.serverGroup=r,t.verification={},this.isValid=function(){return!!t.verification.verified&&this.isDirty()};const s=Ht.chain(t.command).filter({enabled:!0}).map("name").value(),l=Ht.chain(t.command).filter({enabled:!1}).map("name").value();this.isDirty=function(){const e=Ht.chain(t.command).filter({enabled:!0}).map("name").value(),a=Ht.chain(t.command).filter({enabled:!1}).map("name").value(),n=Ht.intersection(l,e),r=Ht.intersection(s,a);return!(!n.length&&!r.length)},t.taskMonitor=new v({application:n,title:"Update Auto Scaling Processes for "+r.name,modalInstance:a,onTaskComplete:()=>n.serverGroups.refresh()}),this.submit=function(){const e=Ht.chain(t.command).filter({enabled:!0}).map("name").value(),a=Ht.chain(t.command).filter({enabled:!1}).map("name").value(),i=Ht.intersection(l,e),o=Ht.intersection(s,a),c=[];i.length&&c.push({type:"modifyScalingProcess",action:"resume",processes:i,asgName:r.name,regions:[r.region],credentials:r.account,cloudProvider:"aws",reason:t.command.reason}),o.length&&c.push({type:"modifyScalingProcess",action:"suspend",processes:o,asgName:r.name,regions:[r.region],credentials:r.account,cloudProvider:"aws",reason:t.command.reason});t.taskMonitor.submit(function(){return O.executeTask({job:c,application:n,description:"Update Auto Scaling Processes for "+r.name})})},this.cancel=a.dismiss}]);const hc="spinnaker.amazon.serverGroup.details.scheduledActions.editScheduledActions.modal.controller";t(hc,[]).controller("EditScheduledActionsCtrl",["$scope","$uibModalInstance","application","serverGroup",function(e,t,a,n){e.command={scheduledActions:n.scheduledActions.map(e=>({recurrence:e.recurrence,minSize:e.minSize,maxSize:e.maxSize,desiredCapacity:e.desiredCapacity}))},e.serverGroup=n,this.addScheduledAction=()=>{e.command.scheduledActions.push({})},this.removeScheduledAction=t=>{e.command.scheduledActions.splice(t,1)},e.taskMonitor=new v({application:a,title:"Update Scheduled Actions for "+n.name,modalInstance:t,onTaskComplete:()=>a.serverGroups.refresh()}),this.submit=()=>{const t=[{type:"upsertAsgScheduledActions",asgs:[{asgName:n.name,region:n.region}],scheduledActions:e.command.scheduledActions,credentials:n.account}];e.taskMonitor.submit(function(){return O.executeTask({job:t,application:a,description:"Update Scheduled Actions for "+n.name})})},this.cancel=t.dismiss}]);const fc="spinnaker.amazon.serverGroup.details.securityGroup.editSecurityGroups.modal.controller";t(fc,[Lt,Ge]).controller("EditSecurityGroupsCtrl",["$scope","$uibModalInstance","serverGroupWriter","securityGroupReader","application","serverGroup","securityGroups",function(e,t,a,n,r,i,s){this.command={securityGroups:(s||[]).slice(0).sort((e,t)=>e.name.localeCompare(t.name))},this.state={securityGroupsLoaded:!1,submitting:!1,verification:{}},this.infiniteScroll={currentItems:20},this.addMoreItems=()=>this.infiniteScroll.currentItems+=20,this.resetCurrentItems=()=>this.infiniteScroll.currentItems=20,this.isValid=()=>this.state.verification.verified,n.getAllSecurityGroups().then(e=>{const t=i.account,a=i.region,n=i.vpcId;this.availableSecurityGroups=Ht.get(e,[t,"aws",a].join("."),[]).filter(e=>e.vpcId===n).sort((e,t)=>this.command.securityGroups.some(t=>t.id===e.id)?-1:this.command.securityGroups.some(e=>e.id===t.id)?1:e.name.localeCompare(t.name)),this.state.securityGroupsLoaded=!0}),this.serverGroup=i,this.taskMonitor=new v({application:r,title:`Update ${U.get("Firewalls")} for ${i.name}`,modalInstance:t,onTaskComplete:()=>r.serverGroups.refresh()}),this.submit=()=>{this.taskMonitor.submit(()=>{this.state.submitting=!0;const e=Boolean(i.launchTemplate);return a.updateSecurityGroups(i,this.command.securityGroups,r,e)})},this.cancel=t.dismiss}]);const vc="spinnaker.amazon.serverGroup.details";t(vc,[mc,fc,gc,hc,dc,uc]);const yc="spinnaker.amazon.serverGroup.transformer";t(yc,[]).service("awsServerGroupTransformer",class{addComparator(e){if(e.comparisonOperator)switch(e.comparisonOperator){case"LessThanThreshold":e.comparator="<";break;case"GreaterThanThreshold":e.comparator=">";break;case"LessThanOrEqualToThreshold":e.comparator="≤";break;case"GreaterThanOrEqualToThreshold":e.comparator="≥"}}addAdjustmentAttributes(e){e.operator=e.scalingAdjustment<0?"decrease":"increase",e.absAdjustment=Math.abs(e.scalingAdjustment)}transformScalingPolicy(e){const t={...e},a=(e,t)=>t.metricIntervalUpperBound-e.metricIntervalUpperBound,n=(e,t)=>e.metricIntervalLowerBound-t.metricIntervalLowerBound;if(t.alarms=e.alarms||[],t.alarms.forEach(e=>this.addComparator(e)),this.addAdjustmentAttributes(t),t.stepAdjustments&&t.stepAdjustments.length){t.stepAdjustments.forEach(e=>this.addAdjustmentAttributes(e));const r=e.stepAdjustments.every(e=>void 0!==e.metricIntervalUpperBound)?a:n;t.stepAdjustments.sort((e,t)=>r(e,t))}return t}normalizeServerGroupDetails(e){const t={...e};return e.scalingPolicies&&(t.scalingPolicies=e.scalingPolicies.map(e=>this.transformScalingPolicy(e))),t}normalizeServerGroup(e){return e.instances.forEach(t=>{t.vpcId=e.vpcId}),Wn.listVpcs().then(t=>this.addVpcNameToServerGroup(e)(t))}addVpcNameToServerGroup(e){return t=>{const a=t.find(t=>t.id===e.vpcId);return e.vpcName=a?a.name:"",e}}convertServerGroupCommandToDeployConfiguration(e){const t={...e};t.cloudProvider="aws",t.availabilityZones={[t.region]:e.availabilityZones},t.loadBalancers=(e.loadBalancers||[]).concat(e.vpcLoadBalancers||[]),t.targetGroups=e.targetGroups||[],t.account=t.credentials,t.subnetType=t.subnetType||"",t.instanceType=t.instanceType||t.launchTemplateOverridesForInstanceType&&t.launchTemplateOverridesForInstanceType[0].instanceType,"clone"!==e.viewState.mode&&delete t.source,t.ramdiskId||delete t.ramdiskId;return["region","viewState","backingData","selectedProvider","instanceProfile","vpcId"].forEach(e=>{delete t[e]}),t}constructNewStepScalingPolicyTemplate(e){return{alarms:[{namespace:"AWS/EC2",metricName:"CPUUtilization",threshold:50,statistic:"Average",comparisonOperator:"GreaterThanThreshold",evaluationPeriods:1,dimensions:[{name:"AutoScalingGroupName",value:e.name}],period:60}],adjustmentType:"ChangeInCapacity",stepAdjustments:[{scalingAdjustment:1,metricIntervalLowerBound:0}],estimatedInstanceWarmup:600}}constructNewTargetTrackingPolicyTemplate(){return{alarms:[],estimatedInstanceWarmup:300,targetTrackingConfiguration:{targetValue:null,predefinedMetricSpecification:{predefinedMetricType:"ASGAverageCPUUtilization"}}}}});const bc="spinnaker.amazon.subnet.renderer";t(bc,[]).service("awsSubnetRenderer",class{render(e){return e.subnetType}});Rt.registerValidator("aws",new class{validateSpecialCharacters(e,t){/^[a-zA-Z_0-9.]*$/g.test(e)||t.push("Only dot(.) and underscore(_) special characters are allowed.")}validateClassicLock(e){const t=kn.classicLaunchLockout;t&&t<(new Date).getTime()&&e.push(`New applications deployed to AWS are restricted to VPC; you cannot create server groups,\n load balancers, or ${U.get("firewalls")} in EC2 Classic.`)}validateLoadBalancerCharacters(e,t){(e.includes(".")||e.includes("_"))&&t.push("If the application's name contains an underscore(_) or dot(.),\n you will not be able to create a load balancer,\n preventing it from being used as a front end service.\n Any hostname constructed with this application name may have issues.")}validateLength(e,t,a){if(e.length>250)a.push("The maximum length for an application in Amazon is 250 characters.");else{if(e.length>240)if(e.length>=248)t.push(`You will not be able to include a stack or detail field for clusters or ${U.get("firewalls")}.`);else{const a=248-e.length;t.push(`If you plan to include a stack or detail field for clusters, you will only\n have ~${a} characters to do so.`)}if(e.length>20)if(e.length>32)t.push(`You will not be able to create an Amazon load balancer for this application if the\n application's name is longer than 32 characters (currently: ${e.length} characters)`);else if(e.length>=30)t.push(`If you plan to create load balancers for this application, be aware that the character limit\n for load balancer names is 32 (currently: ${e.length} characters). With separators ("-"), you will not\n be able to add a stack and detail field to any load balancer.`);else{const a=30-e.length;t.push(`If you plan to create load balancers for this application, be aware that the character limit\n for load balancer names is 32. You will only have ~${a} characters to add a stack or detail\n field to any load balancer.`)}}}validate(e=""){const t=[],a=[];return e.length&&(this.validateClassicLock(t),this.validateSpecialCharacters(e,a),this.validateLoadBalancerCharacters(e,t),this.validateLength(e,t,a)),{warnings:t,errors:a}}});const Ec="spinnaker.amazon.vpc";t(Ec,[]).component("vpcTag",Ja(L(vr,"vpcTag"),["vpcId"]));Ar('.cloud-provider-logo .icon-aws {\n -webkit-mask-image: url("data:image/svg+xml,%3C%3Fxml version%3D%221.0%22 encoding%3D%22utf-8%22%3F%3E%3C!DOCTYPE svg PUBLIC %22-%2F%2FW3C%2F%2FDTD SVG 1.1%2F%2FEN%22 %22http%3A%2F%2Fwww.w3.org%2FGraphics%2FSVG%2F1.1%2FDTD%2Fsvg11.dtd%22%3E%3Csvg version%3D%221.1%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22 x%3D%220px%22 y%3D%220px%22%09 width%3D%22130px%22 height%3D%22130px%22 viewBox%3D%220 0 27 27%22%3E%3Cg%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2213.2%2C27 2.4%2C23.1 2.4%2C8.5 13.2%2C12.5 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2226.5%2C23.1 15.2%2C27 15.2%2C12.5 26.5%2C8 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2214.2%2C3.4 25.5%2C7 14.2%2C11.0 2.9%2C7 %22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");\n mask-image: url("data:image/svg+xml,%3C%3Fxml version%3D%221.0%22 encoding%3D%22utf-8%22%3F%3E%3C!DOCTYPE svg PUBLIC %22-%2F%2FW3C%2F%2FDTD SVG 1.1%2F%2FEN%22 %22http%3A%2F%2Fwww.w3.org%2FGraphics%2FSVG%2F1.1%2FDTD%2Fsvg11.dtd%22%3E%3Csvg version%3D%221.1%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22 x%3D%220px%22 y%3D%220px%22%09 width%3D%22130px%22 height%3D%22130px%22 viewBox%3D%220 0 27 27%22%3E%3Cg%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2213.2%2C27 2.4%2C23.1 2.4%2C8.5 13.2%2C12.5 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2226.5%2C23.1 15.2%2C27 15.2%2C12.5 26.5%2C8 %22%2F%3E%09%3Cpolygon fill%3D%22%23000000%22 stroke%3D%22%23FFFFFF%22 stroke-width%3D%220%22 points%3D%2214.2%2C3.4 25.5%2C7 14.2%2C11.0 2.9%2C7 %22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");\n}\n');const wc="spinnaker.amazon";t(wc,[Js,Bi,zi,ms,gs,hs,Is,fs,vs,ys,Ns,Ts,Hs,Ws,js,vc,In,yc,gr,Pi,er,Cr,fl,bc,Ec,Qs,Ji,Wi,Ui,es,Ir,Gr,Nr,kr,yr,Vi,ps,ks,Xs,qs]).config(()=>{V.registerProvider("aws",{name:"Amazon",adHocInfrastructureWritesEnabled:kn.adHocInfraWritesEnabled,logo:{path:"amazon.logo352d4e042476837f.svg"},image:{reader:ar},serverGroup:{transformer:"awsServerGroupTransformer",detailsActions:oo,detailsGetter:uo,detailsSections:[Uo,Ho,Wo,jo,_o,Yo,rc,tc,ec,nc,ic,Jo,Vo,Xo],CloneServerGroupModal:ao,commandBuilder:"awsServerGroupCommandBuilder",configurationService:"awsServerGroupConfigurationService",scalingActivitiesEnabled:!0,TargetTrackingChart:fo,UpsertStepPolicyModal:Do,UpsertTargetTrackingModal:So},instance:{instanceTypeService:"awsInstanceTypeService",detailsTemplateUrl:"amazon/src/instance/details/instanceDetails.html",detailsController:"awsInstanceDetailsCtrl"},loadBalancer:{transformer:Mr,detailsTemplateUrl:"amazon/src/loadBalancer/details/loadBalancerDetails.html",detailsController:"awsLoadBalancerDetailsCtrl",CreateLoadBalancerModal:Si,targetGroupDetailsTemplateUrl:"amazon/src/loadBalancer/details/targetGroupDetails.html",targetGroupDetailsController:"awsTargetGroupDetailsCtrl",ClusterContainer:Pr,LoadBalancersTag:Fr},function:{details:Qn,CreateFunctionModal:_n,transformer:xn},securityGroup:{transformer:"awsSecurityGroupTransformer",reader:"awsSecurityGroupReader",detailsTemplateUrl:"amazon/src/securityGroup/details/securityGroupDetail.html",detailsController:"awsSecurityGroupDetailsCtrl",createSecurityGroupTemplateUrl:"amazon/src/securityGroup/configure/createSecurityGroup.html",createSecurityGroupController:"awsCreateSecurityGroupCtrl"},subnet:{renderer:"awsSubnetRenderer"},search:{resultFormatter:"awsSearchResultFormatter"},applicationProviderFields:{templateUrl:"amazon/src/applicationProviderFields/awsFields.html"}})}),r.registerProvider("aws",["custom","redblack","rollingpush","rollingredblack","monitored"]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/instance/details/instanceDetails.html",'<div class="text-center" ng-if="state.notFoundStandalone">\n <h3>Could not find instance {{instanceIdNotFound}}.</h3>\n <a ui-sref="home.infrastructure">Back to search results</a>\n</div>\n<div class="details-panel" ng-if="!state.notFoundStandalone">\n <div class="header">\n <instance-details-header\n health-state="instance.healthState"\n instance-id="instance.instanceId || instanceIdNotFound"\n loading="state.loading"\n standalone="state.standalone"\n ></instance-details-header>\n <div ng-if="!state.loading" ng-hide="isDisabled">\n <div class="actions" ng-class="{ insights: instance.insightActions.length > 0 }" ng-if="instance.placement">\n <instance-actions actions="instanceActions"></instance-actions>\n <instance-insights insights="instance.insightActions" instance="instance"></instance-insights>\n </div>\n </div>\n </div>\n <div class="content" ng-if="!state.loading && instance">\n <amazon-instance-information instance="instance"></amazon-instance-information>\n <instance-status\n health-metrics="healthMetrics"\n health-state="instance.healthState"\n metric-types="[\'LoadBalancer\', \'TargetGroup\']"\n private-ip-address="instance.privateIpAddress"\n >\n </instance-status>\n <collapsible-section heading="DNS">\n <instance-dns\n instance-port="state.instancePort"\n ipv6-addresses="instance.ipv6Addresses"\n permanent-ips="instance.permanentIps"\n private-dns-name="instance.privateDnsName"\n private-ip-address="instance.privateIpAddress"\n public-dns-name="instance.publicDnsName"\n public-ip-address="instance.publicIpAddress"\n >\n </instance-dns>\n </collapsible-section>\n <instance-security-groups instance="instance"></instance-security-groups>\n <instance-tags tags="instance.tags"></instance-tags>\n <collapsible-section heading="Console Output" ng-if="baseIpAddress">\n <ul>\n <li>\n <console-output-link instance="instance"></console-output-link>\n </li>\n </ul>\n </collapsible-section>\n <instance-links\n address="baseIpAddress"\n application="application"\n instance="instance"\n moniker="moniker"\n environment="environment"\n ></instance-links>\n </div>\n <div class="content" ng-if="!state.loading && !instance">\n <div class="content-section">\n <div class="content-body text-center">\n <h3>Instance not found.</h3>\n </div>\n </div>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/loadBalancer/details/loadBalancerDetails.html",'<div class="details-panel">\n <div ng-if="ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="horizontal center middle spinner-container">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n </div>\n\n <div ng-if="!ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="header-text horizontal middle">\n <i class="fa icon-sitemap"></i>\n <h3 class="horizontal middle space-between flex-1" select-on-dbl-click>\n {{ctrl.loadBalancer.name}}\n <render-if-feature feature="entityTags">\n <entity-notifications\n entity="ctrl.loadBalancer"\n application="ctrl.application"\n placement="bottom"\n h-offset-percent="90%"\n entity-type="loadBalancer"\n page-location="details"\n on-update="ctrl.application.loadBalancers.refresh()"\n ></entity-notifications>\n </render-if-feature>\n </h3>\n </div>\n <div>\n <div class="actions">\n <load-balancer-actions\n app="ctrl.application"\n load-balancer="ctrl.loadBalancer"\n load-balancer-from-params="ctrl.loadBalancerFromParams"\n ></load-balancer-actions>\n <div\n class="dropdown"\n ng-if="ctrl.loadBalancer.elb.insightActions.length > 0"\n uib-dropdown\n dropdown-append-to-body\n >\n <button type="button" class="btn btn-sm btn-default dropdown-toggle" uib-dropdown-toggle>\n Insight <span class="caret"></span>\n </button>\n <ul class="dropdown-menu" uib-dropdown-menu role="menu">\n <li ng-repeat="action in ctrl.loadBalancer.elb.insightActions">\n <a target="_blank" href="{{action.url}}">{{action.label}}</a>\n </li>\n </ul>\n </div>\n </div>\n </div>\n </div>\n <managed-resource-details-indicator\n ng-if="!ctrl.state.loading && ctrl.loadBalancer.isManaged"\n resource-summary="ctrl.loadBalancer.managedResourceSummary"\n application="ctrl.application"\n >\n </managed-resource-details-indicator>\n <div ng-if="!ctrl.state.loading" class="content">\n <collapsible-section heading="Load Balancer Details" expanded="true">\n <dl class="dl-horizontal dl-narrow">\n <dt>Created</dt>\n <dd>{{ctrl.loadBalancer.elb.createdTime | timestamp}}</dd>\n <dt>In</dt>\n <dd>\n <account-tag account="ctrl.loadBalancer.account" pad="right"></account-tag> {{ctrl.loadBalancer.region}}\n </dd>\n <dt>VPC</dt>\n <dd>\n <vpc-tag vpc-id="ctrl.loadBalancer.elb.vpcId"></vpc-tag>\n </dd>\n <dt>Subnet</dt>\n <dd>{{ctrl.getFirstSubnetPurpose(ctrl.loadBalancer.subnetDetails)}}</dd>\n <dt>Scheme</dt>\n <dd>{{ ctrl.loadBalancer.scheme }}</dd>\n <dt ng-if="ctrl.loadBalancer.loadBalancerType">Type</dt>\n <dd ng-if="ctrl.loadBalancer.loadBalancerType">{{ctrl.loadBalancer.loadBalancerType}}</dd>\n <dt ng-if="ctrl.ipAddressTypeDescription">IP Type</dt>\n <dd ng-if="ctrl.ipAddressTypeDescription">{{ctrl.ipAddressTypeDescription}}</dd>\n </dl>\n <dl class="horizontal-when-filters-collapsed">\n <dt>Availability Zones</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="availabilityZone in ctrl.loadBalancer.elb.availabilityZones">{{availabilityZone}}</li>\n </ul>\n </dd>\n </dl>\n <dl\n ng-if="ctrl.loadBalancer.serverGroups && ctrl.loadBalancer.serverGroups.length"\n class="horizontal-when-filters-collapsed"\n >\n <dt>Server Groups</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="serverGroup in ctrl.loadBalancer.serverGroups | orderBy: [\'isDisabled\', \'-name\']">\n <a\n ui-sref="^.serverGroup({region: serverGroup.region,\n accountId: serverGroup.account,\n serverGroup: serverGroup.name,\n provider: \'aws\'})"\n >\n {{serverGroup.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n <dl\n ng-if="ctrl.loadBalancer.targetGroups && ctrl.loadBalancer.targetGroups.length"\n class="horizontal-when-filters-collapsed"\n >\n <dt>Target Groups</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="targetGroup in ctrl.loadBalancer.targetGroups | orderBy: [\'isDisabled\', \'-name\']">\n <a\n ui-sref="^.targetGroupDetails({region: targetGroup.region,\n loadBalancerName: ctrl.loadBalancer.name,\n accountId: targetGroup.account,\n name: targetGroup.name,\n vpcId: targetGroup.vpcId,\n provider: \'aws\'})"\n >\n {{targetGroup.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n <dl class="horizontal-when-filters-collapsed">\n <dt ng-if="ctrl.loadBalancer.elb.dnsname">DNS Name</dt>\n <dd>\n <a target="_blank" href="{{ctrl.elbProtocol}}//{{ctrl.loadBalancer.elb.dnsname}}"\n >{{ctrl.loadBalancer.elb.dnsname}}</a\n >\n <copy-to-clipboard\n class="copy-to-clipboard copy-to-clipboard-sm"\n text="ctrl.loadBalancer.elb.dnsname"\n tool-tip="\'Copy DNS Name to clipboard\'"\n >\n </copy-to-clipboard>\n </dd>\n </dl>\n </collapsible-section>\n <collapsible-section heading="Status" expanded="true" ng-if="ctrl.loadBalancer.loadBalancerType === \'classic\'">\n <health-counts class="pull-left" container="ctrl.loadBalancer.instanceCounts"></health-counts>\n </collapsible-section>\n <collapsible-section heading="Status" expanded="false" ng-if="ctrl.loadBalancer.loadBalancerType !== \'classic\'">\n Select a target group to check the instance health status from the view of the target group.\n </collapsible-section>\n <collapsible-section ng-if="ctrl.loadBalancer.loadBalancerType === \'classic\'" heading="Listeners">\n <dl>\n <dt>Load Balancer → Instance</dt>\n <dd ng-repeat="listener in ctrl.loadBalancer.elb.listenerDescriptions">\n {{listener.listener.protocol}}:{{listener.listener.loadBalancerPort}} →\n {{listener.listener.instanceProtocol}}:{{listener.listener.instancePort}}\n </dd>\n </dl>\n </collapsible-section>\n <collapsible-section ng-if="ctrl.loadBalancer.loadBalancerType !== \'classic\'" heading="Listeners">\n <div ng-repeat="listener in ctrl.listeners">\n <div class="listener-targets">{{listener.in}} →</div>\n <div class="listener-targets">\n <div ng-repeat="action in listener.actions">\n \x3c!-- redirect --\x3e\n <span ng-if="action.type === \'redirect\'">\n <span ng-if="action.redirectConfig.protocol !== listener.protocol">\n {{action.redirectConfig.protocol}}:\n </span>\n <span ng-if="action.redirectConfig.host !== \'#{host}\'"> {{action.redirectConfig.host}} </span>\n <span ng-if="action.redirectConfig.port !== \'#{port}\'"> {{action.redirectConfig.port}} </span>\n <span ng-if="action.redirectConfig.path !== \'/#{path}\'"> {{action.redirectConfig.path}} </span>\n <span ng-if="action.redirectConfig.query !== \'#{query}\'"> ?{{action.redirectConfig.query}} </span>\n ({{action.redirectConfig.statusCode}})\n </span>\n \x3c!-- authenticate-oidc --\x3e\n <span ng-if="action.type === \'authenticate-oidc\'">\n <i class="fas fa-fw fa-user-lock"></i>\n <a\n ng-if="ctrl.oidcConfigPath"\n href="{{ctrl.oidcConfigPath}}{{action.authenticateOidcConfig.clientId}}"\n target="_blank"\n >\n {{action.authenticateOidcConfig.clientId}}\n </a>\n <span ng-if="!ctrl.oidcConfigPath"> {{action.authenticateOidcConfig.clientId}} </span>\n </span>\n \x3c!-- forward --\x3e\n <span ng-if="action.targetGroupName && action.targetGroup">\n <i class="fa fa-fw fa-crosshairs icon" aria-hidden="true"></i>\n <a\n ui-sref="^.targetGroupDetails({region: action.targetGroup.region,\n loadBalancerName: ctrl.loadBalancer.name,\n accountId: action.targetGroup.account,\n name: action.targetGroup.name,\n vpcId: action.targetGroup.vpcId,\n provider: \'aws\'})"\n >\n {{action.targetGroupName}}\n </a>\n </span>\n <span ng-if="action.targetGroupName && !action.targetGroup">\n <i class="fa fa-fw fa-crosshairs icon" aria-hidden="true"></i>\n {{action.targetGroupName}}\n </span>\n </div>\n </div>\n </div>\n </collapsible-section>\n <collapsible-section\n heading="{{ctrl.firewallsLabel}}"\n ng-if="ctrl.loadBalancer.loadBalancerType !== \'network\' || (ctrl.loadBalancer.loadBalancerType === \'network\' && ctrl.securityGroups && ctrl.securityGroups.length > 0)"\n >\n <ul>\n <li ng-repeat="securityGroup in ctrl.securityGroups | orderBy:\'name\'">\n <a\n ui-sref="^.firewallDetails({name:securityGroup.name, accountId: ctrl.loadBalancer.account, region: ctrl.loadBalancer.region, vpcId: ctrl.loadBalancer.vpcId, provider: ctrl.loadBalancer.provider})"\n >\n {{securityGroup.name}} ({{securityGroup.id}})\n </a>\n </li>\n </ul>\n </collapsible-section>\n <collapsible-section heading="Subnets">\n <div ng-if="ctrl.loadBalancer.subnetDetails.length === 0">\n <h5>No subnets</h5>\n </div>\n <div ng-repeat="subnet in ctrl.loadBalancer.subnetDetails" ng-class="{\'bottom-border\': !$last}">\n <h5><strong>{{subnet.id}}</strong></h5>\n <dl class="dl-horizontal dl-narrow">\n <dt>Purpose</dt>\n <dd>{{subnet.purpose}}</dd>\n\n <dt>State</dt>\n <dd>{{subnet.state}}</dd>\n\n <dt>Cidr Block</dt>\n <dd>{{subnet.cidrBlock}}</dd>\n </dl>\n </div>\n </collapsible-section>\n <collapsible-section ng-if="ctrl.loadBalancer.loadBalancerType === \'classic\'" heading="Health Checks">\n <dl class="horizontal-when-filters-collapsed">\n <dt>Target</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.target}}</dd>\n <dt>Timeout</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.timeout}} seconds</dd>\n <dt>Interval</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.interval}} seconds</dd>\n <dt>Healthy Threshold</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.healthyThreshold}}</dd>\n <dt>Unhealthy Threshold</dt>\n <dd>{{ctrl.loadBalancer.elb.healthCheck.unhealthyThreshold}}</dd>\n </dl>\n </collapsible-section>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/loadBalancer/details/targetGroupDetails.html",'<div class="details-panel">\n <div ng-if="ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n </div>\n\n <div ng-if="!ctrl.state.loading" class="header">\n <div class="close-button">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div class="header-text horizontal middle">\n <i class="fa fa-crosshairs icon" aria-hidden="true"></i>\n <h3 class="horizontal middle space-between flex-1" select-on-dbl-click>{{ctrl.targetGroup.name}}</h3>\n </div>\n </div>\n <managed-resource-details-indicator\n ng-if="!ctrl.state.loading && ctrl.loadBalancer.isManaged"\n resource-summary="ctrl.loadBalancer.managedResourceSummary"\n application="ctrl.application"\n >\n </managed-resource-details-indicator>\n <div ng-if="!ctrl.state.loading" class="content">\n <collapsible-section heading="Target Group Details" expanded="true">\n <dl class="dl-horizontal dl-narrow">\n <dt>In</dt>\n <dd><account-tag account="ctrl.targetGroup.account" pad="right"></account-tag> {{ctrl.targetGroup.region}}</dd>\n <dt>VPC</dt>\n <dd>\n <vpc-tag vpc-id="ctrl.targetGroup.vpcId"></vpc-tag>\n </dd>\n <dt>Protocol</dt>\n <dd>{{ctrl.targetGroup.protocol}}</dd>\n <dt>Port</dt>\n <dd>{{ctrl.targetGroup.port}}</dd>\n <dt>Target Type</dt>\n <dd>{{ctrl.targetGroup.targetType}}</dd>\n </dl>\n <dl ng-if="ctrl.loadBalancer" class="horizontal-when-filters-collapsed">\n <dt>Load Balancer</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li>\n <a\n ui-sref="^.loadBalancerDetails({ name: ctrl.loadBalancer.name,\n region: ctrl.loadBalancer.region,\n accountId: ctrl.loadBalancer.account,\n vpcId: ctrl.loadBalancer.vpcId,\n provider: \'aws\'})"\n >\n {{ctrl.loadBalancer.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n <dl class="horizontal-when-filters-collapsed">\n <dt ng-if="ctrl.loadBalancer.dnsname">Load Balancer DNS Name</dt>\n <dd ng-if="ctrl.loadBalancer.dnsname">\n <a target="_blank" href="{{ctrl.elbProtocol}}//{{ctrl.loadBalancer.dnsname}}"\n >{{ctrl.loadBalancer.dnsname}}</a\n >\n <copy-to-clipboard\n class="copy-to-clipboard copy-to-clipboard-sm"\n text="ctrl.loadBalancer.dnsname"\n tool-tip="\'Copy DNS Name to clipboard\'"\n >\n </copy-to-clipboard>\n </dd>\n </dl>\n <dl\n ng-if="ctrl.targetGroup.serverGroups && ctrl.targetGroup.serverGroups.length"\n class="horizontal-when-filters-collapsed"\n >\n <dt>Server Groups</dt>\n <dd>\n <ul class="collapse-margin-on-filter-collapse">\n <li ng-repeat="serverGroup in ctrl.targetGroup.serverGroups | orderBy: [\'isDisabled\', \'-name\']">\n <a\n ui-sref="^.serverGroup({region: serverGroup.region,\n accountId: serverGroup.account,\n serverGroup: serverGroup.name,\n provider: serverGroup.cloudProvider})"\n >\n {{serverGroup.name}}\n </a>\n </li>\n </ul>\n </dd>\n </dl>\n </collapsible-section>\n <collapsible-section heading="Status" expanded="true">\n <health-counts class="pull-left" container="ctrl.targetGroup.instanceCounts"></health-counts>\n </collapsible-section>\n <collapsible-section heading="Health Checks">\n <dl class="horizontal-when-filters-collapsed">\n <dt>Target</dt>\n <dd>\n {{ctrl.targetGroup.healthCheckProtocol}}:{{ctrl.targetGroup.healthCheckPort}}\n {{ctrl.targetGroup.healthCheckPath}}\n </dd>\n <dt>Timeout</dt>\n <dd>{{ctrl.targetGroup.healthCheckTimeoutSeconds}} seconds</dd>\n <dt>Interval</dt>\n <dd>{{ctrl.targetGroup.healthCheckIntervalSeconds}} seconds</dd>\n <dt>Healthy Threshold</dt>\n <dd>{{ctrl.targetGroup.healthyThresholdCount}}</dd>\n <dt>Unhealthy Threshold</dt>\n <dd>{{ctrl.targetGroup.unhealthyThresholdCount}}</dd>\n <dt>Matcher</dt>\n <dd>HTTP Code(s): {{ctrl.targetGroup.matcher.httpCode}}</dd>\n </dl>\n </collapsible-section>\n <collapsible-section heading="Attributes" expanded="true">\n <dl class="horizontal-when-filters-collapsed">\n <dt>Deregistration Delay Timeout</dt>\n <dd>{{ctrl.targetGroup.attributes[\'deregistration_delay.timeout_seconds\']}} seconds</dd>\n <dt>Stickiness Enabled</dt>\n <dd>{{ctrl.targetGroup.attributes[\'stickiness.enabled\']}}</dd>\n <dt ng-if-start="ctrl.targetGroup.attributes[\'stickiness.enabled\'] === \'true\'">\n Stickiness Load Balancer Cookie Duration\n </dt>\n <dd>{{ctrl.targetGroup.attributes[\'stickiness.lb_cookie.duration_seconds\']}} seconds</dd>\n <dt>Stickiness Type</dt>\n <dd ng-if-end>{{ctrl.targetGroup.attributes[\'stickiness.type\']}}</dd>\n <dt ng-if-start="ctrl.loadBalancer.loadBalancerType === \'network\'">Preserve Client IP</dt>\n <dd ng-if-end>{{ctrl.targetGroup.attributes[\'preserve_client_ip.enabled\']}}</dd>\n </dl>\n </collapsible-section>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/details/securityGroupDetail.html",'<div class="text-center" ng-if="state.notFound">\n <h3>Could not find <firewall-label label="firewall"></firewall-label> {{group}}.</h3>\n <a ui-sref="home.infrastructure">Back to search results</a>\n</div>\n<div class="details-panel" ng-if="!state.notFound">\n <div class="header">\n <div class="close-button" ng-if="!state.standalone">\n <a class="btn btn-link" ui-sref="^">\n <span class="glyphicon glyphicon-remove"></span>\n </a>\n </div>\n <div ng-if="state.loading" class="horizontal center middle">\n <loading-spinner size="\'small\'"></loading-spinner>\n </div>\n <div class="header-text horizontal middle" ng-if="!state.loading">\n <span class="glyphicon glyphicon-transfer"></span>\n <h3 class="horizontal middle space-between flex-1" select-on-dbl-click>\n {{securityGroup.name || \'(not found)\'}}\n <render-if-feature feature="entityTags">\n <entity-notifications\n entity="securityGroup"\n application="ctrl.application"\n placement="bottom"\n h-offset-percent="90%"\n entity-type="securityGroup"\n page-location="details"\n on-update="ctrl.application.securityGroups.refresh()"\n ></entity-notifications>\n </render-if-feature>\n </h3>\n </div>\n <div class="actions" ng-hide="isDisabled">\n <div class="dropdown" uib-dropdown dropdown-append-to-body>\n <button type="button" class="btn btn-sm btn-primary dropdown-toggle" ng-disabled="disabled" uib-dropdown-toggle>\n <firewall-label label="Firewall"></firewall-label> Actions <span class="caret"></span>\n </button>\n <ul class="dropdown-menu" uib-dropdown-menu role="menu">\n <li><a href ng-click="ctrl.editInboundRules()">Edit Inbound Rules</a></li>\n <li>\n <a href ng-click="ctrl.deleteSecurityGroup()">Delete <firewall-label label="Firewall"></firewall-label></a>\n </li>\n <li>\n <a href ng-click="ctrl.cloneSecurityGroup()">Clone <firewall-label label="Firewall"></firewall-label></a>\n </li>\n <render-if-feature feature="entityTags">\n <add-entity-tag-links\n component="securityGroup"\n application="ctrl.application"\n entity-type="securityGroup"\n on-update="ctrl.application.securityGroups.refresh"\n ></add-entity-tag-links>\n </render-if-feature>\n </ul>\n </div>\n </div>\n </div>\n <managed-resource-details-indicator\n ng-if="!state.loading && securityGroup.isManaged"\n resource-summary="securityGroup.managedResourceSummary"\n application="ctrl.application"\n >\n </managed-resource-details-indicator>\n <div class="content" ng-if="!state.loading">\n <collapsible-section heading="{{ctrl.firewallLabel}} Details" expanded="true">\n <dl class="dl-horizontal dl-medium">\n <dt>ID</dt>\n <dd>{{securityGroup.id}}</dd>\n <dt>Account</dt>\n <dd>\n <account-tag account="securityGroup.accountName"></account-tag>\n </dd>\n <dt>Region</dt>\n <dd>{{securityGroup.region}}</dd>\n <dt>VPC</dt>\n <dd>\n <vpc-tag vpc-id="securityGroup.vpcId"></vpc-tag>\n </dd>\n <dt>Description</dt>\n <dd>{{securityGroup.description}}</dd>\n </dl>\n </collapsible-section>\n <ip-range-rules ip-rules="ipRules"></ip-range-rules>\n <collapsible-section\n heading="{{ctrl.firewallLabel}} Rules ({{securityGroupRules.length || 0}})"\n expanded="{{securityGroupRules.length > 0}}"\n >\n <div ng-if="!securityGroupRules.length">None</div>\n\n <dl\n ng-class="insightCtrl.vm.filtersExpanded ? \'\' : \'dl-horizontal dl-medium\'"\n ng-repeat="rule in securityGroupRules | orderBy: \'securityGroup.name\' "\n >\n <dt>\n <firewall-label label="Firewall"></firewall-label>\n </dt>\n <dd ng-if="rule.securityGroup.name">\n <a\n ui-sref="^.firewallDetails({name: rule.securityGroup.name, accountId: rule.securityGroup.accountName, region: rule.securityGroup.region, vpcId: rule.securityGroup.vpcId, provider: \'aws\'})"\n >\n <account-tag\n account="rule.securityGroup.accountName || rule.securityGroup.accountId"\n ng-if="rule.securityGroup.accountName !== securityGroup.accountName"\n ></account-tag>\n {{rule.securityGroup.name}} ({{rule.securityGroup.id}})\n </a>\n </dd>\n <dt>Port Ranges</dt>\n <dd ng-repeat="portRange in rule.rules">\n {{portRange.protocol}}: {{portRange.startPort}} → {{portRange.endPort}}\n </dd>\n </dl>\n </collapsible-section>\n </div>\n</div>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/securityGroup/configure/createSecurityGroup.html",'<ng-form role="form" name="form" novalidate>\n <v2-modal-wizard heading="Create New {{ctrl.translate(\'Firewall\')}}" task-monitor="taskMonitor" dismiss="$dismiss()">\n <v2-wizard-page key="Location" label="Location">\n <ng-include src="pages.location"></ng-include>\n </v2-wizard-page>\n <v2-wizard-page key="Ingress" label="Ingress" done="true">\n <ng-include src="pages.ingress"></ng-include>\n </v2-wizard-page>\n </v2-modal-wizard>\n <div class="modal-footer">\n <button class="btn btn-default" ng-click="ctrl.cancel()">Cancel</button>\n <submit-button\n is-disabled="form.$invalid || !wizard.isComplete() || state.submitting || !customComponentIsvalid"\n submitting="state.submitting"\n on-click="ctrl.upsert()"\n is-new="state.isNew"\n ></submit-button>\n </div>\n</ng-form>\n')}]),window.angular.module("ng").run(["$templateCache",function(e){e.put("amazon/src/applicationProviderFields/awsFields.html",'<div class="form-group row">\n <div class="col-sm-3 sm-label-right">AWS Settings</div>\n <div class="col-sm-9 checkbox" style="margin-bottom: 0; margin-top: 5px">\n <label>\n <input\n type="checkbox"\n ng-init="$ctrl.initializeApplicationField(\'aws.useAmiBlockDeviceMappings\')"\n ng-model="$ctrl.application.providerSettings.aws.useAmiBlockDeviceMappings"\n />\n Prefer AMI Block Device Mappings\n </label>\n </div>\n</div>\n')}]);export{wc as AMAZON_MODULE,kn as AWSProviderSettings,oc as AWS_SERVER_GROUP_CONFIGURATION_SERVICE,Vo as AdvancedSettingsDetailsSection,Ao as AlarmConfigurer,Ho as AmazonCapacityDetailsSection,Zr as AmazonCertificateReader,Or as AmazonCertificateSelectField,Qn as AmazonFunctionDetails,yl as AmazonImageSelectInput,Uo as AmazonInfoDetailsSection,br as AmazonInstanceWriter,Si as AmazonLoadBalancerChoiceModal,Pr as AmazonLoadBalancerClusterContainer,Dr as AmazonLoadBalancerDataUtils,Fr as AmazonLoadBalancersTag,io as AmazonResizeServerGroupModal,Do as AmazonUpsertScalingPolicyModal,So as AmazonUpsertTargetTrackingModal,xn as AwsFunctionTransformer,Mr as AwsLoadBalancerTransformer,no as AwsModalFooter,Yn as AwsReactInject,Xn as AwsReactInjector,lc as AwsServerGroupConfigurationService,Io as COMPARATORS,_n as CreateLambdaFunction,Bo as CreateScalingPolicyButton,po as DateLineChart,vo as DimensionsEditor,Kn as FunctionActions,On as FunctionBasicInformation,Wo as HealthDetailsSection,ul as IPRangeRules,Sr as InstanceDns,hr as InstanceInformation,Tr as InstanceStatus,jo as InstancesDistributionDetailsSection,sc as KeyPairsReader,_o as LaunchConfigDetailsSection,Yo as LaunchTemplateDetailsSection,wi as LoadBalancerTypes,Xo as LogsDetailsSection,mo as MetricAlarmChart,bo as MetricSelector,Jo as PackageDetailsSection,ko as PolicyTypeSelectionModal,ec as ScalingPoliciesDetailsSection,No as ScalingPolicyAdditionalSettings,Oo as ScalingPolicySummary,zo as ScalingPolicyWriter,tc as ScalingProcessesDetailsSection,nc as ScheduledActionsDetailsSection,_l as SecurityGroupSelector,rc as SecurityGroupsDetailsSection,eo as ServerGroupAdvancedSettings,Xl as ServerGroupAdvancedSettingsCommon,El as ServerGroupBasicSettings,Sl as ServerGroupCapacity,Hl as ServerGroupInstanceType,Zl as ServerGroupLoadBalancers,Yl as ServerGroupSecurityGroups,Kl as ServerGroupSecurityGroupsRemoved,Wl as ServerGroupZones,Po as StepPolicyAction,Lo as StepPolicySummary,si as SubnetSelectField,ii as SubnetSelectInput,ic as TagsDetailsSection,xr as TargetGroup,Lr as TargetGroupDetails,Eo as TargetMetricFields,wo as TargetTrackingAdditionalSettings,fo as TargetTrackingChart,Ro as TargetTrackingSummary,Wn as VpcReader,wr as applyHealthCheckInfoToTargetGroups,Er as getAllTargetGroups,Zo as getBaseImageName};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|