@spinnaker/amazon 0.14.4 → 0.14.5

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 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 p,NumberInput as u,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 G,AccountTag as I,Overrides as A,CollapsibleSection as x,HelpContentsRegistry as P,REST as z,LabeledValue as D,timestamp as B,useData as F,SubnetTag as M,withErrorBoundary as L,InstanceWriter as R,TaskExecutor as O,CloudProviderRegistry as U,FirewallLabels as V,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 pe,ValidationMessage as ue,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 Ge,SECURITY_GROUP_READER as Ie,LOAD_BALANCER_READ_SERVICE as Ae,MANAGED_RESOURCE_DETAILS_INDICATOR as xe,APPLICATION_STATE_PROVIDER as Pe,Registry as ze,BakeExecutionLabel as De,AuthenticationService as Be,PipelineTemplates as Fe,BakeryReader as Me,StageConstants as $e,AppListExtractor as Le,ExecutionDetailsSection as Re,StageFailureMessage as Oe,ExecutionDetailsTasks as Ue,FormikStageConfig as Ve,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 pt,ServerGroupNamePreview as ut,TaskReason as mt,ToggleButtonGroup as gt,ToggleSize as ht,usePrevious as ft,NgReact as vt,PlatformHealthOverride as yt,MapEditor as bt,UserVerification as Et,TaskMonitorWrapper as wt,MinMaxDesiredChanges as Ct,ServerGroupWarningMessageService as St,ModalInjector as kt,ClusterTargetBuilder as Nt,ServerGroupReader as Tt,CloudMetricsReader as Gt,TaskMonitorModal as It,EntitySource as At,ViewChangesLink as xt,CapacityDetailsSection as Pt,ViewScalingActivitiesLink as zt,ShowUserData as Dt,SERVER_GROUP_COMMAND_REGISTRY_PROVIDER as Bt,setMatchingResourceSummary as Ft,INSTANCE_TYPE_SERVICE as Mt,SERVER_GROUP_WRITER as $t,ApplicationNameValidator as Lt}from"@spinnaker/core";import*as Rt from"react";import Ot,{useState as Ut,useEffect as Vt}from"react";import qt,{isEmpty as Ht,forOwn as Wt,uniqBy as jt,cloneDeep as Zt,flatten as _t,isNil as Kt,orderBy as Yt,isEqual as Xt,sortBy as Jt,filter as Qt,chain as ea,map as ta,pickBy as aa,groupBy as na,get as ra,uniq as ia,difference as sa,some as la,isNumber as oa,set as ca,partition as da,every as pa,values as ua,head as ma,extend as ga,isString as ha,intersection as fa,keyBy as va,find as ya,flatMap as ba,has as Ea,clone as wa,keys as Ca,xor as Sa}from"lodash";import ka from"classnames";import{Subject as Na,from as Ta,combineLatest as Ga,BehaviorSubject as Ia,of as Aa,Observable as xa}from"rxjs";import{map as Pa,distinctUntilChanged as za,shareReplay as Da,switchMap as Ba,withLatestFrom as Fa,takeUntil as Ma,tap as $a,mergeMap as La,catchError as Ra,debounceTime as Oa,take as Ua}from"rxjs/operators";import{Dropdown as Va,Modal as qa,Button as Ha,Tooltip as Wa,OverlayTrigger as ja,Checkbox as Za,ModalFooter as _a,MenuItem as Ka}from"react-bootstrap";import{$q as Ya}from"ngimport";import{react2angular as Xa}from"react2angular";import{UISref as Ja,UISrefActive as Qa}from"@uirouter/react";import{UIRouterContextComponent as en}from"@uirouter/react-hybrid";import tn from"@uirouter/angularjs";import an from"angular-ui-bootstrap";import nn from"react-select";import{SortableHandle as rn,arrayMove as sn,SortableElement as ln,SortableContainer as on}from"react-sortable-hoc";import{Form as cn,Field as dn}from"formik";import pn from"react-virtualized-select";import{Chart as un,LineController as mn,LineElement as gn,PointElement as hn,LinearScale as fn,Title as vn,TimeScale as yn,Tooltip as bn,Legend as En,Filler as wn}from"chart.js";import"chartjs-adapter-luxon";var Cn;const Sn=a.providers.aws||{defaults:{}};Sn&&(Sn.adHocInfraWritesEnabled=null==(Cn=Sn.adHocInfraWritesEnabled)||Cn,Sn.resetToOriginal=a.resetProvider("aws"));const kn={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:()=>{}};t("spinnaker.amazon.footer",[]).component("awsFooter",kn);t("spinnaker.amazon.common",["spinnaker.amazon.footer"]);class Nn extends Ot.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 Ot.createElement("div",{className:"form-group",style:{marginTop:"20px"}},Ot.createElement("div",{className:"well-compact alert alert-warning"},Ot.createElement("strong",null,"Note:")," a rolling push only updates the"," ",Ot.createElement("em",null,"launch ",Boolean(null==(e=Sn.serverGroups)?void 0:e.enableLaunchTemplates)?"template":"configuration")," ","for the auto scaling group.",Ot.createElement("br",null)," Changes to the following fields will be ignored:",Ot.createElement("ul",null,Ot.createElement("li",null,"Account, Region, Subnet Type"),Ot.createElement("li",null,"Capacity"),Ot.createElement("li",null,"Load Balancers"),Ot.createElement("li",null,"Health Check Configuration"),Ot.createElement("li",null,"Termination Policies, Enable Traffic flag"))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:t.termination.relaunchAllInstances,onChange:e=>this.handleChange("relaunchAllInstances",e.target.checked)}),Ot.createElement("b",null,"Relaunch all instances"),Ot.createElement(n,{id:"strategy.rollingPush.relaunchAll"})))),!t.termination.relaunchAllInstances&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},"Total relaunches",Ot.createElement(n,{id:"strategy.rollingPush.totalRelaunches"})),Ot.createElement("div",{className:"col-md-2"},Ot.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)&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},"Concurrent relaunches",Ot.createElement(n,{id:"strategy.rollingPush.concurrentRelaunches"})),Ot.createElement("div",{className:"col-md-2"},Ot.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)&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},"Order",Ot.createElement(n,{id:"strategy.rollingPush.order"})),Ot.createElement("div",{className:"col-md-3"},Ot.createElement("select",{className:"input input-sm",style:{width:"100px"},value:t.termination.order,onChange:e=>this.handleChange("order",e.target.value)},Ot.createElement("option",{value:"oldest"},"oldest first"),Ot.createElement("option",{value:"newest"},"newest first")))))}}var Tn;r.registerStrategy({label:"Rolling Push (not recommended)",description:`Updates the launch ${(null==(Tn=Sn.serverGroups)?void 0:Tn.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:Nn,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 Gn{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:Ht(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||Sn.defaults.account,cloudProvider:"aws",detail:"",region:e.defaultRegions.aws||Sn.defaults.region,envVariables:{},tracingConfig:{mode:"PassThrough"},kmskeyArn:"",vpcId:"",subnetIds:[],securityGroupIds:[],timeout:3,deadLetterConfig:{targetArn:""},operation:"",targetGroups:""}}}const In=(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+=,.@-_/]+`,An=(e,t)=>e.match(/^[0-9A-Za-z.-]*[^.]$/)?void 0:`Invalid S3 Bucket name. ${t} must match regular expression: [0-9A-Za-z.-]*[^.]$`,xn=(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.-]+:./`,Pn=(e,t)=>Ht(e)?`At least one ${t} is required`:void 0,zn=(e,t)=>e.match(/^[0-9A-Za-z]*$/)?void 0:`Invalid String Value. ${t} must match regular expression: [0-9A-Za-z]`;class Dn extends Ot.Component{constructor(e){super(e)}validate(e){const t=new i(e);return t.field("role","Role ARN").required().withValidators(In),t.validateForm()}render(){return Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-11"},Ot.createElement("div",{className:"sp-margin-m-bottom"},Ot.createElement(s,{name:"role",label:"Role ARN",input:e=>Ot.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"}),required:!0}))))}}const Bn=["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"],Fn="(Optional) Stack is naming components of a function, used to create vertical stacks of dependent services for integration testing.",Mn="(Optional) Detail is a string of free-form alphanumeric characters to describe any other variables in naming a function.";class $n extends Ot.Component{constructor(){super(...arguments),this.state={accounts:[],existingFunctionNames:[],regions:[]},this.props$=new Na,this.destroy$=new Na}validate(e){const t=new i(e);t.field("s3bucket","S3 Bucket Name").optional().withValidators(An);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(Pa((e=>e.formik.values))),t={account$:e.pipe(Pa((e=>e.credentials)),za()),region$:e.pipe(Pa((e=>e.region)),za()),functionName$:e.pipe(Pa((e=>e.functionName)),za()),runtime$:e.pipe(Pa((e=>e.runtime)),za()),s3bucket$:e.pipe(Pa((e=>e.s3bucket)),za()),s3key$:e.pipe(Pa((e=>e.s3key)),za()),handler$:e.pipe(Pa((e=>e.handler)),za())},a=Ta(o.listAccounts("aws")).pipe(Da(1)),n=Ga([t.account$,a]).pipe(Ba((([e,t])=>o.getRegionsForAccount(e))),Da(1)),r=this.props.app.getDataSource("functions").data$,i=Ga([r,t.account$,t.region$]).pipe(Pa((([e,t,a])=>e.filter((e=>e.account===t&&e.region===a)).map((e=>e.functionName)))),Da(1));n.pipe(Fa(t.region$),Ma(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(Ma(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=ka({well:!0,"alert-danger":!!t.functionName,"alert-info":!t.functionName});return Ot.createElement("div",{className:"container-fluid form-horizontal "},e&&Ot.createElement("div",{className:o},Ot.createElement("strong",null,"Your function will be named: "),Ot.createElement(n,{id:"aws.function.name"}),Ot.createElement("span",null,this.props.app.name,"-",a.functionName),Ot.createElement(s,{name:"functionName",input:()=>null})),Ot.createElement(s,{name:"credentials",label:"Account",input:e=>Ot.createElement(c,{...e,stringOptions:r.map((e=>e.name)),clearable:!0})}),Ot.createElement(s,{name:"region",label:"Region",input:e=>Ot.createElement(c,{...e,stringOptions:i.map((e=>e.name)),clearable:!0})}),Ot.createElement(s,{name:"functionName",label:"Function Name",help:Ot.createElement(n,{id:"aws.function.name"}),input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"runtime",label:"Runtime",help:Ot.createElement(n,{id:"aws.function.runtime"}),input:e=>Ot.createElement(c,{...e,stringOptions:Bn,clearable:!0})}),Ot.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Ot.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Ot.createElement(l,{...e,placeholder:"S3 bucket name"})}),Ot.createElement(s,{name:"s3key",label:"S3 Key",help:Ot.createElement(n,{id:"aws.function.s3key"}),input:e=>Ot.createElement(l,{...e,placeholder:"object.zip"})}),Ot.createElement(s,{name:"handler",label:"Handler",help:Ot.createElement(n,{id:"aws.function.handler"}),input:e=>Ot.createElement(l,{...e,placeholder:"filename.method"})}),Ot.createElement(s,{name:"publish",label:"Publish",input:e=>Ot.createElement(d,{...e})}))}}class Ln extends Ot.Component{constructor(e){super(e),this.validate=e=>{const t=new i(e);return t.field("deadLetterConfig.targetArn","Target ARN").optional().withValidators(xn),t.validateForm()}}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},"Dead Letter Config",Ot.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Ot.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Ot.createElement(l,{...e})}),"X-Ray Tracing",Ot.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Ot.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Ot.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}}class Rn extends Ot.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("kmskeyArn","KMS Key ARN").optional().withValidators(xn),t.validateForm()}}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},Ot.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Ot.createElement(p,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Ot.createElement(s,{name:"kmskeyArn",label:"Key ARN",help:Ot.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Ot.createElement(l,{...e})}))}}class On extends Ot.Component{constructor(){super(...arguments),this.validate=()=>({})}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},Ot.createElement(s,{name:"description",label:"Description",input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Ot.createElement(u,{...e,min:128,max:3008})}),Ot.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Ot.createElement(u,{...e,min:1,max:900})}),Ot.createElement(s,{name:"targetGroups",label:"Target Group Name",input:e=>Ot.createElement(l,{...e})}))}}class Un extends Ot.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("tags","Tag").required().withValidators(Pn),t.validateForm()}}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},Ot.createElement(s,{name:"tags",input:e=>Ot.createElement(p,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}))}}class Vn{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 qn extends Ot.Component{constructor(e){super(e),this.state={vpcOptions:[],accounts:null,regions:[],subnets:[],availableSubnets:[],securityGroups:null},this.props$=new Na,this.destroy$=new Na,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 Wt(e,(function(e,n){n===t.credentials&&Wt(e,(function(e,n){"aws"===n&&Wt(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(){Ta(Vn.listVpcs()).pipe(Ma(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 jt(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(Ma(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 Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-11"},Ot.createElement("div",{className:"sp-margin-m-bottom"},a.credentials&&Ot.createElement(s,{name:"vpcId",label:"VPC Id",help:Ot.createElement(n,{id:"aws.function.vpc.id"}),input:t=>Ot.createElement(c,{...t,stringOptions:e.filter((e=>e.account===a.credentials)).map((e=>e.id)),clearable:!0}),onChange:this.setVpc,required:!1})),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Subnets "),Ot.createElement(n,{id:"aws.function.subnet"})),Ot.createElement("div",{className:"col-md-7"},0===r.length&&Ot.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC"),a.vpcId?Ot.createElement(f,{multi:!0,options:r,value:a.subnetIds,onChange:this.handleSubnetUpdate}):null)),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Security Groups "),Ot.createElement(n,{id:"aws.function.subnet"})),Ot.createElement("div",{className:"col-md-7"},0===i.length&&Ot.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC"),a.credentials&&a.vpcId?Ot.createElement(f,{multi:!0,options:i,value:a.securityGroupIds,onChange:this.handleSecurityGroupsUpdate}):null))))}}const Hn=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.submit=e=>{const{app:t}=this.props,{isNew:a}=this.state,n=Zt(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 Gn,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(Hn,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}`),Ot.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})=>Ot.createElement(Ot.Fragment,null,Ot.createElement(w,{label:"Basic information",wizard:i,order:a(),render:({innerRef:a})=>Ot.createElement($n,{ref:a,app:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Execution Role",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(Dn,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Environment",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(Rn,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Tags",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(Un,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Settings",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(On,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Network",wizard:i,order:a(),render:({innerRef:a})=>Ot.createElement(qn,{ref:a,app:e,formik:t,isNew:r})}),Ot.createElement(w,{label:"Debugging and Error Handling",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(Ln,{ref:e,formik:t,isNew:r,functionDef:n})}))})}};let Wn=Hn;Wn.defaultProps={closeModal:C,dismissModal:C};class jn extends Ot.Component{constructor(e){super(e),this.editFunction=()=>{const{functionDef:e}=this.props,{application:t}=this.state;Wn.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 Ot.createElement("div",{style:{display:"inline-block"}},Sn.adHocInfraWritesEnabled&&Ot.createElement(Va,{className:"dropdown",id:"function-actions-dropdown"},Ot.createElement(Va.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Ot.createElement("span",null,"Function Actions")),Ot.createElement(Va.Menu,{className:"dropdown-menu"},Ot.createElement("li",{className:n?"":"disabled"},Ot.createElement("a",{className:"clickable",onClick:this.editFunction},"Edit Function")),t.functionName&&Ot.createElement("li",null,Ot.createElement("a",{className:"clickable",onClick:this.deleteFunction},"Delete Function")),a&&a.feature.entityTags&&Ot.createElement(N,{component:t,application:e,entityType:"function",onUpdate:this.entityTagUpdate}))))}}class Zn 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 _n=new Zn;var Kn=Object.defineProperty,Yn=Object.getOwnPropertyDescriptor;let Xn=class extends Ot.Component{constructor(e){super(e),this.destroy$=new Na,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))?Ta(_n.functionReader.getFunctionDetails("aws",t.account,t.region,t.functionName)).pipe(Ma(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;Ta(t.ready()).pipe(Ma(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 Ot.createElement(G,{loading:t});const n=Ot.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Last Modified "),Ot.createElement("dd",null,a.lastModified),Ot.createElement("dt",null,"In"),Ot.createElement("dd",null,Ot.createElement(I,{account:a.account})," ",a.region),Ot.createElement("dt",null,"VPC"),Ot.createElement("dd",null,a.vpcConfig?a.vpcConfig.vpcId:"Default"),Ot.createElement("dt",null,"Function ARN"),Ot.createElement("dd",null,a.functionArn),Ot.createElement("dt",null,"Revision ID"),Ot.createElement("dd",null,a.revisionId),Ot.createElement("dt",null,"Version"),Ot.createElement("dd",null,a.version)),r=Ot.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.eventSourceMappings&&0!==a.eventSourceMappings.length?a.eventSourceMappings.map((e=>Ot.createElement(Ot.Fragment,null,Ot.createElement("h5",null,Ot.createElement("strong",null,"Event Source")),Ot.createElement("dl",null,Ot.createElement("dt",null,"ARN"),Ot.createElement("dd",null,e.eventSourceArn),Ot.createElement("dt",null,"State"),Ot.createElement("dd",null,e.state))))):"None"),i=Ot.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.aliasConfigurations&&0!==a.aliasConfigurations.length?a.aliasConfigurations.map((e=>Ot.createElement(Ot.Fragment,null,Ot.createElement("h5",null,Ot.createElement("strong",null,"Alias Details")),Ot.createElement("dl",null,Ot.createElement("dt",null,"Name"),Ot.createElement("dd",null,e.name),Ot.createElement("dt",null,"ARN"),Ot.createElement("dd",null,e.aliasArn))))):"None"),s=Ot.createElement(x,{heading:"Function Details"},n),l=Ot.createElement(x,{heading:"Event Source Details"},r),o=Ot.createElement(x,{heading:"Alias Configuration Details"},i);return Ot.createElement(G,{loading:this.state.loading},Ht(this.state.functionDef)?"Function not found.":Ot.createElement(G.Header,{icon:Ot.createElement("i",{className:"fa fa-xs fa-fw fa-asterisk"}),name:this.state.functionDef.functionName},Ot.createElement("div",{className:"actions"},Ot.createElement(jn,{app:e,functionDef:a,functionFromParams:{account:this.state.functionDef.account,region:this.state.functionDef.region,functionName:this.state.functionDef.functionName}}))),Ht(this.state.functionDef)?"":s,Ht(this.state.functionDef)||Ht(this.state.functionDef.eventSourceMappings)?"":l,Ht(this.state.functionDef)||Ht(this.state.functionDef.aliasConfigurations)?"":o)}};Xn=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Yn(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&&Kn(t,a,i),i})([A("function.details","aws")],Xn);t("spinnaker.amazon.function",[]);const Jn={"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;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(Jn).forEach((e=>P.register(e,Jn[e])));class Qn{findImages(e){return!e.q||e.q.length<3?Ya.when([{message:"Please enter at least 3 characters...",disabled:!0}]):z("/images/find").query(e).get().catch((()=>[]))}getImage(e,t,a){return z("/images").path(a,t,e).query({provider:"aws"}).get().then((e=>e&&e.length?e[0]:null)).catch((()=>null))}}var er,tr,ar,nr,rr,ir;const sr={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}]},lr=[{type:"general",label:"General Purpose",families:[sr,{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:[sr.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"}],or=null!=(ar=null==(tr=null==(er=Sn.instanceTypes)?void 0:er.exclude)?void 0:tr.categories)?ar:[],cr=null!=(ir=null==(rr=null==(nr=Sn.instanceTypes)?void 0:nr.exclude)?void 0:rr.families)?ir:[],dr=lr.filter((({type:e})=>!or.includes(e))).map((e=>Object.assign({},e,{families:e.families.filter((({type:e})=>!cr.includes(e)))})));t("spinnaker.amazon.instanceType.service",[]).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(dr)},getAvailableTypesForRegions:function(e,a){let n=[];return(a=a||[])&&a.length&&(n=e[a[0]]||[]),a.forEach((function(t){e[t]&&(n=qt.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 z("/instanceTypes").get().then((function(e){return qt.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 qt.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=qt.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=qt.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=qt.flatten(null==(a=qt.find(lr,{type:t}))?void 0:a.families.map((e=>e.instanceTypes.map((e=>e.name)))));return qt.intersection(e,n)}}}]);const pr=({account:e,availabilityZone:t,instanceType:a,capacityType:n,launchTime:r,provider:i,region:s,serverGroup:l,showInstanceType:o})=>Ot.createElement(Ot.Fragment,null,Ot.createElement(D,{label:"Launched",value:r?B(r):"Unknown"}),Ot.createElement(D,{label:"In",value:Ot.createElement("div",null,Ot.createElement(I,{account:e}),t||"Unknown")}),o&&Ot.createElement(D,{label:"Type",value:a||"Unknown"}),o&&n&&Ot.createElement(D,{label:"Capacity Type",value:n||"Unknown"}),l&&Ot.createElement(D,{label:"Server Group",value:Ot.createElement("div",null,Ot.createElement(en,null,Ot.createElement(Ja,{to:"^.serverGroup",params:{region:s,accountId:e,serverGroup:l,provider:i}},Ot.createElement("a",null,l))))}));function ur(e){const{vpcId:t}=e,a=F((async()=>{const t=await Vn.getVpcName(e.vpcId);return t?`${t} (${e.vpcId})`:`(${e.vpcId})`}),"None (EC2 Classic)",[t]),n=t?a.result:"None (EC2 Classic)";return Ot.createElement("span",{className:"vpc-tag"},n)}t("spinnaker.application.amazonInstanceInformation.component",[]).component("amazonInstanceInformation",Xa(L((({instance:e})=>{const{imageId:t,serverGroup:a,subnetId:n,vpcId:r}=e;return Ot.createElement(x,{heading:"Instance Information",defaultExpanded:!0},Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement(pr,{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&&Ot.createElement(D,{label:"VPC",value:Ot.createElement(ur,{vpcId:r})}),n&&Ot.createElement(D,{label:"Subnet",value:Ot.createElement(M,{subnetId:n})}),t&&Ot.createElement(D,{label:"Image ID",value:t})))}),"amazonInstanceInformation"),["instance"]));class mr 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 gr=e=>{const t=e.map((e=>e.targetGroups));return _t(t)},hr=(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||Kt(s.healthCheckPort)?s.port:s.healthCheckPort;e.healthCheckProtocol=null==(r=s.healthCheckProtocol)?void 0:r.toLowerCase(),e.healthCheckPath=`:${l}${null!=(i=s.healthCheckPath)?i:""}`}))}))};t("spinnaker.amazon.instance.details.controller",[tn,an]).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,p,u,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,p=e.region,u=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,p=e.region,u=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,p=e.region,u=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,p=e.region,u=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,p=e.region,u=e.vpcId,!0}))}))}))})))):(a={id:n.instanceId},i=[],s=[],c=n.account,p=n.region),a&&c&&p?(a.account=c,t.account=c,t.region=p,q.addExtraDataToLatest("instances",t),H.getInstanceDetails(c,p,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=gr(r.loadBalancers.data.filter((function(e){return"aws"===e.cloudProvider})));hr(n,e,t.account)}a.health&&n.forEach((function(e){const t=a.health.filter((function(t){return t.type===e.type}));t.length&&qt.defaults(e,t[0])})),e.healthMetrics=n}(a,t),e.instance=qt.defaults(t,a),e.instance.account=c,e.instance.region=p,e.instance.vpcId=u,e.instance.serverGroupDisabled=m,e.instance.loadBalancers=i,e.instance.targetGroups=s,e.instance.networkInterfaces){e.instance.ipv6Addresses=qt.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=!Sn.adHocInfraWritesEnabled,e.detailsTemplateUrl=U.getValue("aws","instance.detailsTemplateUrl"),e.state={loading:!0,standalone:r.isStandalone,instancePort:qt.get(r,"attributes.instancePort")||a.defaultInstancePort||80},e.application=r,e.moniker=i,e.environment=s,e.securityGroupsLabel=V.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 mr.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 mr.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"]),mr.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 mr.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 mr.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 mr.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 mr.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 mr.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 mr.disableInstanceInDiscovery(t,r)}})},this.hasHealthState=function(t,a){return(e.instance.health||[]).some((function(e){return e.type===t&&e.state===a}))};const p=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=p(e.instance),e.$$destroyed||r.isStandalone||r.serverGroups.onRefresh(e,c)})),e.account=n.account}]);const fr=({instancePort:e,ipv6Addresses:t,permanentIps:a,privateDnsName:n,privateIpAddress:r,publicDnsName:i,publicIpAddress:s})=>{const l=e?`:${e}`:"";return Rt.createElement(W,{className:"horizontal-when-filters-collapsed"},n&&Rt.createElement(D,{label:"Private DNS Name",value:Rt.createElement(j,{text:n,url:`http://${n}${l}`})}),i&&Rt.createElement(D,{label:"Public DNS Name",value:Rt.createElement(j,{text:i,url:`http://${i}${l}`})}),r&&Rt.createElement(D,{label:"Private IP Address",value:Rt.createElement(j,{text:r,url:`http://${r}${l}`})}),Boolean(null==a?void 0:a.length)&&Rt.createElement(D,{label:"Permanent IP Address",value:a.map((e=>Rt.createElement(j,{key:e,text:e,url:`http://${e}${l}`})))}),s&&Rt.createElement(D,{label:"Public IP Address",value:Rt.createElement(j,{text:s,url:`http://${s}${l}`})}),Boolean(null==t?void 0:t.length)&&Rt.createElement(D,{label:"IPv6 Address"+(t.length>1?"es":""),value:t.map((e=>Rt.createElement(j,{key:e.ip,text:e.ip,url:e.url})))}))};t("spinnaker.application.instanceDns.component",[]).component("instanceDns",Xa(L(fr,"instanceDns"),["instancePort","ipv6Addresses","permanentIps","privateDnsName","privateIpAddress","publicDnsName","publicIpAddress"]));t("spinnaker.application.instanceSecurityGroups.component",[]).component("instanceSecurityGroups",Xa(L((({instance:e})=>{const{account:t,region:a,provider:n,securityGroups:r,vpcId:i}=e,s=Yt(r,["groupName"],["asc"]),l=V.get("Firewalls");return Ot.createElement(x,{heading:l,defaultExpanded:!0},Ot.createElement(en,null,Ot.createElement("ul",null,(s||[]).map((e=>Ot.createElement("li",{key:e.groupId},Ot.createElement(Ja,{to:"^.firewallDetails",params:{name:e.groupName,accountId:t,region:a,vpcId:i,provider:n}},Ot.createElement("a",null,e.groupName," (",e.groupId,")"))))))))}),"instanceSecurityGroups"),["instance"]));const vr=({healthMetrics:e,healthState:t,metricTypes:a,customHealthUrl:n,privateIpAddress:r})=>{const i=a.includes("LoadBalancer"),s=a.includes("TargetGroup");return Ot.createElement(x,{heading:"Status",defaultExpanded:!0},!e.length&&Ot.createElement("p",null,"Starting"===t?"Starting":"No health metrics found for this instance"),Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},e.sort(((e,t)=>e.type<t.type?-1:e.type>t.type?1:0)).map((e=>Ot.createElement(Ot.Fragment,{key:`${e.type}-${e.description}`},Ot.createElement("dt",null,Z(e.type)),Ot.createElement("dd",null,!a.includes(e.type)&&Ot.createElement("div",null,Ot.createElement(_,{value:"down"===e.state.toLowerCase()?e.description:"",placement:"left"},Ot.createElement("span",null,Ot.createElement("span",{className:`glyphicon glyphicon-${e.state}-triangle`}),Ot.createElement("span",null,Z(e.state)))),Ot.createElement("span",{className:"pad-left small"},e.healthCheckUrl&&Ot.createElement("a",{target:"_blank",href:e.healthCheckUrl},"Health Check"),e.healthCheckUrl&&e.statusPageUrl&&Ot.createElement("span",null," | "),e.statusPageUrl&&Ot.createElement("a",{target:"_blank",href:e.statusPageUrl},"Status"),n&&e.type===n.type&&Ot.createElement("span",null," ","|"," ",Ot.createElement("a",{target:"_blank",href:n.href},n.text)))),i&&"LoadBalancer"===e.type&&(e.loadBalancers||[]).map((e=>Ot.createElement(K,{key:`lb-${e.name}`,loadBalancer:e}))),s&&"TargetGroup"===e.type&&(e.targetGroups||[]).map((e=>Ot.createElement(K,{key:`tg-${e.name}`,loadBalancer:e,ipAddress:r})))))))))};t("spinnaker.application.instanceStatus.component",[]).component("instanceStatus",Xa(L(vr,"instanceStatus"),["healthMetrics","healthState","metricTypes","customHealthUrl","privateIpAddress"]));function yr(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("spinnaker.application.instanceTags.component",[]).component("instanceTags",Xa(L((({tags:e})=>{const t=Yt(e,["key"],["asc"]);return Ot.createElement(x,{heading:"Tags",defaultExpanded:!0},!e.length&&Ot.createElement("div",null,"No tags associated with this server"),e.length&&t.map((e=>Ot.createElement(D,{key:e.key,label:e.key,value:e.value}))))}),"instanceTags"),["tags"]));yr(".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 br extends Ot.Component{render(){const{targetGroup:e,showInstances:t,showServerGroups:a,loadBalancer:n}=this.props,r=Yt(e.serverGroups,["isDisabled","name"],["asc","desc"]).map((e=>Ot.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 Ot.createElement("div",{className:"target-group-container container-fluid no-padding"},Ot.createElement(Qa,{class:"active"},Ot.createElement(Ja,{to:".targetGroupDetails",params:i},Ot.createElement("div",{className:"clickable clickable-row row no-margin-y target-group-header"},Ot.createElement("div",{className:"col-md-8 target-group-title"},e.name),Ot.createElement("div",{className:"col-md-4 text-right"},Ot.createElement(X,{container:e.instanceCounts}))))),a&&r,!a&&t&&Ot.createElement(J,{serverGroups:e.serverGroups,instances:e.instances}))}}class Er extends Ot.Component{shouldComponentUpdate(e){return e.showInstances!==this.props.showInstances||e.showServerGroups!==this.props.showServerGroups||e.loadBalancer!==this.props.loadBalancer||(()=>!Xt((e.serverGroups||[]).map((e=>e.name)),(this.props.serverGroups||[]).map((e=>e.name))))()||(()=>!Xt((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=>Ot.createElement(br,{key:n.name,loadBalancer:e,targetGroup:n,showInstances:t,showServerGroups:a})));return Ot.createElement("div",{className:"cluster-container"},n)}return Ot.createElement(Q,{...this.props})}}class wr{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 Ya.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=_t(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 Cr extends Ot.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Ot.createElement("a",{onClick:this.onClick},Ot.createElement("span",{className:"name"},this.props.loadBalancer.name),Ot.createElement(X,{container:this.props.loadBalancer.instanceCounts}))}}class Sr extends Ot.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Ot.createElement(_,{value:`${this.props.label||"Load Balancer"}: ${this.props.loadBalancer.name}`},Ot.createElement("button",{className:"btn btn-link no-padding",onClick:this.onClick},Ot.createElement("span",{className:"badge badge-counter"},Ot.createElement("span",{className:"icon"},Ot.createElement("i",{className:"fa icon-sitemap"})))))}}class kr extends Ot.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})})),wr.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?Ot.createElement(ae,{size:"nano"}):null;const s="load-balancers-tag "+(i>1?"overflowing":""),l=Ot.createElement("div",{className:"menu-load-balancers"},r>0&&Ot.createElement("div",{className:"menu-load-balancers-header"},"Load Balancers"),Jt(e,"name").map((e=>Ot.createElement(Cr,{key:e.name,loadBalancer:e,onItemClick:this.showLoadBalancerDetails}))),n>0&&Ot.createElement("div",{className:"menu-load-balancers-header"},"Target Groups"),Jt(t,"name").map((e=>Ot.createElement(Cr,{key:e.name,loadBalancer:e,onItemClick:this.showTargetGroupDetails}))));return Ot.createElement("span",{className:s},i>1&&Ot.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"},Ot.createElement("button",{onClick:this.handleClick,className:"btn btn-link btn-multiple-load-balancers clearfix no-padding"},Ot.createElement("span",{className:"badge badge-counter"},Ot.createElement("span",{className:"icon"},Ot.createElement("i",{className:"fa icon-sitemap"}))," ",i))),1===e.length&&0===t.length&&Ot.createElement("span",{className:"btn-load-balancer"},Ot.createElement(Sr,{key:e[0].name,label:"Load Balancer",loadBalancer:e[0],onItemClick:this.showLoadBalancerDetails})),1===t.length&&0===e.length&&Ot.createElement("span",{className:"btn-load-balancer"},Ot.createElement(Sr,{key:t[0].name,label:"Target Group",loadBalancer:t[0],onItemClick:this.showTargetGroupDetails})))}}class Nr{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=_t(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=Qt(e.serverGroups,{isDisabled:!1});return e.provider=e.type,e.instances=ea(t).map("instances").flatten().value(),e.detachedInstances=ea(t).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Ya.all([Vn.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=_t(ta(a.targetGroups,"serverGroups"))}e.loadBalancerType=e.loadBalancerType||"classic",e.provider=e.type,this.normalizeActions(e);const a=Qt(t,{isDisabled:!1});return e.instances=ea(a).map("instances").flatten().value(),e.detachedInstances=ea(a).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Vn.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||Sn.defaults.account,region:e.defaultRegions.aws||Sn.defaults.region,vpcId:null,subnetType:Sn.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||Sn.defaults.account,region:e.defaultRegions.aws||Sn.defaults.region,vpcId:null,subnetType:Sn.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||Sn.defaults.account,region:e.defaultRegions.aws||Sn.defaults.region,vpcId:null,subnetType:Sn.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 Tr=Object.defineProperty,Gr=Object.getOwnPropertyDescriptor;let Ir=class extends Ot.Component{render(){return Ot.createElement("h3",null,"Target Group Details")}};Ir=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Gr(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&&Tr(t,a,i),i})([ie("loadBalancer.targetGroupDetails")],Ir);var Ar=Object.defineProperty,xr=Object.getOwnPropertyDescriptor;let Pr=class extends Ot.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 Ot.createElement("div",{style:{width:"100%"}},Ot.createElement(nn,{className:"input-sm",wrapperStyle:{width:"100%"},clearable:!0,required:!0,options:i,onChange:e=>a(e.value),value:n}),s&&Ot.createElement("div",{className:"small sp-margin-xs-top sp-margin-m-bottom sp-margin-m-left"},Ot.createElement("div",null,"Uploaded ",se(s.uploadDate)," (",B(s.uploadDate),")"),Ot.createElement("b",null,"Expires ",se(s.expiration))," (",B(s.expiration),")"))}};Pr=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?xr(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&&Ar(t,a,i),i})([ie("amazon.certificateSelectField")],Pr);const zr=Ot.forwardRef(((e,t)=>Ot.createElement("div",{ref:t},Ot.createElement(s,{name:"idleTimeout",label:"Idle Timeout",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Ot.createElement(u,{...e,min:0})}),Ot.createElement(s,{name:"deletionProtection",label:"Protection",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Ot.createElement(d,{...e,text:"Enable delete protection"})}),Ot.createElement(s,{name:"dualstack",label:"Dualstack",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.albIpAddressType"}),input:e=>Ot.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})}))));yr(".configure-config-modal .StandardFieldLayout .sm-label-right {\n min-width: 160px;\n}\n");const Dr=class extends Ot.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(Dr,e)}render(){const{initialValues:e}=this.state;return Ot.createElement("div",{className:"configure-config-modal"},Ot.createElement(le,{initialValues:e,onSubmit:this.submit,validate:this.validate,render:({isValid:e})=>Ot.createElement(cn,{className:"form-horizontal"},Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Configure OIDC Client")),Ot.createElement(qa.Body,null,Ot.createElement(s,{name:"issuer",label:"Issuer",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter the OpenId Provider"})}),Ot.createElement(s,{name:"authorizationEndpoint",label:"Authorization Endpoint",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter OpenID provider server endpoint"})}),Ot.createElement(s,{name:"tokenEndpoint",label:"Token Endpoint",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter a URI for your token endpoint"})}),Ot.createElement(s,{name:"userInfoEndpoint",label:"User info Endpoint",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter a URI for your user info endpoint"})}),Ot.createElement(s,{name:"clientId",label:"Client ID",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter the client ID"})}),Ot.createElement(s,{name:"clientSecret",label:"Client secret",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter the client secret"})})),Ot.createElement(qa.Footer,null,Ot.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Ot.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Client"})))}))}};let Br=Dr;Br.defaultProps={closeModal:C,dismissModal:C};const Fr=class extends Ot.Component{constructor(e){super(e),this.close=e=>{this.props.dismissModal(e)},this.submit=e=>{const t=aa(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(Fr,e)}render(){return Ot.createElement("div",{className:"configure-config-modal"},Ot.createElement(le,{initialValues:this.initialValues,onSubmit:this.submit,render:({isValid:e})=>Ot.createElement(cn,{className:"form-horizontal"},Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Configure Redirect ",Ot.createElement(n,{id:"aws.loadBalancer.redirect"}))),Ot.createElement(qa.Body,null,Ot.createElement(s,{name:"host",label:"Host",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.host"})}),Ot.createElement(s,{name:"path",label:"Path",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.path"})}),Ot.createElement(s,{name:"port",label:"Port",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.port"})}),Ot.createElement(s,{name:"protocol",label:"Protocol",required:!1,input:e=>Ot.createElement(c,{...e,stringOptions:["HTTP","HTTPS","#{protocol}"],placeholder:"Select Protocol",clearable:!1,style:{width:"130px"}}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.protocol"})}),Ot.createElement(s,{name:"query",label:"Query",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.query"})}),Ot.createElement(s,{name:"statusCode",label:"Status Code",required:!0,input:e=>Ot.createElement(de,{...e,options:["HTTP_301","HTTP_302"]}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.statusCode"})})),Ot.createElement(qa.Footer,null,Ot.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Ot.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Config"})))}))}};let Mr=Fr;Mr.defaultProps={closeModal:C,dismissModal:C};class $r{static listCertificates(){return pe.listCertificatesByProvider("aws").then((e=>o.listAllAccounts("aws").then((t=>{const a=t.reduce(((e,t)=>(e[t.accountId]=t.name,e)),{}),n=Jt(e,"serverCertificateName");return na(n,(e=>{const[,,,,t]=e.arn.split(":");return a[t]||"unknown"}))}))))}}const Lr=rn((()=>Ot.createElement("span",{className:"pipeline-drag-handle clickable glyphicon glyphicon-resize-vertical"}))),Rr={authenticateOidcConfig:{authorizationEndpoint:"",clientId:"",issuer:"",scope:"openid",sessionCookieName:"AWSELBAuthSessionCookie",tokenEndpoint:"",userInfoEndpoint:""},type:"authenticate-oidc"};class Or extends Ot.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=sn(t.rules,e.oldIndex,e.newIndex),this.updateListeners()},this.configureOidcClient=e=>{Br.show({config:e.authenticateOidcConfig}).then((t=>{e.authenticateOidcConfig=t,this.updateListeners()})).catch((()=>{}))},this.configureRedirect=e=>{Mr.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)||{...Rr};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:ra(Sn,"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=_t(e.map((e=>e.defaultActions))),a=_t(e.map((e=>e.rules)));return t.push(..._t(a.map((e=>e.actions)))),ia(t.map((e=>e.targetGroupName)))}validate(e){const t={},a=e.targetGroups.map((e=>e.name)),n=this.getAllTargetGroupsFromListeners(e.listeners),r=sa(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;jt(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||!la(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(){$r.listCertificates().then((e=>{this.setState({certificates:e})}))}loadOidcClients(){(class{static getOidcConfigsByApp(e){return z("/oidcConfigs").query({app:e}).get()}}).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),Ya.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},t.listeners.map(((e,i)=>Ot.createElement("div",{key:i,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Ot.createElement("div",{className:"wizard-pod-row-contents spread"},Ot.createElement("div",null,Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol"),Ot.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=>Ot.createElement("option",{key:e},e))))),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port"),Ot.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}))),Ot.createElement("div",null,Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(i)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))))),this.needsCert(e)&&Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Ot.createElement("div",{className:"wizard-pod-row-contents"},e.certificates.map(((e,r)=>Ot.createElement("div",{key:r,style:{width:"100%",display:"flex",flexDirection:"row"}},Ot.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=>Ot.createElement("option",{key:e},e)))),this.showCertificateSelect(e)&&Ot.createElement(Pr,{certificates:a,accountName:t.credentials,currentValue:e.name,app:this.props.app,onCertificateSelect:t=>this.handleCertificateChanged(e,t)}),!this.showCertificateSelect(e)&&Ot.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})))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Ot.createElement("table",{className:"table table-condensed packed rules-table"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{style:{width:"15px",padding:"0"}}),Ot.createElement("th",null,"If"),Ot.createElement("th",{style:{width:"315px"}},"Then"),Ot.createElement("th",{style:{width:"45px"}}))),Ot.createElement(Hr,{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&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(ue,{type:"error",message:e.listenerPorts})),e.listeners&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(ue,{type:"error",message:e.listeners})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}const Ur=ln((e=>Ot.createElement("tr",{className:"listener-rule"},Ot.createElement("td",{className:"handle"},Ot.createElement(Lr,null)),Ot.createElement("td",null,e.rule.conditions.map(((t,a)=>Ot.createElement("div",{key:a,className:"listener-rule-condition"},Ot.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)&&Ot.createElement("option",{value:"host-header"},"Host"),(1===e.rule.conditions.length||"path-pattern"===t.field)&&Ot.createElement("option",{value:"path-pattern"},"Path"),(1===e.rule.conditions.length||"http-request-method"===t.field)&&Ot.createElement("option",{value:"http-request-method"},"Method(s)")),"path-pattern"===t.field&&Ot.createElement(n,{id:"aws.loadBalancer.ruleCondition.path"}),"host-header"===t.field&&Ot.createElement(n,{id:"aws.loadBalancer.ruleCondition.host"}),"http-request-method"!==t.field&&Ot.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&&Ot.createElement("div",{className:"col-md-6 checkbox"},["DELETE","GET","PATCH","POST","PUT"].map((a=>Ot.createElement("label",{key:`${a}-checkbox`},Ot.createElement("input",{type:"checkbox",checked:t.values.includes(a),onChange:n=>e.handleHttpRequestMethodChanged(t,a,n.target.checked)}),a)))),Ot.createElement("span",{className:"remove-condition"},1===a&&Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeCondition(e.rule,a),style:{padding:"0"}},Ot.createElement(_,{value:"Remove Condition"},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))))))),1===e.rule.conditions.length&&Ot.createElement("div",{className:"add-new-container"},Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addCondition(e.rule)},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new condition")),Ot.createElement("span",{style:{minWidth:"15px"}}))),Ot.createElement("td",null,e.rule.actions.map(((t,a)=>Ot.createElement(Vr,{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})))),Ot.createElement("td",null,Ot.createElement(qr,{ruleIndex:e.ruleIndex,listener:e.listener,authenticateRuleToggle:e.authenticateRuleToggle,removeRule:e.removeRule,actions:e.rule.actions}))))),Vr=e=>{var t;if("authenticate-oidc"!==e.action.type){const t=e.action.redirectActionConfig||e.action.redirectConfig;return Ot.createElement("div",{className:"horizontal top"},Ot.createElement("select",{className:"form-control input-sm",style:{width:"80px"},value:e.action.type,onChange:t=>e.actionTypeChanged(t.target.value)},Ot.createElement("option",{value:"forward"},"forward to"),Ot.createElement("option",{value:"redirect"},"redirect to")),"forward"===e.action.type&&Ot.createElement("select",{className:"form-control input-sm",value:e.action.targetGroupName,onChange:t=>e.targetChanged(t.target.value),required:!0},Ot.createElement("option",{value:""}),ia(e.targetGroups.map((e=>e.name))).map((e=>Ot.createElement("option",{key:e},e)))),"redirect"===e.action.type&&Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Host"),Ot.createElement("dd",null,t.host),Ot.createElement("dt",null,"Path"),Ot.createElement("dd",null,t.path),Ot.createElement("dt",null,"Port"),Ot.createElement("dd",null,t.port),Ot.createElement("dt",null,"Protocol"),Ot.createElement("dd",null,t.protocol),Ot.createElement("dt",null,"Query"),Ot.createElement("dd",null,t.query),Ot.createElement("dt",null,"Status Code"),Ot.createElement("dd",null,t.statusCode),Ot.createElement("dt",null,Ot.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=ra(Sn,"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=>Ot.createElement("option",{key:e.clientId},e.clientId))):Ot.createElement("option",{disabled:!0},"No ",me.get("OIDC client")," config found");return Ot.createElement("div",{className:"horizontal middle",style:{height:"30px"}},Ot.createElement("span",{style:{whiteSpace:"pre"}},"auth with ",me.get("OIDC client")," "),n&&Ot.createElement("select",{className:"form-control input-sm",value:a,onChange:t=>e.oidcConfigChanged(e.oidcConfigs.find((e=>e.clientId===t.target.value))),required:!0},Ot.createElement("option",{value:""}),r),!n&&Ot.createElement("a",{onClick:()=>e.configureOidcClient(e.action),className:"clickable"},a||"Configure..."),Ot.createElement("span",{style:{whiteSpace:"pre"}},Ot.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 Ot.createElement("span",null,a&&Ot.createElement(Ot.Fragment,null,Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.authenticateRuleToggle(e.listener,e.ruleIndex),style:{padding:"0"}},Ot.createElement(_,{value:r},Ot.createElement("i",{className:i}))),Ot.createElement(n,{id:"aws.loadBalancer.oidcAuthentication"})),void 0!==e.ruleIndex&&e.ruleIndex>=0&&e.removeRule&&Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeRule(e.listener,e.ruleIndex),style:{padding:"0"}},Ot.createElement(_,{value:"Remove Rule"},Ot.createElement("i",{className:"far fa-fw fa-trash-alt"}))))},Hr=on((e=>Ot.createElement("tbody",null,Ot.createElement("tr",{className:"not-sortable"},Ot.createElement("td",null),Ot.createElement("td",null,"Default"),Ot.createElement("td",null,e.listener.defaultActions.map(((t,a)=>Ot.createElement(Vr,{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})))),Ot.createElement("td",null,Ot.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)=>Ot.createElement(Ur,{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}))),Ot.createElement("tr",{className:"not-sortable"},Ot.createElement("td",{colSpan:5},Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addRule(e.listener)},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new rule"))))))),Wr=(e,t,a)=>n=>ra(e,[t,a],[]).includes(n.toLowerCase())?`There is already a target group in ${t}:${a} with that name.`:null,jr=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 Zr extends Ot.Component{constructor(e){super(e),this.protocols=["HTTP","HTTPS"],this.targetTypes=["instance","ip","lambda"],this.destroy$=new Na,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=ia(_t(Qt(na(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(Wr(this.state.existingTargetGroupNames,e.credentials,e.region),jr(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=oa(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={};Ta(t.getDataSource("loadBalancers").refresh(!0)).pipe(Ma(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,ca(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=>Ot.createElement("option",{key:e},e))),s=this.targetTypes.map((e=>Ot.createElement("option",{key:e},e)));return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.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 Ot.createElement("div",{key:l,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"group-name-prefix"},e.name,"-"),Ot.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}),Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(l)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))),o.name&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(ue,{type:"error",message:o.name})))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},Ot.createElement(n,{id:"aws.targetGroup.targetType"})," ",Ot.createElement("span",null,"Target Type ")),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.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&&Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),Ot.createElement(n,{id:"aws.targetGroup.protocol"})," ",Ot.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)),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.createElement(n,{id:"aws.targetGroup.port"})," ",Ot.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}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},"lambda"!==a.targetType&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),"TCP"===a.healthCheckProtocol&&Ot.createElement(n,{id:"aws.targetGroup.healthCheckProtocol"})," ",Ot.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&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.createElement(n,{id:"aws.targetGroup.attributes.healthCheckPort.trafficPort"})," ",Ot.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":"")},Ot.createElement("option",{value:"traffic-port"},"Traffic Port"),Ot.createElement("option",{value:"manual"},"Manual"))," ",Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Path "),Ot.createElement(fe,{error:o.healthCheckPath,name:"healthCheckPath",required:!0,value:a.healthCheckPath,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPath",e.target.value)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Timeout "),(c||d)&&Ot.createElement(n,{id:"aws.targetGroup.healthCheckTimeout"}),Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Interval "),Ot.createElement(ve,{error:o.healthCheckInterval,required:!0,value:a.healthCheckInterval,min:5,max:300,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckInterval",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck Threshold"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Healthy "),Ot.createElement(ve,{error:o.healthyThreshold,value:a.healthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"healthyThreshold",e)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Unhealthy "),Ot.createElement(ve,{error:o.unhealthyThreshold,required:!0,value:a.unhealthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"unhealthyThreshold",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),"lambda"!==a.targetType?Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Dereg. Delay"),Ot.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Ot.createElement("input",{type:"checkbox",checked:a.attributes.stickinessEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.stickinessEnabled",e.target.checked)})," ",Ot.createElement("label",null,"Sticky"),Ot.createElement(n,{id:"aws.targetGroup.attributes.stickinessEnabled"}))),a.attributes.stickinessEnabled&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Duration "),Ot.createElement(n,{id:"aws.targetGroup.attributes.stickinessDuration"})," ",Ot.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"})))):Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Ot.createElement("input",{type:"checkbox",checked:a.attributes.multiValueHeadersEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.multiValueHeadersEnabled",e.target.checked)})," ",Ot.createElement("label",null,"Enable Multi Value Headers"))))))})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}}class _r extends Ot.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 Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Availability Zones"),e&&Ot.createElement("div",{className:"col-md-7"},Ot.createElement("p",{className:"form-control-static"},"Automatic Availability Zone Balancing:"),Ot.createElement("select",{className:"form-control input-sm",value:r?"true":"false",onChange:this.handleUsePreferredZonesChanged},Ot.createElement("option",{value:"true"},"Enabled"),Ot.createElement("option",{value:"false"},"Manual")),Ot.createElement("br",null),r&&Ot.createElement("div",null,Ot.createElement("p",{className:"form-control-static"},"Server group will be available in:"),Ot.createElement("ul",null,n.map((e=>Ot.createElement("li",{key:e},e))))),!r&&Ot.createElement("div",null,"Restrict server group instances to:",Ot.createElement(ye,{stringOptions:t,value:a,onChange:e=>this.handleSelectedZonesChanged(e.target.value)}))))}}function Kr(e){const{application:t,credentials:a,defaultSubnetTypes:n,hideClassic:r,name:i,onChange:s,readOnly:l,region:o,subnets:c,value:d,...p}=e,u=be(c),m=Ot.useMemo((()=>{const e=r||function(e,t,a){const{classicLaunchLockout:n,classicLaunchAllowlist:r}=Sn,i=Number(ra(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,u]),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 Ot.useEffect((()=>{const e=m.some((e=>e.value===d));g&&(!e||"FIRST_RENDER"!==h)&&s(we({name:i,value:g.purpose}))}),[m]),l?Ot.createElement("p",{className:"form-control-static"},e.value||"None (EC2 Classic)"):Ot.createElement(de,{options:m,value:d,onChange:s,...p})}class Yr extends Rt.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:p,...u}=this.props,m=r[s],g=null!=(t=null!=c?c:null==(e=Sn.serverGroups)?void 0:e.recommendedSubnets)?t:[],h=null!=i?i:[Sn.defaults.subnetType],f=g.some((e=>m&&m.includes(e))),v=null==(a=Sn.serverGroups)?void 0:a.subnetWarning;return Rt.createElement("div",{className:"form-group"},Rt.createElement("div",{className:`col-md-${o} sm-label-right`},"VPC Subnet ",Rt.createElement(n,{id:l})),Rt.createElement("div",{className:"col-md-7"},d?Rt.createElement(Kr,{...u,inputClassName:"form-control input-sm",credentials:r.credentials,defaultSubnetTypes:h,region:d,value:m,onChange:this.handleChange}):"(Select an account)",p&&!f&&Boolean(v)&&Rt.createElement("div",{className:"alert alert-warning sp-margin-s-top horizontal center"},Rt.createElement("i",{className:"fa fa-exclamation-triangle sp-margin-s-top"}),Rt.createElement("div",{className:"sp-margin-s-left"},Rt.createElement(Ce,{message:v,style:{display:"inline-block",marginLeft:"2px"}})))))}}class Xr extends Ot.Component{constructor(){super(...arguments),this.state={accounts:void 0,availabilityZones:[],existingLoadBalancerNames:[],hideInternalFlag:!1,internalFlagToggled:!1,regions:[],subnets:[]},this.props$=new Na,this.destroy$=new Na,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(Kt(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!!(Sn&&Sn.loadBalancers&&Sn.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(Pa((e=>e.formik.values))),t=this.props$.pipe(Pa((e=>e.app.name)),za()),a={account$:e.pipe(Pa((e=>e.credentials)),za()),region$:e.pipe(Pa((e=>e.region)),za()),subnetPurpose$:e.pipe(Pa((e=>e.subnetType)),za()),stack$:e.pipe(Pa((e=>e.stack)),za()),detail$:e.pipe(Pa((e=>e.detail)),za())},n=Ta(o.listAccounts("aws")).pipe(Da(1)),r=Ga([a.account$,n]).pipe(Ba((([e,t])=>o.getRegionsForAccount(e))),Da(1)),i=this.props.app.getDataSource("loadBalancers").data$,s=Ga([i,a.account$,a.region$]).pipe(Pa((([e,t,a])=>e.filter((e=>e.account===t&&e.region===a)).map((e=>e.name)))),Da(1)),l=Ga([a.account$,a.region$]).pipe(Ba((([e,t])=>this.getAvailableSubnets(e,t))),Pa((e=>this.makeSubnetOptions(e))),Da(1)),c=Ga([l,a.subnetPurpose$]).pipe(Pa((([e,t])=>e&&e.find((e=>e.purpose===t))))),d=c.pipe(Pa((e=>e?ia(e.availabilityZones).sort():[]))),p=a.region$.pipe(Fa(r),Pa((([e,t])=>t.find((t=>t.name===e)))),Pa((e=>e?e.availabilityZones:[]))),u=Ga([t,a.stack$,a.detail$]).pipe(Pa((([e,t,a])=>({app:e,stack:t,detail:a,cluster:re.getClusterName(e,t,a)}))));r.pipe(Fa(a.region$),Ma(this.destroy$)).subscribe((([e,t])=>{e.some((e=>e.name===t))||this.props.formik.setFieldValue("region",e[0]&&e[0].name)})),p.pipe(Ma(this.destroy$)).subscribe((e=>{this.props.formik.setFieldValue("regionZones",e)})),c.pipe(Ma(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"))})),u.pipe(Ma(this.destroy$)).subscribe((e=>{this.props.formik.setFieldValue("moniker",e),this.props.formik.setFieldValue("name",e.cluster)})),Ga([n,r,d,s,l]).pipe(Ma(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=>ea(a).filter({account:e,region:t}).reject({target:"ec2"}).reject({purpose:null}).value()))}makeSubnetOptions(e){const t=na(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:ia(e.map((e=>e.vpcId))),availabilityZones:ia(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=ka({"col-md-12":!0,well:!0,"alert-danger":!!t.name,"alert-info":!t.name});return Ot.createElement("div",{className:"container-fluid form-horizontal"},!r&&Ot.createElement("div",{style:{height:"200px"}},Ot.createElement(ae,{size:"medium"})),r&&Ot.createElement("div",{className:"modal-body"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:c},Ot.createElement("strong",null,"Your load balancer will be named: "),Ot.createElement("span",null,a.name),Ot.createElement(n,{id:"aws.loadBalancer.name"}),Ot.createElement(dn,{type:"text",style:{display:"none"},className:"form-control input-sm no-spel",name:"name"}),t.name&&Ot.createElement(ue,{type:"error",message:t.name}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Ot.createElement("div",{className:"col-md-7"},Ot.createElement(Se,{value:a.credentials,onChange:e=>this.accountUpdated(e.target.value),accounts:r,provider:"aws"}))),Ot.createElement(ke,{labelColumns:3,component:a,field:"region",account:a.credentials,onChange:this.regionUpdated,regions:l}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Ot.createElement(n,{id:"aws.loadBalancer.stack"})),Ot.createElement("div",{className:"col-md-3"},Ot.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.stack?"invalid":""),value:a.stack,name:"stack",onChange:this.stackChanged})),Ot.createElement("div",{className:"col-md-6 form-inline"},Ot.createElement("label",{className:"sm-label-right"},Ot.createElement("span",null,"Detail ",Ot.createElement(n,{id:"aws.loadBalancer.detail"})," ")),Ot.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.detail?"invalid":""),value:a.detail,name:"detail",onChange:this.detailChanged})),t.stack&&Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement(ue,{type:"error",message:t.stack})),t.detail&&Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement(ue,{type:"error",message:t.detail}))),Ot.createElement(_r,{credentials:a.credentials,region:a.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:a.regionZones,allZones:i}),Ot.createElement(Yr,{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&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("b",null,"Internal")," ",Ot.createElement(n,{id:"aws.loadBalancer.internal"})),Ot.createElement("div",{className:"col-md-7 checkbox"},Ot.createElement("label",null,Ot.createElement(dn,{name:"isInternal",onChange:this.internalFlagChanged,render:({field:{value:e,...t}})=>Ot.createElement("input",{type:"checkbox",...t,checked:!!e})}),"Create an internal load balancer")))))}}class Jr extends Ot.Component{constructor(e){super(e),this.destroy$=new Na,this.props$=new Na,this.refresh$=new Na,this.clearRemoved=()=>{this.setState({removed:[]},(()=>this.props.formik.validateForm()))},this.handleSecurityGroupsChanged=e=>{this.props.formik.setFieldValue("securityGroups",e.map((e=>e.value)))};const t=ra(Sn,"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:`${V.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]=da((()=>{const t=e.concat(r).sort();return ia((a?n:[]).concat(t))})(),(e=>!!i(e))),o=s.map((e=>i(e).name));Xt(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($a((()=>this.onRefreshStart())),Ba((()=>h.cacheInitializer.refreshCache("securityGroups"))),La((()=>h.securityGroupReader.getAllSecurityGroups())),$a((()=>this.onRefreshComplete()))),t=this.props$.pipe(Pa((e=>e.formik.values))),a=t.pipe(Pa((e=>e.vpcId)),za());Ga([a,e]).pipe(Fa(t),Pa((([[e,t],a])=>{const n=t[a.credentials]||{};return(n.aws&&n.aws[a.region]||[]).filter((t=>e===t.vpcId)).sort()}))).pipe(Fa(t),Ma(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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",null,r.length>0&&Ot.createElement("div",{className:"form-group"},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"}),"The following ",V.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,r.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:this.clearRemoved},"Okay"))))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},V.get("Firewalls")),Ot.createElement("div",{className:"col-md-9"},!a&&Ot.createElement("div",{style:{paddingTop:"13px"}},Ot.createElement(ae,{size:"small"})),a&&Ot.createElement(pn,{multi:!0,value:e,options:t,onChange:this.handleSecurityGroupsChanged,clearable:!1}))),Ot.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Ot.createElement("div",{className:"col-md-9 col-md-offset-3"},Ot.createElement("p",null,n&&Ot.createElement("span",null,Ot.createElement("span",{className:"fa fa-sync-alt fa-spin"})," "),V.get("Firewalls"),!n&&Ot.createElement("span",null," last refreshed ",B(i)),n&&Ot.createElement("span",null," refreshing...")),Ot.createElement("p",null,"If you're not finding a ",V.get("firewall")," that was recently added,"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.refresh$.next()},"click here")," ","to refresh the list.")))))}}yr(".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 Qr=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ra(Sn,"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=Zt(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?Nr.convertApplicationLoadBalancerForEditing(e.loadBalancer):Nr.constructNewApplicationLoadBalancerTemplate(e.app);this.state={includeSecurityGroups:!!t.vpcId,isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(Qr,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}`),Ot.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 Ot.createElement(Ot.Fragment,null,l&&Ot.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Ot.createElement(Xr,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),o&&Ot.createElement(w,{label:V.get("Firewalls"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Ot.createElement(Jr,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Ot.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(Zr,{ref:a,app:e,formik:t,isNew:r,loadBalancer:n})}),Ot.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(Or,{ref:a,app:e,formik:t})}),Ot.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(zr,{ref:e})}))}})}};let ei=Qr;ei.defaultProps={closeModal:C,dismissModal:C};yr(".AmazonLoadBalancer-AdvancedSettings .StandardFieldLayout .sm-label-right {\n width: 180px;\n}\n");class ti extends Ot.Component{render(){const{values:e}=this.props.formik,{maxValue:t}=ge;return Ot.createElement("div",{className:"form-group AmazonLoadBalancer-AdvancedSettings"},Ot.createElement(s,{name:"healthTimeout",label:"Timeout",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.healthTimeout"}),input:t=>Ot.createElement(u,{...t,min:0,max:e.healthInterval}),validate:t(e.healthInterval,"Timeout must be less than the health interval.")}),Ot.createElement(s,{name:"healthInterval",label:"Interval",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.healthInterval"}),input:e=>Ot.createElement(u,{...e,min:0})}),Ot.createElement(s,{name:"healthyThreshold",label:"Healthy Threshold",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.healthyThreshold"}),input:e=>Ot.createElement(u,{...e,min:0})}),Ot.createElement(s,{name:"unhealthyThreshold",label:"Unhealthy Threshold",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.unhealthyThreshold"}),input:e=>Ot.createElement(u,{...e,min:0})}),Ot.createElement(s,{name:"idleTimeout",label:"Idle Timeout",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Ot.createElement(u,{...e,min:0})}),Ot.createElement("div",{className:"col-md-12"},Ot.createElement("p",null,"Additional configuration options (cross-zone load balancing, session stickiness, access logs) are available via the AWS console.")))}}class ai extends Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},"Ping"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{style:{width:"35%"}},"Protocol"),Ot.createElement("th",{style:{width:"30%"}},"Port"),Ot.createElement("th",null,this.requiresHealthCheckPath()&&Ot.createElement("span",null,"Path")))),Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement(s,{name:"healthCheckProtocol",required:!0,input:e=>Ot.createElement(de,{...e,options:["HTTP","HTTPS","SSL","TCP"]})})),Ot.createElement("td",null,Ot.createElement(s,{name:"healthCheckPort",required:!0,input:e=>Ot.createElement(u,{...e,min:1,max:65534})})),Ot.createElement("td",null,this.requiresHealthCheckPath()&&Ot.createElement(s,{name:"healthCheckPath",input:e=>Ot.createElement(l,{...e}),required:!0,onChange:this.healthCheckPathChanged})))))))}}yr(".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 ni extends Ot.Component{constructor(){super(...arguments),this.protocols=["HTTP","HTTPS","TCP","SSL"],this.secureProtocols=["HTTPS","SSL"],this.certificateTypes=ra(Sn,"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(){$r.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 Ot.createElement(Pr,{certificates:a,accountName:t.credentials,currentValue:e.sslCertificateName,app:this.props.app,onCertificateSelect:t=>this.handleListenerCertificateChanged(e,t)})}return Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal create-classic-load-balancer-wizard-listeners"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",null,"External Protocol"),Ot.createElement("th",null,"External Port"),Ot.createElement("th",null),Ot.createElement("th",null,"Internal Protocol"),Ot.createElement("th",null,"Internal Port"),Ot.createElement("th",null))),Ot.createElement("tbody",null,e.listeners.map(((e,t)=>Ot.createElement(Ot.Fragment,{key:t},Ot.createElement("tr",{key:t+"-main"},Ot.createElement("td",null,Ot.createElement("select",{className:"form-control input-sm",value:e.externalProtocol,onChange:t=>this.listenerExternalProtocolChanged(e,t.target.value)},this.protocols.map((e=>Ot.createElement("option",{key:e},e))))),Ot.createElement("td",null,Ot.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.externalPort,onChange:t=>this.listenerExternalPortChanged(e,t.target.value),required:!0})),Ot.createElement("td",{className:"small",style:{paddingTop:"10px"}},"→"),Ot.createElement("td",null,Ot.createElement("select",{className:"form-control input-sm",value:e.internalProtocol,onChange:t=>this.listenerInternalProtocolChanged(e,t.target.value)},this.protocols.map((e=>Ot.createElement("option",{key:e},e))))),Ot.createElement("td",null,Ot.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.internalPort,onChange:t=>this.listenerInternalPortChanged(e,t.target.value),required:!0})),Ot.createElement("td",null,Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(t)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"})))),this.secureProtocols.includes(e.externalProtocol)&&Ot.createElement("tr",{key:t+"-ssl"},Ot.createElement("td",{colSpan:5,style:{borderTopWidth:0}},Ot.createElement("div",{className:"horizontal space-between"},Ot.createElement("div",{className:"sm-label-right"},"Certificate"),this.certificateTypes.length>1&&Ot.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=>Ot.createElement("option",{key:e},e)))),this.renderCertificateSelector(e)))))))),Ot.createElement("tfoot",null,Ot.createElement("tr",null,Ot.createElement("td",{colSpan:5},Ot.createElement("button",{className:"add-new col-md-12",onClick:this.addListener,type:"button"},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),Ot.createElement("span",null," Add new port mapping")))))))))}}const ri=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ra(Sn,"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=Zt(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?Nr.convertClassicLoadBalancerForEditing(e.loadBalancer):Nr.constructNewClassicLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(ri,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}`),Ot.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})=>Ot.createElement(Ot.Fragment,null,l&&Ot.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Ot.createElement(Xr,{app:e,formik:t,isNew:r,forPipelineConfig:a,loadBalancer:n,ref:i})}),!!t.values.vpcId&&Ot.createElement(w,{label:V.get("Firewall"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Ot.createElement(Jr,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Ot.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(ni,{ref:a,formik:t,app:e})}),Ot.createElement(w,{label:"Health Check",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(ai,{ref:e,formik:t})}),Ot.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(ti,{ref:e,formik:t})}))})}};let ii=ri;ii.defaultProps={closeModal:C,dismissModal:C};const si=Ot.forwardRef(((e,t)=>Ot.createElement("div",{ref:t},Ot.createElement(s,{name:"deletionProtection",label:"Protection",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Ot.createElement(d,{...e,text:"Enable deletion protection"})}),Ot.createElement(s,{name:"loadBalancingCrossZone",label:"Cross-Zone Load Balancing",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.loadBalancingCrossZone"}),input:e=>Ot.createElement(d,{...e,text:"Distribute traffic across zones"})}),e.showDualstack&&Ot.createElement(s,{name:"dualstack",label:"Dualstack",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.nlbIpAddressType"}),input:e=>Ot.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})}))));function li({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 Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Ot.createElement("div",{className:"wizard-pod-row-contents"},e.map(((e,a)=>Ot.createElement("div",{key:a,style:{width:"100%",display:"flex",flexDirection:"row"}},Ot.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=>Ot.createElement("option",{key:e},e)))),l(e)&&Ot.createElement(Pr,{certificates:t,accountName:o.credentials,currentValue:e.name,app:n,onCertificateSelect:t=>s(e,t)}),!l(e)&&Ot.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 oi extends Ot.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:ra(Sn,"loadBalancers.certificateTypes",["iam","acm"]),oidcConfigs:void 0}}getAllTargetGroupsFromListeners(e){const t=_t(e.map((e=>e.defaultActions))),a=_t(e.map((e=>e.rules)));return t.push(..._t(a.map((e=>e.actions)))),ia(t.map((e=>e.targetGroupName)))}validate(e){const t={},a=e.targetGroups.map((e=>e.name)),n=this.getAllTargetGroupsFromListeners(e.listeners),r=sa(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 jt(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(){$r.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},t.listeners.map(((e,r)=>Ot.createElement("div",{key:r,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Ot.createElement("div",{className:"wizard-pod-row-contents spread"},Ot.createElement("div",null,Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol"),Ot.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=>Ot.createElement("option",{key:e},e))))),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port"),Ot.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}))),Ot.createElement("div",null,Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(r)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))))),Ot.createElement("div",null,"TLS"===e.protocol&&Ot.createElement(li,{availableCertificates:e.certificates,formik:this.props.formik,app:this.props.app,certificateTypes:n,certificates:a})),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title",style:{height:"30px"}},"Rules"),Ot.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Ot.createElement("table",{className:"table table-condensed packed rules-table"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{style:{width:"10px",padding:"0"}}),Ot.createElement("th",{style:{width:"226px"}},"If"),Ot.createElement("th",{style:{width:"75px"}},"Then"),Ot.createElement("th",null,"Target"),Ot.createElement("th",{style:{width:"30px"}}))),Ot.createElement("tbody",null,Ot.createElement("tr",{className:"not-sortable"},Ot.createElement("td",null),Ot.createElement("td",null,"Default"),Ot.createElement("td",null,"forward to"),Ot.createElement("td",null,Ot.createElement("select",{className:"form-control input-sm",value:e.defaultActions[0].targetGroupName,onChange:t=>this.handleDefaultTargetChanged(e,t.target.value),required:!0},Ot.createElement("option",{value:""}),ia(t.targetGroups.map((e=>e.name))).map((e=>Ot.createElement("option",{key:e},e))))),Ot.createElement("td",null)))))))))),e.listenerPorts&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(ue,{type:"error",message:e.listenerPorts})),e.listeners&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(ue,{type:"error",message:e.listeners})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}class ci extends Ot.Component{constructor(e){super(e),this.protocols=["TCP","UDP"],this.healthProtocols=["TCP","HTTP","HTTPS"],this.targetTypes=["instance","ip"],this.destroy$=new Na,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=ia(_t(Qt(na(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(Wr(this.state.existingTargetGroupNames,e.credentials,e.region),jr(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={};Ta(t.getDataSource("loadBalancers").refresh(!0)).pipe(Ma(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];ca(i,t,a),"healthyThreshold"===t&&ca(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=>Ot.createElement("option",{key:e},e))),s=this.healthProtocols.map((e=>Ot.createElement("option",{key:e},e))),l=this.targetTypes.map((e=>Ot.createElement("option",{key:e},e)));return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},a.targetGroups.map(((a,o)=>{const c=t.targetGroups&&t.targetGroups[o]||{};return Ot.createElement("div",{key:o,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"group-name-prefix"},e.name,"-"),Ot.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}),Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(o)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))),c.name&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(ue,{type:"error",message:c.name})))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},Ot.createElement(n,{id:"aws.targetGroup.targetType"})," ",Ot.createElement("span",null,"Target Type ")),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("select",{className:"form-control input-sm",value:a.targetType,onChange:e=>this.targetGroupFieldChanged(o,"targetType",e.target.value),disabled:o<r},l))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),Ot.createElement(n,{id:"aws.targetGroup.protocol"})," ",Ot.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)),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.createElement(n,{id:"aws.targetGroup.port"})," ",Ot.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}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),Ot.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)),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.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&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Path "),Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Timeout "),Ot.createElement(ve,{error:c.healthCheckTimeout,required:!0,value:a.healthCheckTimeout,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckTimeout",e)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Interval "),Ot.createElement(ve,{error:c.healthCheckInterval,required:!0,value:a.healthCheckInterval,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckInterval",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},Ot.createElement(n,{id:"aws.targetGroup.nlbHealthcheckThreshold"})," ",Ot.createElement("span",null,"Healthcheck Threshold ")),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement(ve,{error:c.healthyThreshold,value:a.healthyThreshold,onChange:e=>this.targetGroupFieldChanged(o,"healthyThreshold",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Dereg. Delay"),Ot.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement(d,{name:"deregistrationDelayConnectionTermination",text:"Connection Termination",checked:a.attributes.deregistrationDelayConnectionTermination,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.deregistrationDelayConnectionTermination",e.target.checked)}}),Ot.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelayConnectionTermination"})),"instance"!==a.targetType&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement(d,{name:"preserveClientIp",text:"Preserve Client IP",checked:a.attributes.preserveClientIp,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.preserveClientIp",e.target.checked)}}),Ot.createElement(n,{id:"aws.targetGroup.attributes.preserveClientIp"})))))))})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}}const di=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ra(Sn,"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=Zt(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?Nr.convertNetworkLoadBalancerForEditing(e.loadBalancer):Nr.constructNewNetworkLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(di,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 Ot.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})=>Ot.createElement(Ot.Fragment,null,o&&Ot.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Ot.createElement(Xr,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),Ot.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(ci,{ref:a,formik:t,app:e,isNew:r,loadBalancer:n})}),Ot.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(oi,{ref:e,formik:t})}),Ot.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(si,{ref:e,showDualstack:!t.values.isInternal&&pa(t.values.targetGroups,{targetType:"instance"})})}))})}};let pi=di;pi.defaultProps={closeModal:C,dismissModal:C};const ui=[{type:"application",label:"Application",sublabel:"ALB",description:"Highly configurable, application-focused balancer. HTTP and HTTPS only.",component:ei},{type:"network",label:"Network",sublabel:"NLB",description:"Basic, high-performance balancer with fixed IP.",component:pi},{type:"classic",label:"Classic",sublabel:"Legacy",description:"Previous generation balancer (ELB).",component:ii}],mi=class extends Ot.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:ui,selectedChoice:ui[0]}}static show(e){return b.show(mi,{...e,className:"create-pipeline-modal-overflow-visible modal-lg"},{bsSize:"lg"})}choiceSelected(e){this.setState({selectedChoice:e})}getIncompatibility(e,t){const{loadBalancer:a={}}=U.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=Sn.createLoadBalancerWarnings&&Sn.createLoadBalancerWarnings[n.type];return Ot.createElement(Ot.Fragment,null,Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Select Type of Load Balancer")),Ot.createElement(qa.Body,null,Ot.createElement("div",{className:"modal-body"},Ot.createElement("div",{className:"card-choices"},r.map((e=>Ot.createElement("div",{key:e.type,className:"card "+(n===e?"active":""),onClick:()=>this.choiceSelected(e)},Ot.createElement("h3",{className:"load-balancer-label"},e.label),Ot.createElement("h3",null,"(",e.sublabel,")"),Ot.createElement("div",null,e.description))))),Ot.createElement(Ot.Fragment,null,i.length>0&&i.map((e=>Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"})," ",e.reason))))),!!s&&Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"}),Ot.createElement(Ce,{message:s,style:{display:"inline-block",marginLeft:"2px"}}))),Ot.createElement("div",{className:"load-balancer-description"}))),Ot.createElement(qa.Footer,null,Ot.createElement(Ha,{onClick:this.choose},"Configure Load Balancer ",Ot.createElement("span",{className:"glyphicon glyphicon-chevron-right"}))))}};let gi=mi;gi.defaultProps={closeModal:C,dismissModal:C};class hi extends Ot.Component{constructor(e){super(e),this.editLoadBalancer=()=>{const{loadBalancer:e}=this.props,{application:t}=this.state;ui.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:ra(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&&ua(l).filter((e=>e)).length)&&!s.length;return Ot.createElement("div",{style:{display:"inline-block"}},Sn.adHocInfraWritesEnabled&&Ot.createElement(Va,{className:"dropdown",id:"load-balancer-actions-dropdown"},Ot.createElement(Va.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Ot.createElement("span",null,"Load Balancer Actions")),Ot.createElement(Va.Menu,{className:"dropdown-menu"},r&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.editLoadBalancer},"Edit Load Balancer"),!r&&Ot.createElement("li",{className:"disabled"},Ot.createElement("a",null,"Edit Load Balancer"," ",Ot.createElement(n,{content:`The application <b>${o}</b> must be configured before this load balancer can be edited.`}))),c&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.deleteLoadBalancer},"Delete Load Balancer"),!c&&Ot.createElement("li",{className:"disabled"},Ot.createElement("a",null,"Delete Load Balancer"," ",Ot.createElement(n,{content:"You must detach all instances before you can delete this load balancer."}))),a&&a.feature.entityTags&&Ot.createElement(N,{component:t,application:e,entityType:"loadBalancer",onUpdate:this.entityTagUpdate}))))}}const fi="spinnaker.amazon.loadBalancer.details.loadBalancerActions.component";t(fi,[]).component("loadBalancerActions",Xa(L(hi,"loadBalancerActions"),["app","loadBalancer","loadBalancerFromParams"]));class vi{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=V.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=Jt(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 ma(e.map((e=>e.purpose)))||""}}vi.$inject=["$scope","$state","$q","loadBalancer","app","securityGroupReader","loadBalancerReader"];t("spinnaker.amazon.loadBalancer.details.controller",[tn,Ie,fi,Ae,xe]).controller("awsLoadBalancerDetailsCtrl",vi);class yi{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))}}yi.$inject=["$scope","$q","$state","targetGroup","app"];t("spinnaker.amazon.loadBalancer.details.targetGroupDetails.controller",[tn,xe]).controller("awsTargetGroupDetailsCtrl",yi);t("spinnaker.amazon.loadBalancer.targetGroup.states",[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:Ir,$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)}]);t("spinnaker.amazon.loadBalancer",["spinnaker.amazon.loadBalancer.details.controller","spinnaker.amazon.loadBalancer.details.targetGroupDetails.controller",fi,"spinnaker.amazon.loadBalancer.targetGroup.states"]);t("spinnaker.amazon.pipeline.stage.bake.executionDetails.controller",[tn]).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"===ra(e.stage,"context.status.result")&&!e.stage.failureMessage},s=()=>n.synchronizeSection(e.configSections,i);s(),e.$on("$stateChangeSuccess",s)}]);t("spinnaker.amazon.pipeline.stage.bakeStage",["spinnaker.amazon.pipeline.stage.bake.executionDetails.controller"]).config((function(){ze.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:De,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=Be.getAuthenticatedUser().name),e.viewState={loading:!0,roscoMode:a.feature.roscoMode||"function"==typeof a.feature.roscoSelector&&a.feature.roscoSelector(e.stage),minRootVolumeSize:Sn.minRootVolumeSize,showVmTypeSelector:!0,bakeWarning:Sn.bakeWarning,dockerBakeWarning:Sn.dockerBakeWarning,showDockerPreview:Sn.dockerBakeryDeprecated&&"docker"===e.stage.storeType,showMigrationFields:"Started"!==e.pipeline.migrationStatus,showStoreType:!Sn.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&&qt.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(){qt.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&&qt.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')}]);t("spinnaker.amazon.pipeline.stage.cloneServerGroupStage",[]).config((function(){ze.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=qt.get(e,"application.attributes.providerSettings.aws.useAmiBlockDeviceMappings",!1),t.copySourceCustomBlockDeviceMappings=!1),this.targetClusterUpdated=()=>{if(t.targetCluster){const a=Le.monikerClusterNameFilter(t.targetCluster),n=qt.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},qt.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)=>{qt.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 bi=[{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 Ei extends Ot.Component{constructor(e){super(e);const{value:t}=this.props,a=bi.filter((e=>e.value===t))[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Ot.createElement("div",null,Ot.createElement("b",null," ",this.state.label," "),Ot.createElement("br",null),Ot.createElement("small",null," ",this.state.description," "))}}function wi(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 Ot.createElement("div",{className:"form-horizontal"},Ot.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=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:(t,a)=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue(t,a)},input:e=>Ot.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))})}),Ot.createElement(s,{label:"Function Name",name:"functionName",input:e=>Ot.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:l})}),Ot.createElement(s,{label:"Target Version",name:"version",input:t=>Ot.createElement(c,{...t,clearable:!1,options:bi,optionRenderer:t=>Ot.createElement(Ei,{config:e,value:t.value,showingDetails:!0})})}),"$PROVIDED"===t.version?Ot.createElement(s,{label:"Version Number",name:"versionNumber",input:e=>Ot.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?Ot.createElement(s,{name:"retentionNumber",help:Ot.createElement(n,{content:"The number of Lambda versions to retain"}),label:"Prior Versions to Retain",input:e=>Ot.createElement(u,{...e,min:1,max:100})}):null)}function Ci(e){const{stage:t,name:a,current:n}=e;return Ot.createElement(Re,{name:a,current:n},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," ",Ot.createElement("b",null," Status: ")," ","done"===t.outputs.deleteTask?"COMPLETE":t.outputs.deleteTask," "),Ot.createElement("p",null," ",Ot.createElement("b",null," Deleted Version: ")," ",t.outputs["deleteTask:deleteVersion"]?t.outputs["deleteTask:deleteVersion"]:"N/A"," ")))}function Si(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()}(Ci||(Ci={})).title="Delete Lambda Stage";const ki={key:"Aws.LambdaDeleteStage",label:"AWS Lambda Delete",description:"Delete an AWS Lambda Function",component:function(e){return Ot.createElement("div",{className:"DeleteLambdaStageConfig"},Ot.createElement(Ve,{...e,validate:Si,onChange:e.updateStage,render:e=>Ot.createElement(wi,{...e})}))},executionDetailsSections:[Ci,Ue],validateFn:Si};t("spinnaker.amazon.pipeline.stage.Aws.LambdaDeleteStage",[]).config((function(){a.feature.lambdaAdditionalStages&&ze.pipeline.registerStage(ki)}));t("spinnaker.amazon.cloudformation.changetset.info.component",[]).component("cloudFormationChangeSetInfo",Xa(L((e=>{const{stage:t,stageconfig:a}=e,[n,r]=Ut(t.changeSetName?t.changeSetName:"ChangeSet-${execution['id']}"),[i,s]=Ut(t.executeChangeSet),[o,p]=Ut(t.actionOnReplacement);return Ot.createElement("div",null,Ot.createElement("hr",null),Ot.createElement("h4",null,"ChangeSet Configuration"),Ot.createElement(qe,{label:"ChangeSet Name"},Ot.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}})),Ot.createElement(qe,{label:"Execute ChangeSet"},Ot.createElement(d,{checked:i,onChange:e=>{return t=e.target.checked,s(t),void a.updateStageField({executeChangeSet:t});var t}})),i&&Ot.createElement(qe,{label:"If ChangeSet contains a replacement","help-key":"aws.cloudformation.changeSet.options"},Ot.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,p(t),void a.updateStageField({actionOnReplacement:t});var t}})))}),"cloudFormationChangeSetInfo"),["stage","stageconfig"]));class Ni{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()}}}Ni.$inject=["$scope"];const Ti={bindings:{command:"<",templateBody:"<"},controller:Ni,controllerAs:"ctrl",template:'\n <yaml-editor\n value="ctrl.rawTemplateBody"\n on-change="ctrl.handleChange"\n ></yaml-editor>'};t("spinnaker.amazon.cloudformation.entry.component",[]).component("cloudFormationTemplateEntry",Ti);class Gi extends Rt.Component{constructor(e){super(e)}render(){const{stage:e,current:t,name:a}=this.props;return Rt.createElement(Re,{name:a,current:t},Rt.createElement(We,{item:e}),Rt.createElement(Oe,{stage:e,message:e.failureMessage}))}}Gi.title="Task Status";class Ii{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((()=>{ga(this.$scope.pipeline,e)}))};const t={accounts:o.getAllAccountDetailsForProvider("aws"),artifactAccounts:o.getArtifactAccounts()};Ya.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}}Ii.$inject=["$scope"];const Ai=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),_n.evaluateCloudFormationChangeSetExecutionService.evaluateExecution(n,t,a,e)},p=e=>a.judgmentStatus===e||r&&s===e;return Ot.createElement("div",null,Ot.createElement("div",null,Ot.createElement("p",null,"This ChangeSet contains a replacement, which means there will be ",Ot.createElement("b",null,"potential data loss")," when executed."),Ot.createElement("p",null,"How do you want to proceed?"),Ot.createElement("div",{className:"action-buttons"},Ot.createElement("button",{className:"btn btn-danger",onClick:()=>{d("execute")},disabled:r},p("Execute")&&Ot.createElement(ae,{mode:"circular"}),a.context.stopButtonLabel||"Execute"),Ot.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("skip")}},p("Skip")&&Ot.createElement(ae,{mode:"circular"}),a.context.skipButtonLabel||"Skip"),Ot.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("fail")}},p("Fail")&&Ot.createElement(ae,{mode:"circular"}),a.context.FailButtonLabel||"Fail"))),o&&Ot.createElement("div",{className:"error-message"},"There was an error recording your decision. Please try again."))};class xi extends Rt.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 Rt.createElement(Re,{name:r,current:n},s?Rt.createElement(Ai,{key:a.refId,application:e,execution:t,stage:a}):Rt.createElement("div",null,l?Rt.createElement("div",null,Rt.createElement("dl",{className:"no-margin"},Rt.createElement("dt",null,"ChangeSet Name"),Rt.createElement("dd",null,a.context.changeSetName),Rt.createElement("dt",null,"Replacement"),Rt.createElement("dd",null,String(i)),a.context.changeSetExecutionChoice&&Rt.createElement("div",null,Rt.createElement("dt",null,"Judgment"),Rt.createElement("dd",null,a.context.changeSetExecutionChoice),Rt.createElement("dt",null,"Judged By"),Rt.createElement("dd",null,a.context.lastModifiedBy)))):Rt.createElement("div",null,"No changeSets found")))}}xi.title="Change Set Execution";class Pi extends Rt.Component{render(){if(!this.props.executionMarker)return Rt.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=Rt.createElement("div",null,Rt.createElement("div",null,Rt.createElement("b",null,e.name)),Rt.createElement(Ai,{stage:e.masterStage,application:this.props.application,execution:this.props.execution}));return Rt.createElement(ne,{template:t},this.props.children)}const t=Rt.createElement(Wa,{id:e.id},e.name);return Rt.createElement(ja,{placement:"top",overlay:t},Rt.createElement("span",null,this.props.children))}}class zi extends Rt.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,Rt.createElement("span",{className:"fa fa-child"})):null}}t("spinnaker.amazon.pipeline.stages.deployCloudFormationStage",[]).config((()=>{ze.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:[Gi,xi],executionLabelComponent:Pi,producesArtifacts:!0,supportsCustomTimeout:!0,validators:[],markerIcon:zi,accountExtractor:e=>e.account?[e.account]:[],configAccountExtractor:e=>e.account?[e.account]:[],artifactExtractor:Ke.accumulateArtifacts(["stackArtifactId","requiredArtifactIds"]),artifactRemover:Ye.removeArtifactFromFields(["stackArtifactId","requiredArtifactIds"])})})).controller("DeployCloudFormationStackConfigController",Ii),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 Di{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)))}}Di.$inject=["executionService"];function Bi(e,t){return Object.entries(t).forEach((([t,a])=>{var n;e[t]||ha(n=a)&&(Kt(n)||""===n)||(e[t]=a)})),e}function Fi(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 Ot.createElement("div",null,Ot.createElement(s,{label:"Account",name:"account",input:e=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("enableLambdaAtEdge",!1),e.formik.setFieldValue("region",t)},input:e=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.filter((e=>e.name===t.account)).flatMap((e=>e.regions)).map((e=>e.name))})}),Ot.createElement(s,{name:"functionUid",label:"Function Name",onChange:t=>{e.formik.setFieldValue("functionUid",t),a()},help:Ot.createElement(n,{id:"aws.function.name"}),input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"stackName",label:"Stack",help:Ot.createElement(n,{content:Fn}),onChange:t=>{e.formik.setFieldValue("stackName",t),a()},input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"detailName",label:"Detail",help:Ot.createElement(n,{content:Mn}),onChange:t=>{e.formik.setFieldValue("detailName",t),a()},input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"aliasNames",label:"Alias Name",help:Ot.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=>Ot.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}))):[]})}),Ot.createElement(s,{name:"runtime",label:"Runtime",help:Ot.createElement(n,{id:"aws.function.runtime"}),input:e=>Ot.createElement(c,{...e,stringOptions:Bn,clearable:!0})}),Ot.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Ot.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Ot.createElement(l,{...e,placeholder:"S3 bucket name"})}),Ot.createElement(s,{name:"s3key",label:"S3 Key",help:Ot.createElement(n,{id:"aws.function.s3key"}),input:e=>Ot.createElement(l,{...e,placeholder:"object.zip"})}),Ot.createElement(s,{name:"handler",label:"Handler",help:Ot.createElement(n,{id:"aws.function.handler"}),input:e=>Ot.createElement(l,{...e,placeholder:"filename.method"})}),Ot.createElement(s,{name:"publish",label:"Publish",help:Ot.createElement(n,{id:"aws.function.publish"}),input:e=>Ot.createElement(d,{...e})}))}t("spinnaker.amazon.deployCloudFormation.service",[Xe]).service("evaluateCloudFormationChangeSetExecutionService",Di);function Mi(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=jt(i.filter((e=>e.vpcId===t.vpcId)),"id"),p=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 Ot.createElement("div",null,Ot.createElement(s,{name:"vpcId",label:"VPC Id",input:e=>Ot.createElement(c,{...e,onChange:a,isLoading:"PENDING"===r,stringOptions:o,clearable:!0})}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Subnets ")),0===d.length?Ot.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC "):Ot.createElement("div",{className:"col-md-6"},Ot.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)}}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Security Groups ")),0===p.length?Ot.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC "):Ot.createElement("div",{className:"col-md-6"},Ot.createElement(f,{multi:!0,options:p,value:t.securityGroupIds,onChange:t=>{const a=t.map((e=>e.value));e.formik.setFieldValue("securityGroupIds",a)}}))))}function $i(){return Ot.createElement(s,{name:"role",label:"Role ARN",input:e=>Ot.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"})})}function Li(e){const{values:t}=e.formik;return Ot.createElement("div",null,Ot.createElement(s,{name:"triggerArns",label:"Event ARNs",help:Ot.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=>Ot.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}))):[]})}),Ot.createElement(s,{name:"batchsize",label:"Event Batch Size",input:e=>Ot.createElement(u,{...e,min:1,max:1e3})}))}const Ri="Validate AWS Lambda function configuration against Lambda@Edge requirements. This will not enable Lambda@Edge on this function. ";function Oi(e){const{values:t}=e.formik;return"us-east-1"!==t.region?Ot.createElement("div",{className:"horizontal center"},"Lambda@Edge is only available in region us-east-1."):Ot.createElement("div",null,Ot.createElement(s,{name:"enableLambdaAtEdge",label:"Enable Lambda@Edge Validation",help:Ot.createElement(n,{content:Ri}),input:e=>Ot.createElement(d,{...e})}))}function Ui(e){const{values:t,errors:a}=e.formik,r=ka({well:!0,"alert-danger":!!a.functionName,"alert-info":!a.functionName});return Ot.createElement("div",{className:"form-horizontal"},Ot.createElement("div",{className:r},Ot.createElement("strong",null,"Your function will be named: "),Ot.createElement(n,{id:"aws.function.name"}),Ot.createElement("span",null,t.functionName?t.functionName:e.application.name),Ot.createElement(s,{name:"functionName",input:()=>null})),Ot.createElement("h4",null,"Basic Settings"),Ot.createElement(Fi,{...e}),Ot.createElement("h4",null," Execution Role "),Ot.createElement($i,null),Ot.createElement("h4",null," Environment "),!0!==t.enableLambdaAtEdge?Ot.createElement(Ot.Fragment,null,Ot.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Ot.createElement(p,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Ot.createElement(s,{name:"encryptionKMSKeyArn",label:"Key ARN",help:Ot.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Ot.createElement(l,{...e})})):Ot.createElement("div",{className:"horizontal center"},"Environment variables not available with Lambda@Edge functions."),Ot.createElement("h4",null," Tags "),Ot.createElement(s,{name:"tags",input:e=>Ot.createElement(p,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}),Ot.createElement("h4",null," Settings "),Ot.createElement(s,{name:"description",label:"Description",input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"layers",label:"Layer ARNs",help:Ot.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=>Ot.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}))):[]})}),Ot.createElement(s,{name:"reservedConcurrentExecutions",label:"Reserved Concurrency",help:Ot.createElement(n,{content:"The total number of current executions of your Lambda function that can be instantiated at any time."}),input:e=>Ot.createElement(u,{...e,min:0,max:3e3})}),Ot.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Ot.createElement(u,{...e,min:128,max:!0===t.enableLambdaAtEdge?128:3008})}),Ot.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Ot.createElement(u,{...e,min:1,max:!0===t.enableLambdaAtEdge?5:900})}),Ot.createElement(Oi,{...e}),Ot.createElement("h4",null," Network "),!0!==t.enableLambdaAtEdge?Ot.createElement(Mi,{...e}):Ot.createElement("div",{className:"horizontal center"},"VPC configuration not available with Lambda@Edge functions."),Ot.createElement("h4",null," Event Triggers "),Ot.createElement(Li,{...e}),Ot.createElement("h4",null," Debugging and Error Handling "),"Dead Letter Config",Ot.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Ot.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Ot.createElement(l,{...e})}),"X-Ray Tracing",Ot.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Ot.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Ot.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}function Vi(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(zn),t.field("detailName","Detail Name").optional().withValidators(zn),t.field("s3bucket","S3 Bucket Name").required().withValidators(An),t.field("role","Role ARN").required().withValidators(In),t.field("triggerArns","Trigger ARNs").optional().withValidators(((e,t)=>e.map((e=>xn(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 qi(e){const{stage:t,current:a,name:n}=e;return Ot.createElement(Re,{name:n,current:a},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," ",Ot.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Ot.createElement("p",null," ",Ot.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}(qi||(qi={})).title="Lambda Deployment Stage";const Hi={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 Ot.createElement("div",{className:"LambdaDeploymentConfig"},Ot.createElement(Ve,{...e,stage:Bi(e.stage,t),validate:Vi,onChange:e.updateStage,render:e=>Ot.createElement(Ui,{...e})}))},executionDetailsSections:[qi,Ue],validateFn:Vi};t("spinnaker.amazon.pipeline.stage.Aws.LambdaDeploymentStage",[]).config((function(){a.feature.lambdaAdditionalStages&&ze.pipeline.registerStage(Hi)}));t("spinnaker.amazon.pipeline.stage.aws.destroyAsgStage",[]).config((function(){ze.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')}]);t("spinnaker.amazon.pipeline.stage.disableAsgStage",[]).config((function(){ze.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')}]);t("spinnaker.amazon.pipeline.stage.disableClusterStage",[]).config((function(){ze.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')}]);t("spinnaker.amazon.pipeline.stage.enableAsgStage",[]).config((function(){ze.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')}]);e.module("spinnaker.amazon.pipeline.stage.findAmiStage",[]).config((function(){ze.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')}]);function Wi(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 Ot.createElement("div",null,Ot.createElement(s,{name:"timeout",label:"Timeout",input:e=>Ot.createElement(u,{...e,min:0,max:900})}),Ot.createElement(s,{name:"executionCount",label:"Execution Count",input:e=>Ot.createElement(u,{...e,min:0,max:100})}),Ot.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 ji(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 Ot.createElement("div",{className:"form-horizontal"},Ot.createElement("h4",null," Basic Settings "),Ot.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=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===r,stringOptions:n.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Ot.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))})}),Ot.createElement(s,{label:"Function Name",name:"functionName",input:e=>Ot.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:i})}),Ot.createElement(s,{label:"Alias",name:"aliasName",input:e=>Ot.createElement(l,{...e})}),Ot.createElement("h4",null," Invoke Settings "),Ot.createElement(Wi,{...e}))}function Zi(e){const{stage:t}=e;return Ot.createElement(Re,{name:e.name,current:e.current},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," Function Name: ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Ot.createElement("p",null," ","Deployed Alias:"," ",t.outputs["deployment:aliasDeployed"]?t.outputs["deployment:aliasDeployed"]:"N/A"," "),Ot.createElement("p",null," ","Deployed Major Version:"," ",t.outputs["deployment:majorVersionDeployed"]?t.outputs["deployment:majorVersionDeployed"]:"N/A"," ")))}function _i(e){const t=new i(e);return t.field("triggerArns","Trigger ARNs").optional().withValidators(((e,t)=>e.map((e=>xn(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("spinnaker.amazon.pipeline.stage.findImageFromTagsStage",[]).config((function(){ze.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')}]),(Zi||(Zi={})).title="Invoke Lambda Stage";const Ki={key:"Aws.LambdaInvokeStage",label:"AWS Lambda Invoke",description:"Invoke a Lambda function",component:function(e){return Ot.createElement("div",{className:"InvokeLambdaStageConfig"},Ot.createElement(Ve,{...e,validate:_i,onChange:e.updateStage,render:e=>Ot.createElement(ji,{...e})}))},executionDetailsSections:[Zi,Ue],validateFn:_i};t("spinnaker.amazon.pipeline.stage.Aws.LambdaInvokeStage",[]).config((function(){a.feature.lambdaAdditionalStages&&ze.pipeline.registerStage(Ki)}));t("spinnaker.amazon.pipeline.stage.modifyScalingProcessStage",[]).config((function(){ze.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')}]);t("spinnaker.amazon.pipeline.stage.aws.resizeAsgStage",[]).config((function(){ze.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')}]);t("spinnaker.amazon.pipeline.stage.rollbackClusterStage",[]).config((function(){ze.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')}]);t("spinnaker.amazon.pipeline.stage.scaleDownClusterStage",[]).config((function(){ze.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')}]);t("spinnaker.amazon.pipeline.stage.aws.shrinkClusterStage",[]).config((function(){ze.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')}]);function Yi(e){const{values:t}=e.formik,{functions:a}=e.application,{result:r,status:i}=F((()=>o.listAccounts("aws")),[],[]),p=t.account&&t.region?a.data.filter((e=>e.account===t.account)).filter((e=>e.region===t.region)).map((e=>e.functionName)):[];return Ot.createElement("div",{className:"form-horizontal"},Ot.createElement("h4",null," Basic Settings "),Ot.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=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Ot.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))})}),Ot.createElement(s,{label:"Function Name",name:"functionName",input:e=>Ot.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:p})}),Ot.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Ot.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Ot.createElement(l,{...e,placeholder:"S3 bucket name"})}),Ot.createElement(s,{name:"s3key",label:"S3 Key",help:Ot.createElement(n,{id:"aws.function.s3key"}),input:e=>Ot.createElement(l,{...e,placeholder:"object.zip"})}),Ot.createElement(s,{name:"publish",label:"Publish",help:Ot.createElement(n,{id:"aws.function.publish"}),input:e=>Ot.createElement(d,{...e})}))}t("spinnaker.amazon.pipeline.stage.tagImageStage",[]).config((function(){ze.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 Xi(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(An),t.validateForm()}function Ji(e){const{stage:t,current:a,name:n}=e;return Ot.createElement(Re,{name:n,current:a},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," ",Ot.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Ot.createElement("p",null," ",Ot.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}yr(""),(Ji||(Ji={})).title="Lambda Update Code Stage";const Qi={key:"Aws.LambdaUpdateCodeStage",label:"AWS Lambda Update Code",description:"Update code for a single AWS Lambda Function",component:function(e){return Ot.createElement("div",{className:"LambdaUpdateCodeConfig"},Ot.createElement(Ve,{...e,validate:Xi,onChange:e.updateStage,render:e=>Ot.createElement(Yi,{...e})}))},executionDetailsSections:[Ji,Ue],validateFn:Xi};t("spinnaker.amazon.pipeline.stage.Aws.LambdaUpdateCodeStage",[]).config((function(){a.feature.lambdaAdditionalStages&&ze.pipeline.registerStage(Qi)}));t("spinnaker.amazon.react",[]).run(["$injector",function(e){_n.initialize(e)}]);t("spinnaker.amazon.search.searchResultFormatter",[]).factory("awsSearchResultFormatter",(function(){return{securityGroups:function(e){return Vn.getVpcName(e.vpcId).then((function(t){const a=t?e.region+" - "+t.toLowerCase():e.region;return e.name+" ("+a+")"}))}}}));t("spinnaker.amazon.securityGroup.baseConfig.controller",[tn,Ie]).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 p(){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 u(){e.availableSecurityGroups=[],e.existingSecurityGroupNames=[]}function m(){e.state.refreshTime=Ne.get("securityGroups").getStats().ageMax}e.taskMonitor=new v({application:n,title:`Creating your ${V.get("firewall")}`,modalInstance:a,onTaskComplete:function(){n.securityGroups.refresh(),n.securityGroups.onNextRefresh(e,p)}}),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)),u(),c.regionUpdated(),e.state.isNew&&c.updateName()}))},c.regionUpdated=function(){const t=d(),a=e.securityGroup.regions||[];Vn.listVpcs().then((function(n){const r=qt.groupBy(n.filter((e=>e.account===t)),"label");e.allVpcs=n;const i=[];qt.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=Sn.classicLaunchLockout;if(!r.id&&a){if(Number(qt.get(n,"attributes.createTs",0))>=a&&(e.hideClassic=!0,!r.vpcId&&t.length)){let a;if(Sn.defaults.vpc){const e=t.find((e=>e.label===Sn.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=>Sn.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=qt.find(e.allVpcs,{id:t});s=qt.find(e.allVpcs,{account:a,region:n,name:r.name}).id}const o=qt.get(l,[a,"aws",n].join("."),[]).filter((e=>e.vpcId===s)).map((e=>e.name));r=qt.uniq(r.concat(o)),i=i.length?qt.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")}()}():u(),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 Na,e.coordinatesChanged=new Na,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?qt.filter(t[a].aws[n],{vpcId:r}):t,e.availableSecurityGroups=qt.map(i,"name");const s=Sn.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")}}]);e.module("spinnaker.amazon.securityGroup.clone.controller",["spinnaker.amazon.securityGroup.baseConfig.controller"]).controller("awsCloneSecurityGroupController",["$scope","$uibModalInstance","$controller","securityGroup","application",function(t,a,n,r,i){const s=this;s.firewallLabel=V.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=qt.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=qt.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')}]);e.module("spinnaker.amazon.securityGroup.create.controller",[tn,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=>V.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')}]);e.module("spinnaker.amazon.securityGroup.edit.controller",[tn]).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 ${V.get("firewall")}`,modalInstance:a,onTaskComplete:()=>r.securityGroups.refresh()}),i.securityGroupIngress=qt.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=qt.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 es={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=Sn)?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=ia(n.concat(d)),r=r.length?fa(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)}}}};t("spinnaker.amazon.securityGroup.configure.ingressRuleGroupSelector",[]).component("ingressRuleGroupSelector",es),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 ts=Object.defineProperty,as=Object.getOwnPropertyDescriptor;let ns=class extends Ot.Component{render(){return null}};ns=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?as(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&&ts(t,a,i),i})([ie("aws.securityGroup.details.custom")],ns);t("spinnaker.amazon.securityGroups.details.custom.component",[]).component("securityGroupDetailsCustom",Xa(L(ns,"securityGroupDetailsCustom"),["securityGroupDetails","ctrl","scope"]));e.module("spinnaker.amazon.securityGroup.details.controller",[tn,Ie,"spinnaker.amazon.securityGroup.clone.controller",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 Vn.getVpcName(e.vpcId).then((t=>(e.vpcName=t,e)))})).then((function(a){if(t.state.loading=!1,!a||qt.isEmpty(a))p();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=qt.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=qt.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)}}),p)}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 p(){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=V.get("Firewall"),t.detailsTemplateUrl=U.getValue("aws","securityGroup.detailsTemplateUrl"),t.isDisabled=!Sn.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 ${V.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 rs=Object.defineProperty,is=Object.getOwnPropertyDescriptor;let ss=class extends Ot.Component{render(){const e=this.props.ipRules||[],t=`IP Range Rules (${e.length})`;return Ot.createElement(x,{heading:t},e.map((e=>Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},Ot.createElement(D,{label:"IP Range",value:e.address}),Ot.createElement(D,{label:"Port Ranges",value:e.rules.map((t=>"-1"===t.protocol?Ot.createElement("span",null,"All ports and protocols",e.rules.length>1?Ot.createElement("div",null,Ot.createElement("em",null,"Additional port ranges are specified, but redundant:")):null):Ot.createElement("div",null,Ot.createElement("span",null,t.protocol,":",t.startPort," → ",t.endPort))))})))))}};ss=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?is(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&&rs(t,a,i),i})([ie("aws.securityGroup.ip.rules")],ss);t("spinnaker.amazon.securityGroups.details.securityGroups.component",[]).component("ipRangeRules",Xa(L(ss,"ipRangeRules"),["ipRules"]));class ls{resolveIndexedSecurityGroup(e,t,a){return ls.resolveIndexedSecurityGroup(e,t,a)}static resolveIndexedSecurityGroup(e,t,a){return e[t.account][t.region][a]}}t("spinnaker.amazon.securityGroup.reader",[]).service("awsSecurityGroupReader",ls);t("spinnaker.amazon.securityGroup.transformer",[]).factory("awsSecurityGroupTransformer",(function(){return{normalizeSecurityGroup:function(e){return Vn.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=na(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}}));t("spinnaker.amazon.securityGroup",["spinnaker.amazon.securityGroup.reader","spinnaker.amazon.securityGroup.clone.controller","spinnaker.amazon.securityGroup.configure.ingressRuleGroupSelector","spinnaker.amazon.securityGroup.baseConfig.controller","spinnaker.amazon.securityGroup.create.controller","spinnaker.amazon.securityGroup.edit.controller","spinnaker.amazon.securityGroup.details.controller","spinnaker.amazon.securityGroup.transformer","spinnaker.amazon.securityGroups.details.securityGroups.component","spinnaker.amazon.securityGroups.details.custom.component"]);class os extends Ot.Component{constructor(e){super(e),this.state={templateSelectionText:{copied:["account, region, subnet, cluster name (stack, details)","load balancers",V.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 Ot.createElement(ot,{cloudProvider:"aws",application:e,command:t,onDismiss:a,onTemplateSelected:n,templateSelectionText:r})}}class cs extends Ot.Component{constructor(){super(...arguments),this.state={errorMessage:null,selectionMode:"packageImages",searchString:"",searchResults:null,isSearching:!1,packageImages:null,isLoadingPackageImages:!0},this.awsImageReader=new Qn,this.props$=new Na,this.searchInput$=new Na,this.destroy$=new Na,this.sortImagesBy$=new Ia("ts"),this.buildImageMenu=e=>{const{ImageMenuHeading:t,ImageLabel:a}=this,{options:n}=e;return Ot.createElement("div",{className:"Select-menu-outer"},Ot.createElement("div",{className:"Select-menu",role:"listbox"},n.length>0&&Ot.createElement(t,null),n.map((t=>Ot.createElement(a,{key:t.imageName,option:t,params:e})))))},this.ImageMenuHeading=()=>{const e=this.sortImagesBy$.value;return Ot.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)"}},Ot.createElement("b",null,"Sort by: "),Ot.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("ts")},"ts"===e?Ot.createElement("b",null,"timestamp (newest first)"):"timestamp (newest first)"),Ot.createElement("span",null," | "),Ot.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("name")},"name"===e?Ot.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 Ot.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"},Ot.createElement("div",null,n.imageName),Ot.createElement("div",{className:"small"},Ot.createElement("b",null,"Created: "),n.attributes.creationDate,Ot.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)):Ya.when(null)}searchForImages(e){return e&&e.length>=3?this.awsImageReader.findImages({q:e}):Ya.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(Pa((e=>e.region)),za()),{value:t,region:a,credentials:n,application:r}=this.props;this.setState({isLoadingPackageImages:!0});const i=this.fetchPackageImages(t,a,n,r),s=Ta(i).pipe(Ra((e=>(console.error(e),this.setState({errorMessage:"Unable to load package images"}),Aa([])))),$a((()=>this.setState({isLoadingPackageImages:!1})))),l=Ga([s,e,this.sortImagesBy$]).pipe(Pa((([e,t,a])=>{const n=e.filter((e=>!!e.amis[t]));return this.sortImages(n,a)}))),o=this.searchInput$.pipe($a((e=>this.setState({searchString:e}))),za(),Oa(250)).pipe($a((()=>this.setState({isSearching:!0}))),Ba((e=>this.searchForImages(e))),Ra((e=>(console.error(e),this.setState({errorMessage:"Unable to search for images"}),Aa([])))),$a((()=>this.setState({isSearching:!1}))));Ga([o,e,this.sortImagesBy$]).pipe(Pa((([e,t,a])=>{const{searchString:n}=this.state;if(0===e.length&&/ami-[0-9a-f]{8,17}/.exec(n)){return[cs.makeFakeImage(n,n,t)].filter((e=>!!e))}const r=e.filter((e=>!!e.amis[t]));return this.sortImages(r,a)}))).pipe(Ma(this.destroy$)).subscribe((e=>this.setState({searchResults:e}))),l.pipe(Ma(this.destroy$)).subscribe((e=>{this.setState({packageImages:e}),this.selectImage(this.findMatchingImage(e,this.props.value))})),e.pipe(Ba((e=>{const t=this.props.value;if("packageImages"===this.state.selectionMode)return l.pipe(Pa((e=>this.findMatchingImage(e,t))));{const a=!!(t&&t.amis&&t.amis[e]);return Aa(a?t:void 0)}})),Ma(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,p=!!o,u=e=>{const n=e.amis||{},r=n[a]&&n[a][0],i=r?`(${r})`:` - not found in ${t}/${a}`;return Ot.createElement(Ot.Fragment,null,Ot.createElement("span",null,e.imageName),Ot.createElement("span",null,i))},m={clearable:!1,required:!0,valueKey:"imageName",optionRenderer:u,valueRenderer:u,onSelectResetsInput:!1,onBlurResetsInput:!1,onCloseResetsInput:!1,value:e},g=this.state.errorMessage?Ot.createElement(ue,{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 Ot.createElement("div",{className:"col-md-9"},Ot.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 p?Ot.createElement("div",{className:"col-md-9"},Ot.createElement(f,{...m,menuRenderer:this.buildImageMenu,isLoading:i,placeholder:"Pick an image",noResultsText:h,options:o,onChange:r}),g,Ot.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Ot.createElement(n,{id:"aws.serverGroup.allImages"})):Ot.createElement("div",{className:"col-md-9"},Ot.createElement(f,{...m,isLoading:i,disabled:!0,options:[e].filter((e=>!!e))}),g,Ot.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Ot.createElement(n,{id:"aws.serverGroup.allImages"}))}}const ds=e=>e&&e.includes("${");class ps extends Ot.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=Sn.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,p;const{setFieldValue:u,values:m}=this.props.formik;m.credentials=e,m.credentialsChanged(m),m.subnetChanged(m),u("credentials",e);const g=m.backingData.credentialsKeyedByAccount[e];if(u("associateIPv6Address",(null==(a=null==(t=Sn)?void 0:t.serverGroups)?void 0:a.enableIPv6)&&(null==(r=null==(n=Sn)?void 0:n.serverGroups)?void 0:r.setIPv6InTest)&&"test"===g.environment),null==(i=Sn.serverGroups)?void 0:i.enableIMDSv2){const t=!(null==(o=null==(l=null==(s=Sn)?void 0:s.serverGroups)?void 0:l.accountDenyListIMDSv2)?void 0:o.includes(e)),a=null==(c=Sn.serverGroups)?void 0:c.defaultIMDSv2AppAgeLimit,n=null==(p=null==(d=this.props.app)?void 0:d.attributes)?void 0:p.createTs;u("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=cs.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,ds(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,ds(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 Ot.createElement("div",{className:"container-fluid form-horizontal"},r.regionIsDeprecated(r)&&Ot.createElement("div",{className:"form-group row"},Ot.createElement("div",{className:"col-md-12 error-message"},Ot.createElement("div",{className:"alert alert-danger"},"You are deploying into a deprecated region within the ",r.credentials," account!"))),Ot.createElement(ct,{app:e,formik:t}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Ot.createElement("div",{className:"col-md-7"},Ot.createElement(Se,{value:r.credentials,onChange:e=>this.accountUpdated(e.target.value),readOnly:c.credentials,accounts:o,provider:"aws"}))),Ot.createElement(ke,{readOnly:c.region,labelColumns:3,component:r,field:"region",account:r.credentials,regions:r.backingData.filtered.regions,onChange:this.regionUpdated}),Ot.createElement(Yr,{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}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Ot.createElement(n,{id:"aws.serverGroup.stack"})),Ot.createElement("div",{className:"col-md-7"},Ot.createElement("input",{type:"text",className:"form-control input-sm no-spel",value:r.stack,onChange:e=>this.stackChanged(e.target.value)}))),a.stack&&Ot.createElement("div",{className:"form-group row slide-in"},Ot.createElement("div",{className:"col-sm-9 col-sm-offset-2 error-message"},Ot.createElement("span",null,a.stack))),Ot.createElement(dt,{app:e,formik:t}),r.viewState.imageSourceText&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Image Source"),Ot.createElement("div",{className:"col-md-7",style:{marginTop:"5px"}},Ot.createElement(Ce,{tag:"span",message:r.viewState.imageSourceText}))),!r.viewState.disableImageSelection&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Image ",Ot.createElement(n,{id:"aws.serverGroup.imageName"})),ds(r.amiName)?Ot.createElement(dn,{name:"amiName"}):Ot.createElement(cs,{onChange:e=>this.imageChanged(e),value:this.state.selectedImage,application:e,credentials:r.credentials,region:r.region})),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Traffic ",Ot.createElement(n,{id:"aws.serverGroup.traffic"})),Ot.createElement("div",{className:"col-md-9 checkbox"},Ot.createElement("label",null,Ot.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&&Ot.createElement(pt,{command:r,onFieldChange:this.onStrategyFieldChange,onStrategyChange:this.strategyChanged}),!r.viewState.hideClusterNamePreview&&Ot.createElement(ut,{createsNewCluster:i,latestServerGroupName:null==s?void 0:s.name,mode:r.viewState.mode,namePreview:l,navigateToLatestServerGroup:this.navigateToLatestServerGroup}),Ot.createElement(mt,{reason:r.reason,onChange:this.handleReasonChanged}))}}class us extends Ot.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?Ot.createElement("div",null,Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("p",null,"Sets up auto-scaling constraints for this server group."),Ot.createElement("p",null,"To set min, max, and desired instance counts to the same value use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!0)},"Simple Mode"),"."))),!a.useSourceCapacity&&"editPipeline"===e.viewState.mode&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Capacity"),Ot.createElement("div",{className:"col-md-9 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:e.useSourceCapacity,value:"true",id:"useSourceCapacityTrue",onChange:this.useSourceCapacityUpdated}),"Copy the capacity from the current server group",Ot.createElement(n,{id:"serverGroupCapacity.useSourceCapacityTrue"}))),e.useSourceCapacity&&Ot.createElement("div",{className:"col-md-9 col-md-offset-3 radio",style:{paddingLeft:"35px"}},Ot.createElement("div",null,"If no current server group is found,",Ot.createElement(nn,{clearable:!1,value:!!e.preferSourceCapacity,options:this.preferSourceCapacityOptions,onChange:this.preferSourceCapacityChanged})),e.preferSourceCapacity&&Ot.createElement("div",null,Ot.createElement("b",null,"Fallback values"),Ot.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged}))),Ot.createElement("div",{className:"col-md-9 col-md-offset-3 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:!e.useSourceCapacity,value:"false",id:"useSourceCapacityFalse",onChange:this.useSourceCapacityUpdated}),"Let me specify the capacity",Ot.createElement(n,{id:"serverGroupCapacity.useSourceCapacityFalse"})))),(!e.useSourceCapacity||"editPipeline"!==e.viewState.mode)&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-9 col-md-offset-3"},Ot.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged})))):Ot.createElement("div",null,Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("p",null,"Sets the min, max, and desired instance counts to the same value."),Ot.createElement("p",null," ","To set capacity for auto-scaling, use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!1)},"Advanced Mode"),"."))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Number of Instances"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(ve,{value:e.capacity.desired,min:0,onChange:this.simpleInstancesChanged}))))}}class ms extends Ot.Component{render(){const{command:{capacity:{min:e,max:t,desired:a}},fieldChanged:n}=this.props;return Ot.createElement("div",null,Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-2"},"Min"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(ve,{value:e,min:0,max:"number"==typeof t?t:void 0,onChange:e=>n("min",e),required:!0}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-2"},"Max"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(ve,{value:t,min:"number"==typeof e?e:void 0,onChange:e=>n("max",e),required:!0}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-2"},"Desired"),Ot.createElement("div",{className:"col-md-8"},Ot.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 gs extends Ot.Component{validate(e){const t={};(e.capacity.min<0||e.capacity.max<0||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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement(us,{command:t,setFieldValue:e,MinMaxDesired:ms}))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("div",{className:"form-group form-inline",style:{marginTop:"20px"}},Ot.createElement("div",{className:"col-md-12"},"Consider deployment successful when"," ",Ot.createElement(dn,{type:"number",name:"targetHealthyDeployPercentage",min:"0",max:"100",className:"form-control input-sm inline-number",required:!0})," ","percent of instances are healthy.")))))}}function hs(e){return Ot.createElement("div",null,Ot.createElement("h4",{style:{marginTop:"10px"}},"This application is"),e.instanceProfileList.map((t=>Ot.createElement("div",{key:t.type,className:"instance-profile-header profile-button"},Ot.createElement("button",{type:"button",onClick:()=>e.handleProfileChange(t.type),className:e.currentProfile===t.type?"instance-profile active":"instance-profile"},e.currentProfile===t.type&&Ot.createElement("span",{className:"far fa-check-circle selected-indicator"}),Ot.createElement("div",{className:"panel-heading"},Ot.createElement("h4",null,Ot.createElement("span",{className:`glyphicon glyphicon-${t.icon}`}),Ot.createElement("div",null,t.label))))))))}function fs(e){const{selectedInstanceTypes:t,currentProfile:a}=e,n=_n.awsInstanceTypeService.isBurstingSupportedForAllTypes(t),r=!!_n.awsInstanceTypeService.getInstanceTypesInCategory(t,a).length,[i,s]=Ut(!1);return Vt((()=>{t&&t.length&&(n||e.setUnlimitedCpuCredits(void 0),s(n)),a&&s(t&&t.length>0&&n&&r)}),[a,t]),Ot.createElement("div",{className:"row",style:{fontSize:"110%"}},i&&Ot.createElement("div",null,Ot.createElement(gt,{toggleSize:ht.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 vs(e){var t,a,n,r,i,s,l,o,c,d,p,u,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":"",G=`${null==(n=e.instanceType)?void 0:n.defaultVCpus} vCPU | ${null==(r=e.instanceType)?void 0:r.memoryInGiB} Gib Memory ${T}`,I=(null==(i=e.instanceType)?void 0:i.instanceStorageSupported)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.createElement("span",{className:"select-option-label-attributes"},`Instance Storage: ${qt.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)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.createElement("span",{className:"select-option-label-attributes"},`EBS: optimization ${null==(u=null==(p=e.instanceType)?void 0:p.ebsInfo)?void 0:u.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)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.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)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.createElement("span",{className:"select-option-label-attributes"},(null==(k=e.instanceType)?void 0:k.currentGeneration)?"Current Generation":"Previous Generation"));return Ot.createElement("span",null,Ot.createElement("span",{className:"select-option-label"},null==(N=e.instanceType)?void 0:N.name),Ot.createElement("br",null),Ot.createElement("span",{className:"select-option-label-attributes"},G),I,A,x,P)}yr(".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 ys=({min:e,max:t})=>{const a=Ot.createElement(Ot.Fragment,null,Ot.createElement("span",{className:"cost"},"$".repeat(e)),"$".repeat(4-e)),n=Ot.createElement(Ot.Fragment,null,Ot.createElement("span",{className:"cost"},"$".repeat(Math.min(4,t))),"$".repeat(4-Math.min(4,t)));return Ot.createElement("span",{className:"cost-factor"},a,t?` - ${n}`:"")};function bs(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 p;if(e.isCustom){const a=Ot.createElement(vs,{instanceType:e.selectedTypeInfo});p=Ot.createElement("tr",{key:s,className:"sortable clickable"},Ot.createElement("td",null,Ot.createElement(Es,null)),Ot.createElement("td",null,`${s} `,Ot.createElement(ne,{placement:"right",template:a,className:"custom-profile"},Ot.createElement("span",{className:"clickable help-field"},Ot.createElement("i",{className:"small glyphicon glyphicon-info-sign"})))),Ot.createElement("td",{title:"Enter optional weight (allowed values: 1 to 999)."},Ot.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)})),Ot.createElement("td",null,Ot.createElement("div",null,Ot.createElement("span",null,Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeInstanceType(s),style:{padding:"5px"}},Ot.createElement(_,{value:"Remove instance type"},Ot.createElement("span",{className:"glyphicon glyphicon-trash"})))))))}else{const{cpu:t,memory:i,cpuCreditsPerHour:u,storage:m,costFactor:g}=e.instanceTypeDetails;p=Ot.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?Ot.createElement("td",null,Ot.createElement(Es,null)):Ot.createElement("td",null),Ot.createElement("td",null,Ot.createElement(Za,{id:`selectInstanceType-${s}`,checked:!!n,disabled:o,onChange:()=>{n?e.removeInstanceType(s):c(s,r)}})),Ot.createElement("td",null,s),Ot.createElement("td",null,t),Ot.createElement("td",null,i),u?Ot.createElement("td",null,u):Ot.createElement("td",{title:"Cpu credits not applicable to instance type."},"-"),"EBS"===m.type&&Ot.createElement("td",null,"EBS Only"),"SSD"===m.type&&Ot.createElement("td",null,m.count+"x"+m.size),Ot.createElement("td",null,Ot.createElement(ys,{min:g})),Ot.createElement("td",{title:o?"":"Enter optional weight (allowed values: 1 to 999)."},Ot.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 p}const Es=rn((()=>Ot.createElement(_,{value:"Drag to change priority"},Ot.createElement("span",{className:"instance-type-drag-handle glyphicon glyphicon-resize-vertical"}))));function ws(e){return Ot.createElement(Cs,{isCustom:e.isCustom,selectedInstanceTypesMap:e.selectedInstanceTypesMap,selectedInstanceTypesInfo:e.selectedInstanceTypesInfo,removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType,instanceTypeDetails:e.isCustom?null:new Map(Object.entries(va(_t(e.profileFamiliesDetails.map((e=>e.instanceTypes))),"name"))),onSortEnd:t=>e.handleSortEnd(t),distance:1})}const Cs=on((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)=>Ot.createElement(Ss,{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=sa(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)=>Ot.createElement(Ss,{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=>Ot.createElement(bs,{key:a,isCustom:!1,instanceTypeDetails:t.get(a),addOrUpdateInstanceType:e.addOrUpdateInstanceType})))}return Ot.createElement("tbody",null,n,t?null:r)})),Ss=ln((e=>Ot.createElement(bs,{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 ks(e){return Ot.createElement("div",{className:"custom-profile"},Ot.createElement(nn,{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=>Ot.createElement(vs,{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=qt.toLower(e.trim());return t.match(/\d+\s*vcpu/)&&n>=qt.toNumber(t.split("vcpu")[0].trim())||t.match(/\d+\s*gib/)&&r>=qt.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=>Ot.createElement(Ot.Fragment,null,e.name),onChange:t=>e.addOrUpdateInstanceType(t.name,void 0)})," ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypesSelect"}))}function Ns(e){let t;return t=e.isCustom?Ot.createElement("p",null,"Choose the instance types that best suit the needs of your application."):Ot.createElement(Ot.Fragment,null,Ot.createElement("p",null,Ot.createElement("b",null,e.profileLabel)),Ot.createElement("ul",null,e.profileDescriptionArr.map(((e,t)=>Ot.createElement("li",{key:t},e))))),Ot.createElement("div",{className:"row sub-section"},Ot.createElement("h4",null,"Instance Types"),Ot.createElement("div",{className:"description"},t,Ot.createElement("p",null,"Learn about AWS recommended best practices in"," ",Ot.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"),"."),Ot.createElement("i",null,Ot.createElement("b",null,"Note:"),Ot.createElement("ul",null,Ot.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."),Ot.createElement("li",null,"Some instance types might not be available for the selected configuration.")))))}function Ts(e){let t,a,r,i;return e.isCustom?(t=Ot.createElement("th",null),a=Ot.createElement("th",null,"Instance Type ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypes"})),r=null,i=Ot.createElement("th",null)):(t=Ot.createElement(Ot.Fragment,null,Ot.createElement("th",null),Ot.createElement("th",null)),a=Ot.createElement("th",null,"InstanceType"),r=Ot.createElement(Ot.Fragment,null,Ot.createElement("th",null,"vCPU"),Ot.createElement("th",null,"Mem (GiB)"),e.showCpuCredits&&Ot.createElement("th",null,"CPU Credits"),Ot.createElement("th",null,"Storage (GB)",Ot.createElement(n,{id:"aws.serverGroup.storageType"})),Ot.createElement("th",null,"Cost")),i=null),Ot.createElement("thead",null,Ot.createElement("tr",null,t,a,r,Ot.createElement("th",null,"Weight ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})),i))}function Gs(e){return e.isCustom?Ot.createElement("tfoot",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign",style:{paddingTop:"8px"}})),Ot.createElement("td",{colSpan:2},Ot.createElement(ks,{availableInstanceTypesList:e.availableInstanceTypesList,addOrUpdateInstanceType:e.addOrUpdateInstanceType})),Ot.createElement("td",null))):null}function Is(e){return e.dirty.instanceType||e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0?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"}),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:"),Ot.createElement("ul",null,e.dirty.instanceType&&Ot.createElement("li",{key:e.dirty.instanceType},e.dirty.instanceType),e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0&&e.dirty.launchTemplateOverridesForInstanceType.map((e=>Ot.createElement("li",{key:e.instanceType},e.instanceType,e.weightedCapacity?" with weight "+e.weightedCapacity:"")))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>e.clearWarnings()},"Okay")))):null}function As(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=sn(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=Sn.serverGroups)?void 0:t.enableCpuCredits,c=Array.from(n.keys()),d=Ot.createElement("div",null,Ot.createElement(fs,{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,p=!1;return Ot.createElement("div",{className:"row sub-section"},Ot.createElement(Ns,{isCustom:p,profileLabel:t,profileDescriptionArr:a||i.map((e=>e.description))}),Ot.createElement(Is,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Ot.createElement("table",{className:"table table-hover"},Ot.createElement(Ts,{isCustom:p,showCpuCredits:c}),Ot.createElement(ws,{isCustom:p,profileFamiliesDetails:i,selectedInstanceTypesMap:n,addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r})))}{const t=!0;return Ot.createElement("div",{className:"row sub-section"},Ot.createElement(Ns,{isCustom:t}),Ot.createElement(Is,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Ot.createElement("table",{className:"table table-hover"},Ot.createElement(Ts,{isCustom:t}),Ot.createElement(ws,{isCustom:t,selectedInstanceTypesMap:n,selectedInstanceTypesInfo:e.availableInstanceTypesList.filter((e=>c.includes(e.name))),addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r}),Ot.createElement(Gs,{isCustom:t,availableInstanceTypesList:e.availableInstanceTypesList.filter((e=>!c.includes(e.name))),addOrUpdateInstanceType:l})))}}function xs(e,t,a){const n=ra(e.values,t);Ot.useEffect((()=>{void 0===n&&void 0!==a&&e.setFieldValue(t,a)}),[t,a,n])}function Ps(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 Ot.useEffect((()=>{"lowest-price"!==t.spotAllocationStrategy?a("spotInstancePools",void 0):void 0===t.spotInstancePools&&a("spotInstancePools",2)}),[t.spotAllocationStrategy]),xs(e.formik,"spotAllocationStrategy","capacity-optimized"),xs(e.formik,"onDemandAllocationStrategy","prioritized"),xs(e.formik,"onDemandBaseCapacity",0),xs(e.formik,"onDemandPercentageAboveBaseCapacity",100),Ot.createElement("div",{className:"InstancesDistribution row sub-section form-group"},Ot.createElement("h4",null,"Instances Distribution"),Ot.createElement("div",{className:"description"},"Diversify and distribute instance types across purchase options."," ",Ot.createElement(n,{id:"aws.serverGroup.instancesDistribution"})),Ot.createElement("br",null),Ot.createElement(s,{label:"Spot Allocation Strategy",name:"spotAllocationStrategy",help:Ot.createElement(n,{id:"aws.serverGroup.spotAllocationStrategy"}),input:e=>Ot.createElement(c,{...e,mode:"PLAIN",options:r})}),"lowest-price"===e.formik.values.spotAllocationStrategy&&Ot.createElement(s,{label:"Spot Instance Pools Count",name:"spotInstancePools",help:Ot.createElement(n,{id:"aws.serverGroup.spotInstancePoolCount"}),input:e=>Ot.createElement(u,{...e})}),Ot.createElement(s,{label:"On-Demand Allocation Strategy",name:"onDemandAllocationStrategy",help:Ot.createElement(n,{id:"aws.serverGroup.odAllocationStrategy"}),input:e=>Ot.createElement(l,{...e,disabled:!0})}),Ot.createElement(s,{label:"On-Demand Base Capacity",name:"onDemandBaseCapacity",help:Ot.createElement(n,{id:"aws.serverGroup.odBase"}),input:e=>Ot.createElement(u,{...e})}),Ot.createElement(s,{label:"On-Demand Percentage Above Base Capacity",name:"onDemandPercentageAboveBaseCapacity",help:Ot.createElement(n,{id:"aws.serverGroup.odPercentAboveBase"}),input:e=>Ot.createElement(u,{...e})}),Ot.createElement(s,{label:"Spot Max Price",name:"spotPrice",help:Ot.createElement(n,{id:"aws.serverGroup.spotMaxPrice"}),input:e=>Ot.createElement(_,{value:"Recommended to leave empty and use AWS default i.e. On-Demand price"},Ot.createElement(l,{...e,placeholder:"Recommended to leave empty and use AWS default i.e. On-Demand price"}))}))}function zs(e){const{instanceTypeDetails:t,setUnlimitedCpuCredits:a}=e,{values:n,setFieldValue:r}=e.formik,{instanceType:i,launchTemplateOverridesForInstanceType:s}=n;Vt((()=>{!s&&i&&e.formik.setFieldValue("launchTemplateOverridesForInstanceType",[{instanceType:n.instanceType,priority:1}])}));const l=n.launchTemplateOverridesForInstanceType?n.launchTemplateOverridesForInstanceType:void 0,o=new Map(Object.entries(va(l,"instanceType"))),[c,d]=Ut(n.viewState.instanceProfile||"custom"),p=ft(c);return t&&t.length>0?Ot.createElement("div",{className:"advanced-mode-selector"},Ot.createElement(hs,{currentProfile:c,handleProfileChange:e=>{d(e),r("viewState",{...n.viewState,instanceProfile:e});const t=p&&e&&p!==e,a="custom"!==e&&l&&l.length;if(t&&a){const t=_n.awsInstanceTypeService.getInstanceTypesInCategory(l.map((e=>e.instanceType)),e),a=l.filter((e=>t.includes(e.instanceType)));r("launchTemplateOverridesForInstanceType",a),n.launchTemplateOverridesChanged(n)}},instanceProfileList:t}),Ot.createElement(Ps,{formik:e.formik}),Ot.createElement(As,{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 Ds(e){var t,a;const{command:n}=e,{InstanceArchetypeSelector:r,InstanceTypeSelector:i}=vt,s=null==(t=Sn.serverGroups)?void 0:t.enableLaunchTemplates,l=null==(a=Sn.serverGroups)?void 0:a.enableCpuCredits,o=t=>{n.instanceTypeChanged(n),e.setFieldValue("instanceType",t)};return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"row"},Ot.createElement(r,{command:n,onTypeChanged:o,onProfileChanged:t=>{e.setFieldValue("viewState",{...n.viewState,instanceProfile:t})}}),Ot.createElement(Is,{dirty:n.viewState.dirty,clearWarnings:e.clearWarnings}),Ot.createElement("div",{style:{padding:"0 15px"}},n.viewState.instanceProfile&&"custom"!==n.viewState.instanceProfile&&Ot.createElement(i,{command:n,onTypeChanged:o}))),s&&l&&Ot.createElement("div",{className:"row"},Ot.createElement(fs,{unlimitedCpuCredits:n.unlimitedCpuCredits,selectedInstanceTypes:[n.instanceType],currentProfile:n.viewState.instanceProfile,setUnlimitedCpuCredits:e.setUnlimitedCpuCredits})))}function Bs(e){var t;const{instanceTypeDetails:a}=e,{values:r,setFieldValue:i}=e.formik,s=null==(t=Sn.serverGroups)?void 0:t.enableLaunchTemplates,l=r.viewState.useSimpleInstanceTypeSelector,[o,c]=Ut(r.unlimitedCpuCredits);Vt((()=>{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()},p=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?Ot.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Ot.createElement("div",null,Ot.createElement("p",null,"Switch to",Ot.createElement("a",{className:"clickable",onClick:()=>p(!0)},Ot.createElement("span",null," Simple Mode")),"."),Ot.createElement("i",null,Ot.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.")),Ot.createElement(zs,{formik:e.formik,instanceTypeDetails:a,setUnlimitedCpuCredits:c,clearWarnings:d})):Ot.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Ot.createElement("div",null,Ot.createElement("span",null,"To configure mixed server groups and/or multiple instance types,"),!s&&Ot.createElement("span",null,Ot.createElement("a",{href:"https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates-setup/"},Ot.createElement("span",null," enable launch templates")),Ot.createElement("span",null," and")),Ot.createElement("span",null,Ot.createElement("a",{className:s?"clickable":"disabled",onClick:s?()=>p(!1):()=>{}},Ot.createElement("span",null," use Advanced Mode ")),Ot.createElement(n,{id:"aws.serverGroup.advancedMode"}),"."),Ot.createElement("p",null),s&&Ot.createElement("i",null,Ot.createElement("b",null,"Note:")," If an instance type is already selected in simple mode, it will be preserved in advanced mode.")),Ot.createElement(Ds,{command:r,setUnlimitedCpuCredits:c,setFieldValue:i,clearWarnings:d}))}yr(".InstancesDistribution .StandardFieldLayout_Label {\n min-width: 300px;\n}\n");class Fs extends Ot.Component{constructor(){super(...arguments),this.state={instanceTypeDetails:[]},this.props$=new Na,this.destroy$=new Na}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."),la(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>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(_n.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?Ot.createElement(Bs,{formik:this.props.formik,instanceTypeDetails:s}):Ot.createElement("h5",{className:"text-center"},"Please select an image.")}}class Ms extends Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement(_r,{credentials:e.credentials,region:e.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:e.availabilityZones,allZones:e.backingData.filtered.availabilityZones,usePreferredZones:e.viewState.usePreferredZones}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("b",null,"AZ Rebalance")),Ot.createElement("div",{className:"col-md-7 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",onChange:this.rebalanceToggled,checked:!e.processIsSuspended(e,"AZRebalance")}),"Keep instances evenly distributed across zones"))))}}const $s=e=>({value:e,label:e});class Ls extends Ot.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($s);c=Ot.createElement(Ot.Fragment,null,i.targetGroups&&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"}),"The following target groups could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,i.targetGroups.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("targetGroups")},"Okay")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Target Groups "),Ot.createElement(n,{id:"aws.loadBalancer.targetGroups"})),Ot.createElement("div",{className:"col-md-7"},0===t.length&&Ot.createElement("div",{className:"form-control-static"},"No ",Ot.createElement("b",null,null!=(e=this.props.targetGroupTypeHelpText)?e:"instance")," target groups found in the selected account/region/VPC"),t.length>0&&Ot.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($s),t=(r.backingData.filtered.vpcLoadBalancers||[]).map($s),a=r.vpcLoadBalancers&&r.vpcLoadBalancers.length>0;d=Ot.createElement(Ot.Fragment,null,i.loadBalancers&&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"}),"The following load balancers could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,i.loadBalancers.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("loadBalancers")},"Okay")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Classic Load Balancers "),Ot.createElement(n,{id:"aws.loadBalancer.loadBalancers"})),Ot.createElement("div",{className:"col-md-7"},0===e.length&&Ot.createElement("div",{className:"form-control-static"},"No load balancers found in the selected account/region/VPC"),e.length>0&&Ot.createElement(f,{multi:!0,options:e,value:r.loadBalancers,onChange:this.loadBalancersChanged}))),!r.vpcId&&Ot.createElement("div",{className:"form-group"},!a&&!o&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-8 col-md-offset-3"},Ot.createElement("a",{className:"clickable",onClick:()=>this.setState({showVpcLoadBalancers:!0})},"Add VPC Load Balancers"))),a&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"VPC Load Balancers")),Ot.createElement("div",{className:"col-md-8"},t.length>0&&Ot.createElement(f,{multi:!0,options:t,value:r.vpcLoadBalancers,onChange:this.vpcLoadBalancersChanged})))),!s&&Ot.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Ot.createElement("div",{className:"col-md-8 col-md-offset-4"},l&&Ot.createElement("p",null,Ot.createElement("span",{className:"fa fa-sync-alt fa-spin"}),Ot.createElement("span",null," refreshing...")),!l&&Ot.createElement("p",null,"If you are looking for a load balancer or target group from a different application, ",Ot.createElement("br",null),Ot.createElement("a",{className:"clickable",onClick:this.refreshLoadBalancers},"click here")," ","to load all load balancers."))))}return Ot.createElement("div",{className:"container-fluid form-horizontal"},c,d)}}class Rs extends Ot.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 Ot.createElement(Ot.Fragment,null,Ot.createElement("div",{className:"form-group"},!r&&Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("b",null,V.get("Firewalls")),a&&Ot.createElement(n,{key:a})),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(pn,{ignoreAccents:!0,options:l,onChange:this.onChange,value:t,multi:!0}))),Ot.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Ot.createElement("div",{className:`col-md-${r?12:9} col-md-offset-${r?0:3}`},Ot.createElement("p",null,i&&Ot.createElement("span",null,Ot.createElement("span",{className:"fa fa-sync-alt fa-spin"})),V.get("Firewalls"),!i&&Ot.createElement("span",null," last refreshed ",B(s)),i&&Ot.createElement("span",null," refreshing...")),Ot.createElement("p",null,"If you're not finding a ",V.get("firewall")," that was recently added,"," ",Ot.createElement("a",{className:"clickable",onClick:this.refreshSecurityGroups},"click here")," ","to refresh the list."))))}}class Os extends Ot.Component{render(){const{command:e,onClear:t,removed:a}=this.props,n=(e&&e.viewState.dirty.securityGroups||[]).concat(a||[]);return 0===n.length?null: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"}),"The following ",V.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,n.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:t},"Okay"))))}}Os.defaultProps={onClear:C};class Us extends Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement(Os,{command:e,onClear:this.acknowledgeRemovedGroups}),Ot.createElement(Rs,{command:e,availableGroups:e.backingData.filtered.securityGroups,groupsToEdit:e.securityGroups,onChange:this.onChange}))}}class Vs extends Ot.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=Sn.serverGroups;return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Cooldown")),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(dn,{type:"text",required:!0,name:"cooldown",className:"form-control input-sm no-spel"}))," ","seconds"),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Enabled Metrics "),Ot.createElement(n,{id:"aws.serverGroup.enabledMetrics"})),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{multi:!0,value:a.enabledMetrics,options:a.backingData.enabledMetrics.map((e=>({label:e,value:e}))),onChange:e=>t("enabledMetrics",e.map((e=>e.value)))}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Health Check Type")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{value:a.healthCheckType,clearable:!1,placeholder:"Select...",options:a.backingData.healthCheckTypes.map((e=>({label:e,value:e}))),onChange:e=>t("healthCheckType",e.value)}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Health Check Grace Period")),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(dn,{type:"text",required:!0,className:"form-control input-sm no-spel",name:"healthCheckGracePeriod"}))," ","seconds"),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Termination Policies")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{multi:!0,value:a.terminationPolicies,options:a.backingData.terminationPolicies.map((e=>({label:e,value:e}))),onChange:e=>t("terminationPolicies",e.map((e=>e.value)))}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Key Name")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{value:a.keyPair,required:!0,clearable:!1,options:i.map((e=>({label:e,value:e}))),onChange:e=>t("keyPair",e.value)}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Ramdisk Id (optional)")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(dn,{type:"text",name:"ramdiskId",className:"form-control input-sm no-spel"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"IAM Instance Profile (optional)")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(dn,{type:"text",className:"form-control input-sm no-spel",name:"iamRole"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"UserData (optional) "),Ot.createElement(n,{id:"aws.serverGroup.base64UserData"})),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(dn,{type:"text",className:"form-control input-sm no-spel",name:"base64UserData"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Instance Monitoring "),Ot.createElement(n,{id:"aws.serverGroup.instanceMonitoring"})),Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:a.instanceMonitoring,onChange:e=>t("instanceMonitoring",e.target.checked)})," ","Enforce Instance Monitoring"," "))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"EBS Optimized")),Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:a.ebsOptimized,onChange:e=>t("ebsOptimized",e.target.checked)})," ","Optimize Instances for EBS"))),(null==s?void 0:s.enableIMDSv2)&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"IMDSv2 "),Ot.createElement(n,{id:"aws.serverGroup.imdsv2"})),Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:!0===a.requireIMDSv2,onChange:e=>t("requireIMDSv2",e.target.checked)})," ","Require IMDSv2"," "))),!Sn.disableSpotPricing&&a.viewState.useSimpleInstanceTypeSelector&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Spot Instances Price (optional)")," ",Ot.createElement(n,{id:"aws.serverGroup.spotMaxPrice"})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(dn,{type:"text",className:"form-control input-sm",name:"spotPrice"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"AMI Block Device Mappings")),Ot.createElement("div",{className:"col-md-6 radio"},Ot.createElement("div",null,Ot.createElement("label",null,Ot.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("source"),checked:"source"===r,name:"blockDeviceMappingsSource"}),"Copy from current server group ",Ot.createElement(n,{id:"aws.blockDeviceMappings.useSource"}))),Ot.createElement("div",null,Ot.createElement("label",null,Ot.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("ami"),checked:"ami"===r,name:"blockDeviceMappingsSource"}),"Prefer AMI block device mappings ",Ot.createElement(n,{id:"aws.blockDeviceMappings.useAMI"}))),Ot.createElement("div",null,Ot.createElement("label",null,Ot.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("default"),checked:"default"===r,name:"blockDeviceMappingsSource"}),"Defaults for selected instance type ",Ot.createElement(n,{id:"aws.blockDeviceMappings.useDefaults"}))))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,`Associate ${(null==s?void 0:s.enableIPv6)?"IPv6 (Recommended)":"Public IPv4"} Address`),Ot.createElement(n,{id:"serverGroup.ipv6"})),(null==s?void 0:s.enableIPv6)&&Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.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)&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-2 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:!0===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!0),id:"associatePublicIpAddressTrue"}),"Yes")),Ot.createElement("div",{className:"col-md-2 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:!1===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!1),id:"associatePublicIpAddressFalse"}),"No")),Ot.createElement("div",{className:"col-md-2 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:null===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",null),id:"associatePublicIpAddressDefault"}),"Default")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Scaling Processes")),Ot.createElement("div",{className:"col-md-6 checkbox"},a.backingData.scalingProcesses.map((e=>Ot.createElement("div",{key:e.name},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",onChange:()=>this.toggleSuspendedProcess(e.name),checked:!a.suspendedProcesses.includes(e.name)})," ",e.name," ",Ot.createElement(n,{content:e.description}))))))),e.attributes.platformHealthOnlyShowOverride&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Task Completion")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(yt,{interestingHealthProviderNames:a.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"sm-label-left"},Ot.createElement("b",null,"Tags (optional)"),Ot.createElement(n,{id:"aws.serverGroup.tags"})),Ot.createElement(bt,{model:a.tags,allowEmpty:!0,onChange:this.tagsChanged})))}}var qs=Object.defineProperty,Hs=Object.getOwnPropertyDescriptor;let Ws=class extends Ot.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 Ot.createElement(Vs,{formik:e,app:t,ref:this.handleRef})}};Ws=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Hs(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&&qs(t,a,i),i})([ie("aws.serverGroup.advancedSettings")],Ws);class js extends Ot.Component{constructor(){super(...arguments),this.ref=Ot.createRef()}validate(e){return this.ref&&this.ref.current?this.ref.current.validate(e):{}}render(){const{app:e,formik:t}=this.props;return Ot.createElement(Ws,{formik:t,app:e,ref:this.ref})}}const Zs=class extends Ot.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),_n.awsServerGroupConfigurationService.configureSubnetPurposes(e)},this.configureCommand=()=>{const{application:e,command:t}=this.props;_n.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=ra(e,"command.viewState.requiresTemplateSelection",!1);t||this.configureCommand(),this.state={firewallsLabel:V.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(Zs,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?Ot.createElement(os,{app:e,command:t,onDismiss:a,onTemplateSelected:this.templateSelected}):Ot.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})=>Ot.createElement(Ot.Fragment,null,Ot.createElement(w,{label:"Basic Settings",wizard:r,order:n(),render:({innerRef:t})=>Ot.createElement(ps,{ref:t,formik:a,app:e})}),Ot.createElement(w,{label:"Load Balancers",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(Ls,{ref:e,formik:a})}),Ot.createElement(w,{label:V.get("Firewalls"),wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(Us,{ref:e,formik:a})}),Ot.createElement(w,{label:t.viewState.useSimpleInstanceTypeSelector?"Instance Type":"Instance Types",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(Fs,{ref:e,formik:a})}),Ot.createElement(w,{label:"Capacity",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(gs,{ref:e,formik:a})}),Ot.createElement(w,{label:"Availability Zones",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(Ms,{ref:e,formik:a})}),Ot.createElement(w,{label:"Advanced Settings",wizard:r,order:n(),render:({innerRef:t})=>Ot.createElement(js,{ref:t,formik:a,app:e})}))})}};let _s=Zs;_s.defaultProps={closeModal:C,dismissModal:C};class Ks extends Ot.Component{constructor(){super(...arguments),this.state={verified:!1,requireVerification:!1},this.handleVerification=e=>{this.setState({verified:e})}}componentDidMount(){o.accounts$.pipe(Ua(1),Pa((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 Ot.createElement(_a,null,Ot.createElement("form",{onSubmit:()=>(this.props.onSubmit(),!1)},i&&Ot.createElement(Et,{expectedValue:e,onValidChange:this.handleVerification})),Ot.createElement("button",{className:"btn btn-default",onClick:t},"Cancel"),Ot.createElement("button",{type:"submit",className:"btn btn-primary",onClick:a,disabled:!n||i&&!r},"Submit"))}}Ks.defaultProps={isValid:!0};const Ys=class extends Ot.Component{constructor(e){super(e),this.formikRef=Ot.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:aa({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(Ys,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 Ot.createElement("div",null,Ot.createElement("p",null,"Sets min, max, and desired instance counts to the same value."),Ot.createElement("p",null,"To allow autoscaling, use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Current size"),Ot.createElement("div",{className:"col-md-4"},Ot.createElement("div",{className:"horizontal middle"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:a.desiredCapacity,disabled:!0}),Ot.createElement("div",{className:"sp-padding-xs-xaxis"},"instances")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Ot.createElement("div",{className:"col-md-4"},Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(s,{name:"desired",input:e=>Ot.createElement(u,{...e,min:0}),touched:!0,onChange:t=>{e.setFieldValue("min",t),e.setFieldValue("max",t)}}),Ot.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 Ot.createElement("div",null,Ot.createElement("p",null,"Sets up autoscaling for this server group."),Ot.createElement("p",null,"To disable autoscaling, use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Simple Mode"),"."),Ot.createElement("div",{className:"form-group bold"},Ot.createElement("div",{className:"col-md-2 col-md-offset-3"},"Min"),Ot.createElement("div",{className:"col-md-2"},"Max"),Ot.createElement("div",{className:"col-md-2"},"Desired")),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Current"),Ot.createElement("div",{className:"col-md-2"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:n.minSize,disabled:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:n.maxSize,disabled:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:n.desiredCapacity,disabled:!0}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(s,{name:"min",input:e=>Ot.createElement(u,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Ot.createElement(Ot.Fragment,null,e),touched:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(s,{name:"max",input:e=>Ot.createElement(u,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Ot.createElement(Ot.Fragment,null,e),touched:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(s,{name:"desired",input:e=>Ot.createElement(u,{...e,min:0,disabled:this.isDesiredControlledByAutoscaling()}),layout:({input:e})=>Ot.createElement(Ot.Fragment,null,e),touched:!0}))),!!r&&Ot.createElement("div",{className:"col-md-offset-3 col-md-9"},Ot.createElement(ue,{message:r,type:"error"})))}renderCapacityConstraintSelector(){return Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement(s,{name:"enforceCapacityConstraints",input:e=>Ot.createElement(Ot.Fragment,null,Ot.createElement(d,{...e,text:"Enforce Capacity Constraints"}),Ot.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?Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement("div",{className:"well-compact alert alert-warning"},Ot.createElement("b",null,"Warning"),": this server group has",1===i.length&&Ot.createElement("span",null," a scaling policy. "),i.length>1&&Ot.createElement("span",null," scaling policies. "),!r&&Ot.createElement("span",null,"Scaling policies will not take effect in Simple Mode. Switch to"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),r&&Ot.createElement("span",null,"Scaling policies will not take effect when ",Ot.createElement("b",null,"Min")," is the same as ",Ot.createElement("b",null,"Max"),".")))):this.isDesiredControlledByAutoscaling()?Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-8 col-md-offset-1"},Ot.createElement("div",{className:"well-compact alert alert-warning"},Ot.createElement("p",null,Ot.createElement("b",null,"Desired")," capacity is managed by Autoscaling Policies."),Ot.createElement("p",null,"If you need to scale ",Ot.createElement("b",null,"down")," this server group, set ",Ot.createElement("b",null,"Max")," to the new desired size."),Ot.createElement("p",null,"If you need to scale ",Ot.createElement("b",null,"up")," this server group, set ",Ot.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 Ot.createElement(Ot.Fragment,null,Ot.createElement(wt,{monitor:this.state.taskMonitor}),Ot.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 Ot.createElement(Ot.Fragment,null,Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Resize ",e.name)),Ot.createElement(qa.Body,null,Ot.createElement(cn,{className:"form-horizontal"},t&&this.renderAdvancedMode(a),!t&&this.renderSimpleMode(a),this.renderScalingPolicyWarning(a),this.renderCapacityConstraintSelector(),n&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-8 col-md-offset-3"},Ot.createElement(yt,{interestingHealthProviderNames:this.state.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged,showHelpDetails:!0}))),Ot.createElement(mt,{reason:a.values.reason,onChange:e=>a.setFieldValue("reason",e)}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Changes"),Ot.createElement("div",{className:"col-md-9 sm-control-field"},Ot.createElement(Ct,{current:i,next:s}))))),Ot.createElement(Ks,{onSubmit:()=>this.submit(a.values),onCancel:this.close,isValid:a.isValid,account:e.account}))}}))}};let Xs=Ys;Xs.defaultProps={closeModal:C,dismissModal:C};var Js=Object.defineProperty,Qs=Object.getOwnPropertyDescriptor;let el=class extends Ot.Component{constructor(){super(...arguments),this.resizeServerGroup=()=>{Xs.show(this.props)}}render(){return Ot.createElement(Ka,{onClick:this.resizeServerGroup},"Resize")}};el=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Qs(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&&Js(t,a,i),i})([ie("AmazonServerGroupActions.resize")],el);class tl extends Ot.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"};St.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};St.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=Yt(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]),kt.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=ya(e.clusters,{name:a.cluster,account:a.account,serverGroups:[]});return Qt(t.serverGroups,{isDisabled:!0,region:a.region})},allServerGroups:()=>n,application:()=>e}})},this.cloneServerGroup=()=>{const{app:e,serverGroup:t}=this.props;_n.awsServerGroupCommandBuilder.buildServerGroupCommandFromExisting(e,t).then((a=>{const n=`Clone ${t.name}`;_s.show({title:n,application:e,command:a})}))}}isEnableLocked(){if(this.props.serverGroup.isDisabled){if((this.props.serverGroup.runningTasks||[]).filter((e=>ra(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||ra(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=Nt.buildClusterTargets(t);return Ot.createElement(Ot.Fragment,null,Sn.adHocInfraWritesEnabled&&Ot.createElement(Va,{className:"dropdown",id:"server-group-actions-dropdown"},Ot.createElement(Va.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},"Server Group Actions"),Ot.createElement(Va.Menu,{className:"dropdown-menu"},this.isRollbackEnabled()&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.rollbackServerGroup},"Rollback"),this.isRollbackEnabled()&&Ot.createElement("li",{role:"presentation",className:"divider"}),Ot.createElement(el,{application:e,serverGroup:t}),!t.isDisabled&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.disableServerGroup},"Disable"),this.hasDisabledInstances()&&!this.isEnableLocked()&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.enableServerGroup},"Enable"),this.isEnableLocked()&&Ot.createElement("li",{className:"disabled"},Ot.createElement(Wa,{value:"Cannot enable this server group until resize operation completes",placement:"left"},Ot.createElement("a",null,Ot.createElement("span",{className:"small glyphicon glyphicon-lock"})," Enable"))),Ot.createElement(Ge,{resource:t,application:e,onClick:this.destroyServerGroup},"Destroy"),Ot.createElement("li",null,Ot.createElement("a",{className:"clickable",onClick:this.cloneServerGroup},"Clone")),n&&Ot.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 al{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 nl(e,t){const{app:a,serverGroup:n}=e;return new xa((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=>{Tt.getServerGroup(a.name,n.accountId,n.region,n.name).then((a=>{Object.assign(a,e,{account:n.accountId});const i=_n.awsServerGroupTransformer.normalizeServerGroupDetails(a);if(o.getAccountDetails(i.account).then((e=>{i.accountDetails=e,r.next(i)})),Ht(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=al.getDisabledDate(i),r.next(i)}}),t)}),t)}))}function rl(e){const t=Rt.useRef(),a=Rt.useRef(),{lines:n,className:r="",style:i={}}=e;return Rt.useEffect((()=>{return t?(a.current=(e=t.current,new un(e,{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}}}})),()=>{var e;return null==(e=a.current)?void 0:e.destroy()}):null;var e}),[t.current]),Rt.useEffect((()=>{const e=a.current;e&&n&&(e.options.animation=!1,e.data.datasets=n,e.update())}),[a.current,n]),Rt.createElement("canvas",{ref:t,...i,className:r})}function il(e){return e.serverGroup&&e.alarm?Rt.createElement(sl,{...e}):null}function sl(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:p,period:u}=n,{status:m,result:g}=F((async()=>{var t;const a={namespace:d,statistics:p,period:u};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,p,u,o,i,l,c]);if("PENDING"===m)return Rt.createElement("div",{className:"flex-container-v middle center sp-margin-xl"},Rt.createElement(ae,null));if("REJECTED"===m)return Rt.createElement(Rt.Fragment,null,Rt.createElement("div",null,"no data"),Rt.createElement("div",null,"something went wrong fetching stats"));if(0===g.datapoints.length)return Rt.createElement(Rt.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:e.average})))},y={label:"threshold",borderWidth:1,borderColor:"red",data:[{x:f,y:n.threshold},{x:h,y:n.threshold}]};return Rt.createElement(rl,{lines:[v,y]})}un.register(mn,gn,hn,fn,vn,yn,bn,En,wn);const ll={ASGAverageCPUUtilization:"CPUUtilization",ASGAverageNetworkIn:"NetworkIn",ASGAverageNetworkOut:"NetworkOut"},ol=({config:e,serverGroup:t,updateUnit:a})=>{const[n,r]=Rt.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});Rt.useEffect((()=>{(()=>{var a;const i=null==e?void 0:e.customizedMetricSpecification,s={...n,dimensions:(null==i?void 0:i.dimensions)||[{name:"AutoScalingGroupName",value:t.name}],metricName:(null==i?void 0:i.metricName)||ll[null==(a=null==e?void 0:e.predefinedMetricSpecification)?void 0:a.predefinedMetricType],namespace:(null==i?void 0:i.namespace)||"AWS/EC2",threshold:null==e?void 0:e.targetValue};i&&(s.statistic=null==i?void 0:i.statistic),r(s)})()}),[e]);return Rt.createElement(il,{alarm:n,onChartLoaded:e=>{a&&a(e.unit)},serverGroup:t})};yr("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 cl=({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=ba(e,(e=>e.dimensions));return ia(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 Rt.createElement("div",null,Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-12 small"},Rt.createElement("h5",null,"Dimensions"))),n.map(((t,n)=>Rt.createElement("div",{key:`dimension-${n}`,className:"row dimensions-row horizontal middle"},Rt.createElement("div",{className:"col-md-6"},Rt.createElement(c,{onChange:e=>i("name",e.target.value,n),value:t.name,stringOptions:r})),Rt.createElement(l,{onChange:e=>i("value",e.target.value,n),value:t.value}),!e.disableEditingDimensions&&Rt.createElement("div",{className:"col-md-1",onClick:()=>(t=>{const n=e.dimensions.filter(((e,a)=>a!==t));a(n)})(n)},Rt.createElement("a",null,Rt.createElement("i",{className:"glyphicon glyphicon-trash clickable"})))))),!e.disableEditingDimensions&&Rt.createElement("div",{className:"row"},Rt.createElement("div",null,Rt.createElement("button",{type:"button",className:"btn btn-block btn-xs add-new",onClick:()=>{const e=[...n,{}];a(e)}},Rt.createElement("span",{className:"glyphicon glyphicon-plus-sign sp-margin-xs-left"}),"Add dimension"))))},dl=["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"];yr(".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 pl=({alarm:e,updateAlarm:t,serverGroup:a})=>{var r,i;const s=((null==(i=null==(r=Sn)?void 0:r.metrics)?void 0:i.customNamespaces)||[]).concat(dl),[l,o]=Rt.useState(!1),d=((null==e?void 0:e.dimensions)||[]).reduce(((e,t)=>(e[t.name]=t.value,e)),{}),{result:p}=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]),u=(p||[]).filter((t=>t.namespace===(null==e?void 0:e.namespace))),m=u.find((t=>t.name===(null==e?void 0:e.metricName)&&t.namespace===(null==e?void 0:e.namespace)))||u.find((e=>e.name.match("CPUUtilization")))||u[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 Rt.useEffect((()=>{m&&v(m)}),[m]),l?Rt.createElement("div",{className:"MetricSelector"},Rt.createElement("div",{className:"horizontal middle"},Rt.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"}),Rt.createElement(c,{value:g,onChange:t=>y(null==e?void 0:e.namespace,t.target.value),stringOptions:p.map((e=>e.name)),placeholder:"name",searchable:!0,inputClassName:"advanced-input-metric"})),Rt.createElement("div",{className:"vertical"},!Boolean(p.length)&&Rt.createElement("span",{className:"input-label"},Rt.createElement("b",null,"Note:")," no metrics found for selected namespace + dimensions"),Rt.createElement("a",{className:"clickable",onClick:f},Rt.createElement("span",{className:"sp-margin-s-yaxis sp-margin-xs-right"},"Only show metrics for this auto scaling group"),Rt.createElement(n,{id:"aws.scalingPolicy.search.restricted"}))),Rt.createElement(cl,{alarm:e,serverGroup:a,updateAvailableMetrics:a=>{const n={...e,dimensions:a};t(n)}})):Rt.createElement("div",{className:"MetricSelector horizontal middle"},Rt.createElement(c,{value:m,onChange:e=>v(e.target.value),options:p,clearable:!1,inputClassName:"sp-margin-s-right simple-input"}),Rt.createElement("a",{className:"clickable",onClick:f},Rt.createElement("span",{className:"sp-margin-xs-right"},"Search all metrics"),Rt.createElement(n,{id:"aws.scalingPolicy.search.all"})))};yr(".TargetMetricFields .metric-select-input {\n font-size: 12px;\n width: 180px;\n}\n.TargetMetricFields .target-input {\n width: 120px;\n}\n");const ul=({allowDualMode:e,cloudwatch:t,command:a,isCustomMetric:n,serverGroup:r,toggleMetricType:i,updateCommand:s})=>{var l,o;const[d,p]=Rt.useState(null),m=(e,t)=>{const n=Zt(a);ca(n,e,t),s(n)};return Rt.createElement("div",{className:"TargetMetricFields sp-margin-l-xaxis"},Rt.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&&Rt.createElement("p",null,Rt.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.'),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Metric"),Rt.createElement("div",{className:"col-md-10 content-fields"},!n&&Rt.createElement(c,{value:null==(l=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:l.predefinedMetricType,stringOptions:["ASGAverageCPUUtilization","ASGAverageNetworkOut","ASGAverageNetworkIn"],onChange:e=>m("targetTrackingConfiguration.predefinedMetricSpecification.predefinedMetricType",e.target.value),inputClassName:"metric-select-input"}),n&&Rt.createElement(pl,{alarm:a.targetTrackingConfiguration.customizedMetricSpecification,serverGroup:r,updateAlarm:e=>{m("targetTrackingConfiguration.customizedMetricSpecification",e)}}),e&&Rt.createElement("a",{className:"clickable",onClick:()=>{const e=Zt(a);n?(ca(e,"targetTrackingConfiguration.predefinedMetricSpecification",{predefinedMetricType:"ASGAverageCPUUtilization"}),ca(e,"targetTrackingConfiguration.customizedMetricSpecification",null)):(ca(e,"targetTrackingConfiguration.predefinedMetricSpecification",null),ca(e,"targetTrackingConfiguration.customizedMetricSpecification",{metricName:"CPUUtilization",namespace:"AWS/EC2",dimensions:[{name:"AutoScalingGroupName",value:r.name}],statistic:"Average"})),s(e),i(n?"predefined":"custom")}},n?"Use a predefined metric":"Select a custom metric"))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Target"),Rt.createElement("div",{className:"col-md-10 content-fields horizontal"},n&&Rt.createElement("div",{className:"horizontal middle"},Rt.createElement(c,{value:null==(o=a.targetTrackingConfiguration.customizedMetricSpecification)?void 0:o.statistic,stringOptions:["Average","Maximum","Minimum","SampleCount","Sum"],onChange:e=>m("targetTrackingConfiguration.customizedMetricSpecification.statistic",e.target.value),inputClassName:"form-control input-sm target-input"}),Rt.createElement("span",{className:"sp-margin-xs-xaxis"},"of")),Rt.createElement("div",{className:"horizontal middle"},Rt.createElement(u,{value:a.targetTrackingConfiguration.targetValue,onChange:e=>m("targetTrackingConfiguration.targetValue",Number.parseInt(e.target.value)),inputClassName:"form-control input-sm sp-margin-xs-right"}),Rt.createElement("span",null,d)))),Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement(ol,{config:a.targetTrackingConfiguration,serverGroup:r,unit:d,updateUnit:e=>p(e)}))))};yr(".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 ml=({command:e,cooldowns:t,policyName:a,updateCommand:r})=>{var i;const s=(t,a)=>{const n={...e};ca(n,t,a),r(n)},l=null==(i=e.targetTrackingConfiguration)?void 0:i.disableScaleIn;return Rt.createElement("div",{className:"section-body TargetTrackingAdditionalSettings"},a&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},a)),Boolean(e.estimatedInstanceWarmup)&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static"},"Instances need"),Rt.createElement(u,{value:e.estimatedInstanceWarmup,onChange:e=>s("estimatedInstanceWarmup",Number.parseInt(e.target.value)),inputClassName:"form-control number-input-sm sp-margin-xs-xaxis"}),Rt.createElement("span",{className:"input-label"}," seconds to warm up "))),Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Scale In"),Rt.createElement("div",{className:"col-md-9"},Rt.createElement("div",{className:"checkbox"},Rt.createElement(d,{text:"Disable Scale-downs",checked:l,onChange:e=>s("targetTrackingConfiguration.disableScaleIn",e.target.checked)}),Rt.createElement("div",{className:"small"},Rt.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."),Rt.createElement("p",null,"This is useful when you have special requirements, such as gradual or delayed scale-down."))))),Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},l&&Rt.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&&Rt.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&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-3 sm-label-right"},Rt.createElement("span",{className:"sp-margin-xs-right"},"Scale In Cooldown"),Rt.createElement(n,{id:"titus.autoscaling.scaleIn.cooldown"})),Rt.createElement("div",{className:"col-md-9 horizontal middle"},Rt.createElement(u,{value:e.targetTrackingConfiguration.scaleInCooldown,onChange:e=>s("targetTrackingConfiguration.scaleInCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Rt.createElement("span",{className:"input-label"}," seconds "))),t&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-3 sm-label-right"},Rt.createElement("span",{className:"sp-margin-xs-right"},"Scale Out Cooldown"),Rt.createElement(n,{id:"titus.autoscaling.scaleOut.cooldown"})),Rt.createElement("div",{className:"col-md-9 horizontal middle"},Rt.createElement(u,{value:e.targetTrackingConfiguration.scaleOutCooldown,onChange:e=>s("targetTrackingConfiguration.scaleOutCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Rt.createElement("span",{className:"input-label"}," seconds "))))},gl={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=gl.buildAlarm(a,t.region,t.name),s.minAdjustmentMagnitude=null!=(n=a.minAdjustmentMagnitude)?n:1,(null==(r=a.stepAdjustments)?void 0:r.length)?s.step=gl.buildStepPolicy(a,s.alarm.threshold,s.cooldown):s.simple=gl.buildSimplePolicy(a)),"TargetTracking"===e&&(s.estimatedInstanceWarmup=null!=(i=a.estimatedInstanceWarmup)?i:600,s.targetTrackingConfiguration={...a.targetTrackingConfiguration}),s},prepareCommandForUpsert:(e,t)=>{const a=Zt(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}},hl=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i;const[s,l]=Rt.useState(Boolean(null==(i=n.targetTrackingConfiguration)?void 0:i.customizedMetricSpecification)),[o,c]=Rt.useState({});Rt.useEffect((()=>{const e=gl.buildNewCommand("TargetTracking",r,n);c(e)}),[]);const d=n.policyName?"Update":"Create";return Rt.createElement(It,{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:()=>Rt.createElement("div",{className:"modal-body"},Rt.createElement("h4",{className:"section-heading"},"Target Metric"),Rt.createElement(ul,{allowDualMode:!0,cloudwatch:!1,command:o,isCustomMetric:s,serverGroup:r,toggleMetricType:e=>l("custom"===e),updateCommand:c}),Rt.createElement("h4",{className:"section-heading"},"Additional Settings"),Rt.createElement(ml,{command:o,cooldowns:!1,policyName:n.policyName,updateCommand:c}))})};function fl(e){const[t,a]=Ot.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 Ot.createElement(qa,{show:!0,onHide:e.showCallback},Ot.createElement(qa.Header,{closeButton:!0},Ot.createElement("h3",null,"Select a policy type")),Ot.createElement(qa.Body,null,Ot.createElement("div",{className:"card-choices"},Ot.createElement("div",{className:s,onClick:r,id:"targetTracking"},Ot.createElement("h3",null,"Target Tracking"),Ot.createElement("div",null,"Continuously adjusts the size of the ASG to keep a specified metric at the target value")),Ot.createElement("div",{className:i,onClick:r,id:"step"},Ot.createElement("h3",null,"Step"),Ot.createElement("div",null,"Rule-based scaling, with the ability to define different scaling amounts depending on the magnitude of the alarm breach"))),o&&Ot.createElement(ue,{type:"info",message:Ot.createElement(n,{id:l,expand:!0})}),e.warnOnMinMaxCapacity&&Ot.createElement(ue,{type:"warning",message:Ot.createElement(Ot.Fragment,null,Ot.createElement("p",null,"This server group's ",Ot.createElement("em",null,"min")," and ",Ot.createElement("em",null,"max")," capacity are identical, so scaling policies will have ",Ot.createElement("b",null,"no effect.")),Ot.createElement("p",null,"Scaling policies work by adjusting the server group's ",Ot.createElement("em",null,"desired")," capacity to a value between the min and max."))})),Ot.createElement(qa.Footer,null,Ot.createElement("button",{className:"btn btn-default",onClick:e.showCallback},"Cancel"),Ot.createElement("button",{className:"btn btn-primary",disabled:!t,onClick:()=>{e.typeSelectedCallback(t)}},"Next")))}yr(".ScalingPolicyAdditionalSettings .section-additional-settings .row {\n margin-bottom: 10px;\n}\n.ScalingPolicyAdditionalSettings .section-additional-settings .number-input-sm {\n width: 60px;\n}\n");const vl=({command:e,isInstanceType:t,isNew:a,operator:r,updateCommand:i})=>{var s,l,o,c;const d=(t,a)=>{const n={...e};ca(n,t,a),i(n)};return Rt.createElement("div",{className:"ScalingPolicyAdditionalSettings"},Rt.createElement("h4",{className:"section-heading"},"Additional Settings"),Rt.createElement("div",{className:"section-body section-additional-settings"},!a&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"},e.name))),!t&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Adjustment Step"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"},`${r} instances in increments of at least `),Rt.createElement(u,{value:e.minAdjustmentMagnitude,onChange:e=>d("minAdjustmentMagnitude",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Rt.createElement("span",{className:"input-label"}," instance(s) "))),Boolean(e.simple)&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Cooldown"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"}," Wait at least "),Rt.createElement(u,{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"}),Rt.createElement("span",{className:"input-label"}," seconds before another scaling event "))),Boolean(null==(l=e.step)?void 0:l.estimatedInstanceWarmup)&&"Remove"!==r&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"},"Instances need"),Rt.createElement(u,{value:e.step.estimatedInstanceWarmup,onChange:e=>d("step.estimatedInstanceWarmup",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Rt.createElement("span",{className:"input-label"}," seconds to warm up after each step "))),Boolean(null==(o=e.step)?void 0:o.cooldown)&&"Remove"!==r&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},Rt.createElement("span",{className:"sp-margin-xs-right"},"Cooldown"),Rt.createElement(n,{id:`${e.cloudProvider||e.provider}.autoscaling.cooldown`})),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement(u,{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"}),Rt.createElement("span",{className:"input-label"}," seconds ")))))};yr(".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 yl=["Average","Maximum","Minimum","SampleCount","Sum"],bl=[{label:">=",value:"GreaterThanOrEqualToThreshold"},{label:">",value:"GreaterThanThreshold"},{label:"<=",value:"LessThanOrEqualToThreshold"},{label:"<",value:"LessThanThreshold"}],El=[{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}],wl=({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,p]=Rt.useState(null==e?void 0:e.unit),m=ft(o);Rt.useEffect((()=>{if(n&&void 0!==m){const t={scalingAdjustment:1,["max"===o?"metricIntervalLowerBound":"metricIntervalUpperBound"]:e.threshold};r([t])}}),[o]),Rt.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 Rt.createElement("div",{className:"AlarmConfigurer"},t&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-12"},Rt.createElement("div",{className:"alert alert-warning"},Rt.createElement("p",null,Rt.createElement("i",{className:"fa fa-exclamation-triangle"})," This scaling policy is configured with multiple alarms. You are only editing the first alarm."),Rt.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&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-12"},Rt.createElement("div",{className:"alert alert-warning"},Rt.createElement("p",null,Rt.createElement("i",{className:"fa fa-exclamation-triangle"})," This alarm is used in multiple scaling policies. Any changes here will affect those other scaling policies.")))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Whenever"),Rt.createElement("div",{className:"col-md-10 horizontal"},Rt.createElement(c,{value:e.statistic,onChange:e=>g("statistic",e.target.value),stringOptions:yl,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}),Rt.createElement("span",{className:"input-label sp-margin-xs-right sp-margin-s-top"}," of "),Rt.createElement(pl,{alarm:e,serverGroup:a,updateAlarm:e=>{i(e)}}))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"is"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement(c,{value:e.comparisonOperator,onChange:e=>g("comparisonOperator",e.target.value),options:bl,clearable:!1,inputClassName:"sp-margin-s-right configurer-field-small"}),Rt.createElement("div",{className:"sp-margin-xl-left"},Rt.createElement(u,{value:e.threshold,onChange:e=>g("threshold",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-right configurer-field-lg"})),Rt.createElement("span",{className:"input-label"},d))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"for at least"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement(u,{value:e.evaluationPeriods,onChange:e=>g("evaluationPeriods",Number.parseInt(e.target.value)),inputClassName:"configurer-field-med number-input-field"}),Rt.createElement("span",{className:"input-label sp-margin-s-xaxis"}," consecutive period(s) of "),Rt.createElement(c,{value:e.period,onChange:e=>g("period",e.target.value),options:El,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},e&&Rt.createElement("div",null,Rt.createElement(il,{alarm:e,serverGroup:a,onChartLoaded:e=>p(e.unit)})))))};yr(".SimplePolicyAction .action-input {\n width: 65px;\n}\n.SimplePolicyAction .adjustment-type-input {\n width: 110px;\n}\n");const Cl=({adjustmentType:e,adjustmentTypeChanged:t,operator:a,scalingAdjustment:n,updateScalingAdjustment:r})=>{const i="Set to"===a?["instances"]:["instances","percent of group"],[s,l]=Rt.useState(e),[o,d]=Rt.useState(n);return Rt.createElement("div",{className:"SimplePolicyAction row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1 horizontal middle"},Rt.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"}),Rt.createElement(u,{value:o,min:1,onChange:e=>{return t=Number.parseInt(e.target.value),d(t),void r(t);var t},inputClassName:"action-input"}),Rt.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"})))};yr(".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 Sl=({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"],p="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 Rt.createElement("div",{className:"StepPolicyAction row"},null==m?void 0:m.map(((i,s)=>Rt.createElement("div",{key:`step-adjustment-${s}`,className:"step-policy-row col-md-10 col-md-offset-1 horizontal middle"},Boolean(s)?Rt.createElement("span",{className:"action-input sp-margin-xs-left"},r):Rt.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"}),Rt.createElement(u,{value:i.scalingAdjustment,min:1,onChange:e=>g({...i,scalingAdjustment:Number.parseInt(e.target.value)},s),inputClassName:"action-input"}),Boolean(s)?Rt.createElement("span",{className:"sp-margin-xs-left"},e):Rt.createElement(c,{value:e,stringOptions:p,onChange:e=>{return a=e.target.value,void t(r,a);var a},clearable:!1,inputClassName:"adjustment-type-input sp-margin-xs-left"}),Rt.createElement("span",{className:"sp-margin-xs-xaxis"}," ","when ",Rt.createElement("b",null,null==a?void 0:a.metricName)," is"," "),s===m.length-1&&Rt.createElement("span",null,` ${n?"less":"greater"} than${!Boolean(s)||o?" or equal to":""} ${n?i.metricIntervalUpperBound||"":i.metricIntervalLowerBound||""} `),s<m.length-1&&Rt.createElement(Rt.Fragment,null,Rt.createElement("span",{className:"sp-margin-xs-xaxis"},"between"),n?Rt.createElement(u,{value:i.metricIntervalLowerBound,max:i.metricIntervalUpperBound,step:.1,onChange:e=>g({...i,metricIntervalLowerBound:Number.parseFloat(e.target.value)},s),inputClassName:"action-input"}):Rt.createElement("span",null,i.metricIntervalLowerBound),Rt.createElement("span",{className:"sp-margin-xs-xaxis"},"and"),n?Rt.createElement("span",null,i.metricIntervalUpperBound):Rt.createElement(u,{value:i.metricIntervalUpperBound,min:i.metricIntervalLowerBound,step:.1,onChange:e=>g({...i,metricIntervalUpperBound:Number.parseFloat(e.target.value)},s),inputClassName:"action-input"})),Boolean(s)&&Rt.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)})))),Rt.createElement("div",{className:"row sp-margin-s"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement("button",{type:"button",className:"btn btn-block btn-sm add-new",onClick:()=>{const e=[...m,{scalingAdjustment:1}];l(e)}},Rt.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),"Add step"))),Rt.createElement("div",{className:"row sp-margin-s-xaxis"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement("a",{href:"http://docs.aws.amazon.com/autoscaling/latest/userguide/as-scale-based-on-demand.html#as-scaling-steps",target:"_blank"},Rt.createElement("i",{className:"far fa-file-alt sp-margin-xs-right"}),"Documentation"))))},kl=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i,s,l;const o={closeModal:t,dismissModal:a},[c,d]=Rt.useState({});Rt.useEffect((()=>{const e=gl.buildNewCommand("Step",r,n);d(e)}),[]);const p=(null==(i=n.stepAdjustments)?void 0:i.length)?n.stepAdjustments[0].scalingAdjustment:n.scalingAdjustment,[u,m]=Rt.useState("ExactCapacity"===c.adjustmentType?"Set to":p>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=Zt(c);t.simplescalingAdjustment=e,d(t)},E=e=>{const t=Zt(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=Zt(c),t=c.step?c.step.estimatedInstanceWarmup:c.simple.cooldown;if(c.step)delete e.step,e.simple=gl.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=gl.buildStepPolicy(n,e.alarm.threshold,t),y(e.step)}d(e)};return Rt.createElement(It,{...o,title:`${f} scaling policy`,application:e,description:`${f} scaling policy for ${r.name}`,initialValues:c,mapValuesToTask:()=>{const t=gl.prepareCommandForUpsert(c,"Remove"===u);return{application:e,job:[{type:t.type||"upsertScalingPolicy",...t}]}},render:()=>{var e,t,a,i,s;return Rt.createElement("div",null,Rt.createElement("h4",{className:"section-heading"},"Conditions"),Rt.createElement("div",{className:"section-body"},Rt.createElement(wl,{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})})),Rt.createElement("h4",{className:"section-heading"},"Actions"),Rt.createElement("div",{className:"section-body"},!(null==(t=c.alarm)?void 0:t.metricName)&&Rt.createElement("h4",{className:"text-center"},"Select a metric"),(null==(a=c.alarm)?void 0:a.metricName)&&!h&&Rt.createElement("div",null,Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement("p",null,"This is a simple scaling policy. To declare different actions based on the magnitude of the alarm,",Rt.createElement("b",null,"switch to a",Rt.createElement("a",{className:"clickable sp-margin-xs-l",onClick:C},"step policy"),".")))),Rt.createElement(Cl,{adjustmentType:g,adjustmentTypeChanged:w,operator:u,scalingAdjustment:null==(i=c.simple)?void 0:i.scalingAdjustment,updateScalingAdjustment:b})),(null==(s=c.alarm)?void 0:s.metricName)&&h&&Rt.createElement(Sl,{adjustmentType:g,adjustmentTypeChanged:w,alarm:c.alarm,isMin:"min"===v,operator:u,step:c.step,stepsChanged:E})),Rt.createElement(vl,{command:c,isInstanceType:"instances"===g,isNew:Boolean(!n.policyARN),operator:u,updateCommand:d}))}})};class Nl extends Ot.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:_n.awsServerGroupTransformer.constructNewStepScalingPolicyTemplate(e),serverGroup:e};b.show(kl,a,{dialogClassName:"wizard-modal modal-lg"})}createTargetTrackingPolicy(){const{serverGroup:e,application:t}=this.props,a={app:t,policy:_n.awsServerGroupTransformer.constructNewTargetTrackingPolicyTemplate(),serverGroup:e};b.show(hl,a,{dialogClassName:"wizard-modal modal-lg"})}render(){const{min:e,max:t}=this.props.serverGroup.capacity;return Ot.createElement("div",null,Ot.createElement("a",{className:"clickable",onClick:this.handleClick},"Create new scaling policy"),this.state.showSelection&&Ot.createElement(fl,{warnOnMinMaxCapacity:e===t,typeSelectedCallback:this.typeSelected,showCallback:this.showModalCallback}))}}class Tl{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 Gl={GreaterThanOrEqualToThreshold:">=",GreaterThanThreshold:">",LessThanOrEqualToThreshold:"<=",LessThanThreshold:"<"},Il=({alarm:e})=>Rt.createElement("div",null,Rt.createElement("div",null,Rt.createElement("b",null,"Whenever"),` ${e.statistic} of ${e.metricName}`),Rt.createElement("div",null,Rt.createElement("b",null,"for at least"),` ${e.evaluationPeriods} consecutive periods of ${e.period} seconds`)),Al=({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]||{},p=null==d?void 0:d.comparisonOperator.includes("Greater"),u=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 Rt.createElement("div",null,Rt.createElement(W,{className:"dl-horizontal dl-narrow"},Rt.createElement(D,{label:"Whenever",value:`${d.statistic} of ${d.metricName} is ${Gl[d.comparisonOperator]} ${d.threshold}`}),Rt.createElement(D,{label:"for at least",value:`${d.evaluationPeriods} consecutive periods of ${d.period} seconds`}),Boolean(null==o?void 0:o.length)&&Rt.createElement(D,{label:"then",value:o.map(((e,t)=>Rt.createElement("div",{key:`step-adjustment-boundary-${t}`},o.length>1&&Rt.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=p?e.metricIntervalLowerBound:e.metricIntervalUpperBound,n=`is ${p?"greater":"less"} than ${d.threshold+a}`;return`if ${d.metricName} ${t}${n}`})(e)),Rt.createElement("span",null,u(e)))))}),!Boolean(null==o?void 0:o.length)&&Rt.createElement(D,{label:"then",value:u(e)}),Boolean(l)&&Rt.createElement(D,{label:"in",value:`increments of at least ${l} instance${l>1?"s":""}`}),Boolean(c)&&Rt.createElement(D,{label:"wait",value:`${i} seconds before allowing another scaling activity.`}),Boolean(s)&&Rt.createElement(D,{label:"wait",value:`${s} seconds to warm up after each step.`})),Rt.createElement(il,{alarm:d,serverGroup:t}))};yr(".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 xl=({application:e,policy:t,serverGroup:a})=>{var n,r;const i=a.type||a.cloudProvider||"aws",s=U.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 Rt.createElement("div",{className:"StepPolicySummary"},Rt.createElement("div",null,!Boolean(null==(n=t.alarms)?void 0:n.length)&&Rt.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=>Rt.createElement("div",{key:`step-summary-${t.policyName}`},Rt.createElement(ne,{Component:()=>Rt.createElement(Al,{policy:t,serverGroup:a}),placement:"left",title:t.policyName},Rt.createElement("div",null,Rt.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Rt.createElement(Il,{alarm:e}))),Rt.createElement("div",{className:"actions"},Rt.createElement("button",{className:"btn btn-xs btn-link",onClick:c},Rt.createElement("span",{className:"glyphicon glyphicon-cog"}),Rt.createElement("span",{className:"sr-only"},"Edit policy")),Rt.createElement("button",{className:"btn btn-xs btn-link",onClick:d},Rt.createElement("span",{className:"glyphicon glyphicon-trash"}),Rt.createElement("span",{className:"sr-only"},"Delete policy"))))))))};yr(".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 Pl=({application:e,policy:t,serverGroup:a})=>{var n,r,i;const s=a.type||a.cloudProvider||"aws",l=U.getValue(s,"serverGroup"),o="aws"===s?t.policyName:t.id,c=l.UpsertTargetTrackingModal,d=l.TargetTrackingChart,p=t.targetTrackingConfiguration;return Rt.createElement("div",{className:"TargetTrackingSummary"},Rt.createElement(ne,{Component:()=>Rt.createElement(d,{config:t.targetTrackingConfiguration,serverGroup:a}),placement:"left",title:o},Rt.createElement("div",null,Rt.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Rt.createElement("div",null,Rt.createElement("b",null,"Target"),Rt.createElement("span",{className:"sp-margin-xs-left"},(null==(n=p.predefinedMetricSpecification)?void 0:n.predefinedMetricType)||(null==(r=p.customizedMetricSpecification)?void 0:r.metricName)),Boolean(null==(i=p.customizedMetricSpecification)?void 0:i.statistic)&&Rt.createElement("span",null,` @ ${p.targetValue}`)))),Rt.createElement("div",{className:"actions"},Rt.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"})}},Rt.createElement("span",{className:"glyphicon glyphicon-cog"}),Rt.createElement("span",{className:"sr-only"},"Edit policy")),Rt.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]})})}},Rt.createElement("span",{className:"glyphicon glyphicon-trash"}),Rt.createElement("span",{className:"sr-only"},"Delete policy"))))},zl=({application:e,policy:t,serverGroup:a})=>"TargetTrackingScaling"===(t.policyType?t.policyType:t.targetTrackingConfiguration?"TargetTrackingScaling":"StepScaling")?Rt.createElement(Pl,{application:e,policy:t,serverGroup:a}):Rt.createElement(xl,{application:e,policy:t,serverGroup:a});class Dl extends Ot.Component{constructor(){super(...arguments),this.editAdvancedSettings=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&kt.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 Ot.createElement(x,{heading:"Advanced Settings"},Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},Ot.createElement("dt",null,"Cooldown"),Ot.createElement("dd",null,t.defaultCooldown," seconds"),t.enabledMetrics.length>0&&[Ot.createElement("dt",{key:"t-metrics"},"Enabled Metrics"),Ot.createElement("dd",{key:"d-metrics"},t.enabledMetrics.map((e=>e.metric)).join(", "))],Ot.createElement("dt",null,"Health Check Type"),Ot.createElement("dd",null,t.healthCheckType),Ot.createElement("dt",null,"Grace Period"),Ot.createElement("dd",null,t.healthCheckGracePeriod," seconds"),Ot.createElement("dt",null,"Termination Policies"),Ot.createElement("dd",null,t.terminationPolicies.join(", ")),t.capacityRebalance&&[Ot.createElement("dt",null,"Capacity Rebalance ",Ot.createElement(n,{id:"aws.serverGroup.capacityRebalance"})),Ot.createElement("dd",null,`${t.capacityRebalance}`)]),Sn.adHocInfraWritesEnabled&&Ot.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 &nbsp;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 &nbsp;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 Bl extends Ot.Component{constructor(e){super(e),this.state={changeConfig:this.getChangeConfig(e.serverGroup)}}getChangeConfig(e){const t={metadata:ra(e.entityTags,"creationMetadata")};return Ea(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 Ot.createElement(x,{heading:"Server Group Information",defaultExpanded:!0},Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Created"),Ot.createElement("dd",null,B(e.createdTime)),n&&Ot.createElement(At,{metadata:r.creationMetadata}),n&&Ot.createElement(xt,{changeConfig:t,linkText:"view changes",nameItem:e,viewType:"description"}),Ot.createElement("dt",null,"In"),Ot.createElement("dd",null,Ot.createElement(I,{account:e.account}),e.region),Ot.createElement("dt",null,"VPC"),Ot.createElement("dd",null,Ot.createElement(ur,{vpcId:e.vpcId})),e.vpcId&&e.subnetType&&Ot.createElement("dt",null,"Subnet"),e.vpcId&&e.subnetType&&Ot.createElement("dd",null,e.subnetType),e.asg&&Ot.createElement("dt",null,"Zones"),e.asg&&Ot.createElement("dd",null,Ot.createElement("ul",null,e.asg.availabilityZones.map((e=>Ot.createElement("li",{key:e},e)))))))}}var Fl=Object.defineProperty,Ml=Object.getOwnPropertyDescriptor;let $l=class extends Ot.Component{render(){const{serverGroup:e,app:t}=this.props,a={min:e.asg.minSize,max:e.asg.maxSize,desired:e.asg.desiredCapacity};return Ot.createElement(x,{heading:"Capacity",defaultExpanded:!0},Ot.createElement(Pt,{current:e.instances.length,capacity:a}),Ot.createElement("div",null,Sn.adHocInfraWritesEnabled&&Ot.createElement("a",{className:"clickable",onClick:()=>Xs.show({application:t,serverGroup:e})},"Resize Server Group")),Ot.createElement("div",null,Ot.createElement(zt,{serverGroup:e})))}};$l=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Ml(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&&Fl(t,a,i),i})([ie("amazon.serverGroup.CapacityDetailsSection")],$l);class Ll extends Ot.Component{render(){const{serverGroup:e}=this.props;return e.instanceCounts.total>0?Ot.createElement(x,{heading:"Health",defaultExpanded:!0},Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Instances"),Ot.createElement("dd",null,Ot.createElement(X,{container:e.instanceCounts,className:"pull-left"})))):null}}const Rl=({serverGroup:e})=>{if(!e.mixedInstancesPolicy)return null;const t=e.mixedInstancesPolicy.instancesDistribution;return Ot.createElement(x,{heading:"Instances Distribution"},Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},Ot.createElement(D,{label:"On-Demand Allocation Strategy",helpFieldId:"aws.serverGroup.odAllocationStrategy",value:t.onDemandAllocationStrategy}),Ot.createElement(D,{label:"On-Demand Base Capacity",helpFieldId:"aws.serverGroup.odBase",value:t.onDemandBaseCapacity}),Ot.createElement(D,{label:"On-Demand Percentage Above Base Capacity",helpFieldId:"aws.serverGroup.odPercentAboveBase",value:t.onDemandPercentageAboveBaseCapacity}),Ot.createElement(D,{label:"Spot Allocation Strategy",helpFieldId:"aws.serverGroup.spotAllocationStrategy",value:t.spotAllocationStrategy}),t.spotInstancePools&&Ot.createElement(D,{label:"Spot Instance Pools",helpFieldId:"aws.serverGroup.spotInstancePoolCount",value:t.spotInstancePools}),Ot.createElement(D,{label:"Max Spot Price",helpFieldId:"aws.serverGroup.spotMaxPrice",value:t.spotMaxPrice||"on-demand price, default"})))},Ol=e=>{let t;return(e||"").split(", ").forEach((e=>{const a=e.split("=");2===a.length&&"ancestor_name"===a[0]&&(t=a[1])})),t};class Ul extends Ot.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=Ol(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?Ot.createElement(x,{heading:"Launch Configuration"},Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},Ot.createElement("dt",null,"Name"),Ot.createElement("dd",null,t.launchConfigurationName),Ot.createElement("dt",null,"Image ID"),Ot.createElement("dd",null,t.imageId),a&&a.imageLocation&&Ot.createElement("dt",null,"Image Name"),a&&a.imageLocation&&Ot.createElement("dd",null,a.imageLocation),a&&a.baseImage&&Ot.createElement("dt",null,"Base Image Name"),a&&a.baseImage&&Ot.createElement("dd",null,a.baseImage),Ot.createElement("dt",null,"Instance Type"),Ot.createElement("dd",null,t.instanceType),Ot.createElement("dt",null,"IAM Profile"),Ot.createElement("dd",null,t.iamInstanceProfile),t.instanceMonitoring&&Ot.createElement(Ot.Fragment,null,Ot.createElement("dt",null,"Instance Monitoring"),Ot.createElement("dd",null,t.instanceMonitoring.enabled?"enabled":"disabled")),t.spotPrice&&Ot.createElement("dt",null,"Spot Price"),t.spotPrice&&Ot.createElement("dd",null,t.spotPrice),t.keyName&&Ot.createElement("dt",null,"Key Name"),t.keyName&&Ot.createElement("dd",null,t.keyName),t.kernelId&&Ot.createElement("dt",null,"Kernel ID"),t.kernelId&&Ot.createElement("dd",null,t.kernelId),t.ramdiskId&&Ot.createElement("dt",null,"Ramdisk ID"),t.ramdiskId&&Ot.createElement("dd",null,t.ramdiskId),Ot.createElement("dt",null,"User Data"),t.userData&&Ot.createElement("dd",null,Ot.createElement(Dt,{serverGroupName:e,userData:t.userData})),!t.userData&&Ot.createElement("dd",null,"[none]"))):null}}function Vl(e){return e.instanceTypeOverrides?Ot.createElement(x,{heading:"Instance Types",defaultExpanded:!0,outerDivClassName:"multiple-instance-types-subsection",toggleClassName:"clickable subsection-heading",headingClassName:"collapsible-subheading"},Ot.createElement("table",{className:"table table-condensed packed",id:"MultipleInstanceTypes"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{id:"instanceType"},"Type ",Ot.createElement(n,{id:"aws.serverGroup.multipleInstanceTypes"})),Ot.createElement("th",{id:"weight"},"Weighted Capacity ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})))),Ot.createElement("tbody",null,e.instanceTypeOverrides.map((e=>[Ot.createElement("tr",{key:e.instanceType},Ot.createElement("td",{headers:"instanceType"},e.instanceType),Ot.createElement("td",{headers:"weight"},e.weightedCapacity))]))))):null}yr('.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 -webkit-animation: 0.15 ease-in 0 fadeIn;\n animation: 0.15 ease-in 0 fadeIn;\n -webkit-animation-iteration-count: 1;\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 ql=({serverGroup:e})=>{var t,a,n;const{image:r}=e,i=Ol(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,p=s?e.mixedInstancesPolicy.launchTemplateOverridesForInstanceType:null;return Ot.createElement(x,{heading:"Launch Template"},Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},Ot.createElement(D,{label:"Name",value:l.launchTemplateName}),Ot.createElement(D,{label:"Image ID",value:o.imageId}),(null==r?void 0:r.imageLocation)&&Ot.createElement(D,{label:"Image Name",value:null==r?void 0:r.imageLocation}),i&&Ot.createElement(D,{label:"Base Image Name",value:i}),p&&p.length>0?Ot.createElement(Vl,{instanceTypeOverrides:p}):Ot.createElement(D,{label:"Instance Type",value:o.instanceType}),d&&Ot.createElement(D,{label:"CPU Credit Specification",value:d}),Ot.createElement(D,{label:"IAM Profile",value:o.iamInstanceProfile.name}),o.monitoring&&Ot.createElement(D,{label:"Instance Monitoring",value:o.monitoring.enabled?"enabled":"disabled"}),c&&Ot.createElement(D,{label:"Max Spot Price",value:c}),o.keyName&&Ot.createElement(D,{label:"Key Name",value:o.keyName}),o.kernelId&&Ot.createElement(D,{label:"Kernel ID",value:o.kernelId}),o.ramDiskId&&Ot.createElement(D,{label:"Ramdisk ID",value:o.ramDiskId}),o.userData&&Ot.createElement(D,{label:"User Data",value:Ot.createElement(Dt,{serverGroupName:e.name,userData:o.userData})})))};class Hl extends Ot.Component{render(){return Ot.createElement(x,{heading:"Logs"},Ot.createElement("ul",null,Ot.createElement("li",null,Ot.createElement(zt,{serverGroup:this.props.serverGroup}))))}}class Wl extends Ot.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?Ot.createElement(x,{heading:"Package"},Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},Ot.createElement("dt",null,"Job"),Ot.createElement("dd",null,e.buildInfo.jenkins.name),Ot.createElement("dt",null,"Package"),Ot.createElement("dd",null,e.buildInfo.package_name),Ot.createElement("dt",null,"Build"),Ot.createElement("dd",null,e.buildInfo.jenkins.number),Ot.createElement("dt",null,"Commit"),Ot.createElement("dd",null,t),Ot.createElement("dt",null,"Version"),Ot.createElement("dd",null,e.buildInfo.version),Ot.createElement("dt",null,"Build Link"),Ot.createElement("dd",null,Ot.createElement("a",{target:"_blank",href:a},a)))):null}}var jl=Object.defineProperty,Zl=Object.getOwnPropertyDescriptor;let _l=class extends Ot.Component{constructor(e){super(e)}static arePoliciesDisabled(e){const t=al.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=_l.arePoliciesDisabled(t);return Ot.createElement(x,{cacheKey:"Scaling Policies",heading:({chevron:e})=>Ot.createElement("h4",{className:"collapsible-heading"},e,Ot.createElement("span",null,a&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Policies"))},a&&Ot.createElement("div",{className:"band band-warning"},"Some scaling processes are disabled that may prevent scaling policies from working."),t.scalingPolicies.map((a=>Ot.createElement(zl,{key:a.policyARN,policy:a,serverGroup:t,application:e}))),Sn.adHocInfraWritesEnabled?Ot.createElement(Nl,{serverGroup:t,application:e}):Ot.createElement("p",null,"Can not create scaling policy, because ad-hoc operations are disabled for AWS providers."))}};_l=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Zl(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&&jl(t,a,i),i})([ie("aws.serverGroup.ScalingPoliciesDetailsSection")],_l);class Kl extends Ot.Component{constructor(e){super(e),this.toggleScalingProcesses=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&kt.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=al.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 Ot.createElement(x,{cacheKey:"Scaling Processes",heading:({chevron:e})=>Ot.createElement("h4",{className:"collapsible-heading"},e,Ot.createElement("span",null,t&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),a&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Processes"))},Ot.createElement("ul",{className:"scaling-processes"},e.map((e=>Ot.createElement("li",{key:e.name},Ot.createElement("span",{style:{visibility:e.enabled?"visible":"hidden"},className:"fa fa-check small"}),Ot.createElement("span",{className:e.enabled?"":"text-disabled"},e.name," "),Ot.createElement(n,{content:e.description,placement:"bottom"}),e.suspensionDate&&Ot.createElement("div",{className:"text-disabled small",style:{marginLeft:"35px"}},"Suspended ",B(e.suspensionDate)))))),Sn.adHocInfraWritesEnabled&&Ot.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 Yl extends Ot.Component{render(){const{action:e}=this.props;return Ot.createElement("dl",{className:"horizontal-when-filters-collapsed",style:{marginBottom:"20px"}},Ot.createElement("dt",null,"Schedule"),Ot.createElement("dd",null,e.recurrence),void 0!==e.minSize&&Ot.createElement("dt",null,"Min Size"),void 0!==e.minSize&&Ot.createElement("dd",null,e.minSize),void 0!==e.maxSize&&Ot.createElement("dt",null,"Max Size"),void 0!==e.maxSize&&Ot.createElement("dd",null,e.maxSize),void 0!==e.desiredCapacity&&Ot.createElement("dt",null,"Desired Size"),void 0!==e.desiredCapacity&&Ot.createElement("dd",null,e.desiredCapacity))}}class Xl extends Ot.Component{constructor(e){super(e),this.editScheduledActions=()=>{kt.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=al.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 Ot.createElement(x,{cacheKey:"Scheduled Actions",heading:({chevron:e})=>Ot.createElement("h4",{className:"collapsible-heading"},e,Ot.createElement("span",null,t&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scheduled Actions"))},e.scheduledActions.map(((e,t)=>Ot.createElement(Yl,{key:t,action:e}))),e.scheduledActions.length>0&&Ot.createElement("p",null,Ot.createElement("strong",null,"Note:")," Schedules are evaluated in UTC."),0===e.scheduledActions.length&&Ot.createElement("p",null,"No Scheduled Actions are configured for this server group."),Sn.adHocInfraWritesEnabled&&Ot.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 Jl extends Ot.Component{constructor(e){super(e),this.updateSecurityGroups=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&kt.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 ls.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=ea(n.securityGroups).map((e=>ya(a.securityGroups.data,{accountName:n.account,region:n.region,id:e})||ya(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 Ot.createElement(x,{heading:V.get("Firewalls")},Ot.createElement("ul",null,Jt(t,"name").map((t=>Ot.createElement("li",{key:t.name},Ot.createElement(Ja,{to:"^.firewallDetails",params:{name:t.name,accountId:t.accountName,region:e.region,vpcId:e.vpcId,provider:e.type}},Ot.createElement("a",null,t.name," (",t.id,")")))))),Sn.adHocInfraWritesEnabled&&e.vpcId&&Ot.createElement("a",{className:"clickable",onClick:this.updateSecurityGroups},"Edit ",V.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 Ql extends Ot.Component{render(){const{serverGroup:e}=this.props;return Ot.createElement(x,{heading:"Tags"},0===e.asg.tags.length&&Ot.createElement("div",null,"No tags associated with this server group"),e.asg.tags.length>0&&Ot.createElement("dl",null,Jt(e.asg.tags,"key").map((e=>[Ot.createElement("dt",{key:e.key},e.key),Ot.createElement("dd",{key:e.value},e.value)]))))}}class eo{static listKeyPairs(){return z("/keyPairs").useCache().get().then((e=>e.sort(((e,t)=>e.keyName.localeCompare(t.keyName)))))}}class to{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:wa(this.enabledMetrics),healthCheckTypes:wa(this.healthCheckTypes),terminationPolicies:wa(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=Sn.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=>Ea(e,"backingData.filtered.regions")&&e.backingData.filtered.regions.some((t=>t.name===e.region&&t.deprecated)),Ya.all([o.getCredentialsKeyedByAccount("aws"),this.securityGroupReader.getAllSecurityGroups(),g.listSubnets(),o.getPreferredZonesByAccount("aws"),eo.listKeyPairs(),this.awsInstanceTypeService.getAllTypesByRegion(),Ya.when(wa(this.enabledMetrics)),Ya.when(wa(this.healthCheckTypes)),Ya.when(wa(this.terminationPolicies))]).then((([a,n,r,i,s,l,o,c,d])=>{var p,u;const m={credentialsKeyedByAccount:a,securityGroups:n,subnets:r,preferredZones:i,keyPairs:s,instanceTypesInfo:l,enabledMetrics:o,healthCheckTypes:c,terminationPolicies:d};let g=Ya.when();if(m.accounts=Ca(m.credentialsKeyedByAccount),m.filtered={},m.scalingProcesses=al.listProcesses(),m.appLoadBalancers=e.getDataSource("loadBalancers").data,m.managedResources=null==(u=null==(p=e.getDataSource("managedResources"))?void 0:p.data)?void 0:u.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=ta(this.getRegionalSecurityGroups(t),"id");fa(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=la(e.backingData.credentialsKeyedByAccount,(t=>t.defaultKeyPair&&e.keyPair&&0===e.keyPair.indexOf(t.defaultKeyPair.replace("{{region}}","")))),n=ea(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=ta(a,"name");e.instanceType&&!n.includes(e.instanceType)&&(t.dirty.instanceType=e.instanceType,e.instanceType=null);const r=ta(e.launchTemplateOverridesForInstanceType,"instanceType"),i=fa(r,n),s=sa(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 ga(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=ya(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=ea(e.backingData.subnets).filter({account:e.credentials,region:e.region}).reject({target:"elb"}).reject({purpose:null}).uniqBy("purpose").value(),ea(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 ea(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=ya(a,{id:e});return t?t.name:e})),i=e.securityGroups.map((e=>{const t=ya(a,{id:e})||ya(a,{name:e});return t?t.name:null})).map((e=>ya(n,{name:e}))).filter((e=>e)),s=ta(i,"name"),l=Sa(r,s);e.securityGroups=ta(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 ea(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 _t(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=fa(e,t),[r,i]=da(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=fa(r.concat(o),s),e.vpcId?delete e.vpcLoadBalancers:e.vpcLoadBalancers=fa(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=ya(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 ga(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=Zt(n[e.region].sort());else{e.availabilityZones=fa(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 ga(t.dirty,this.configureSecurityGroupOptions(e).dirty),ga(t.dirty,this.configureLoadBalancerOptions(e).dirty),e.viewState.dirty=e.viewState.dirty||{},ga(e.viewState.dirty,t.dirty),t},e.regionChanged=e=>{const t={dirty:{}},a=e.backingData.filtered;return ga(t.dirty,this.configureSubnetPurposes(e).dirty),e.region?(ga(t.dirty,e.subnetChanged(e).dirty),ga(t.dirty,this.configureInstanceTypes(e).dirty),this.configureAvailabilityZones(e),ga(t.dirty,e.usePreferredZonesChanged(e).dirty),ga(t.dirty,this.configureImages(e).dirty),ga(t.dirty,this.configureKeyPairs(e).dirty)):a.regionalAvailabilityZones=null,Ft(e),t},e.clusterChanged=e=>{e.moniker=re.getMoniker(e.application,e.stack,e.freeFormDetails),Ft(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,la(a.filtered.regions,{name:e.region})?ga(t.dirty,e.regionChanged(e).dirty):(e.region=null,t.dirty.region=!0)}else e.region=null;return Ft(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)}}to.$inject=["securityGroupReader","awsInstanceTypeService","cacheInitializer","loadBalancerReader","serverGroupCommandRegistry"];const ao="spinnaker.amazon.serverGroup.configure.service";t("spinnaker.amazon.serverGroup.configure.service",[Ie,"spinnaker.amazon.instanceType.service",Ae,st,Bt]).service("awsServerGroupConfigurationService",to);e.module("spinnaker.amazon.serverGroupCommandBuilder.service",[Mt,"spinnaker.amazon.serverGroup.configure.service"]).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||Sn.defaults.account,i=a.region||e.defaultRegions.aws||Sn.defaults.region,l=a.subnet||Sn.defaults.subnetType||"",c=o.getAvailabilityZonesForAccountAndRegion("aws",r,i);return t.all([c,n]).then((function([t,n]){var o,c,d,p,u,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=Sn.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==(p=e.attributes)?void 0:p.platformHealthOnlyShowOverride)&&(null==(u=e.attributes)?void 0:u.platformHealthOnly)&&(w.interestingHealthProviderNames=["Amazon"]),"test"===r&&(null==(m=Sn.serverGroups)?void 0:m.enableIPv6)&&(w.associateIPv6Address=!0),null==(g=Sn.serverGroups)?void 0:g.enableIMDSv2){const t=Sn.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,p,u,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==(u=null==(p=i.mixedInstancesPolicy)?void 0:p.launchTemplates[0])?void 0:u.launchTemplateData)?void 0:m.instanceType]}else i.launchTemplate?y=[qt.get(i,"launchTemplate.launchTemplateData.instanceType")]:i.launchConfig&&(y=[qt.get(i,"launchConfig.instanceType")]);const b=a.getCategoryForMultipleInstanceTypes("aws",y);return t.all([h,f,b]).then((([t,a,o])=>{var d,p,u,m,g,h,f,y,b,E,w,C,S;const k=i.asg.availabilityZones.sort();let N=!1;const T=t[i.account];if(T){const e=T[i.region].sort();N=k.join(",")===e.join(",")}const G=["Launch","Terminate","AddToLoadBalancer"],I=(null!=(u=null==(p=null==(d=n.attributes)?void 0:d.providerSettings)?void 0:p.aws)?u:{}).useAmiBlockDeviceMappings||!1,A={},x=["spinnaker:application","spinnaker:stack","spinnaker:details"];i.asg.tags&&i.asg.tags.filter((e=>!x.includes(e.key))).forEach((e=>{A[e.key]=e.value}));const P={application:n.name,strategy:"",stack:v.stack,freeFormDetails:v.freeFormDetails,credentials:i.account,cooldown:i.asg.defaultCooldown,enabledMetrics:qt.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:k,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,A),targetGroups:i.targetGroups,useAmiBlockDeviceMappings:I,copySourceCustomBlockDeviceMappings:"clone"===c,viewState:{instanceProfile:o,useAllImageSelection:!1,useSimpleCapacity:i.asg.minSize===i.asg.maxSize,usePreferredZones:N,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)&&(P.interestingHealthProviderNames=["Amazon"]),"editPipeline"===c){P.useSourceCapacity=!0,P.viewState.useSimpleCapacity=!1,P.strategy="redblack";const e=r.getStrategy("redblack");e.initializationMethod&&e.initializationMethod(P),P.suspendedProcesses=[]}const z=i.asg.vpczoneIdentifier;if(""!==z){const e=z.split(",")[0],t=a.find((t=>t.id===e));P.subnetType=t.purpose,P.vpcId=t.vpcId}else P.subnetType="",P.vpcId=null;if(i.launchConfig&&(e.extend(P,{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&&(P.base64UserData=i.launchConfig.userData),P.viewState.imageId=i.launchConfig.imageId,P.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,P.instanceType=t.instanceType,P.viewState.useSimpleInstanceTypeSelector=!0),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,P.securityGroups=t.networkInterfaces?(null!=(w=t.networkInterfaces.find((e=>0===e.deviceIndex)))?w:{}).groups:t.securityGroups,P.onDemandAllocationStrategy=e.instancesDistribution.onDemandAllocationStrategy,P.onDemandBaseCapacity=e.instancesDistribution.onDemandBaseCapacity,P.onDemandPercentageAboveBaseCapacity=e.instancesDistribution.onDemandPercentageAboveBaseCapacity,P.spotAllocationStrategy=e.instancesDistribution.spotAllocationStrategy,P.spotInstancePools=e.instancesDistribution.spotInstancePools,e.launchTemplateOverridesForInstanceType?P.launchTemplateOverridesForInstanceType=function(e){let t=1;return qt.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):P.instanceType=t.instanceType,P.viewState.useSimpleInstanceTypeSelector=l(P)}const n=qt.get(t,"networkInterfaces[0]"),r=Sn.serverGroups,s=i.accountDetails&&"test"===i.accountDetails.environment,o=r&&r.enableIPv6&&r.setIPv6InTest&&s;e.extend(P,{iamRole:t.iamInstanceProfile.name,keyPair:t.keyName,associateIPv6Address:o||Boolean(n),ramdiskId:t.ramdiskId,instanceMonitoring:t.monitoring&&t.monitoring.enabled,ebsOptimized:t.ebsOptimized,spotPrice:a||void 0,requireIMDSv2:Boolean("required"===(null==(C=t.metadataOptions)?void 0:C.httpTokens)),unlimitedCpuCredits:t.creditSpecification?"unlimited"===t.creditSpecification.cpuCredits:void 0}),P.viewState.imageId=t.imageId}if("clone"===c&&i.image&&i.image.name&&(P.amiName=i.image.name),i.launchConfig&&i.launchConfig.securityGroups.length&&(P.securityGroups=i.launchConfig.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.securityGroups.length&&(P.securityGroups=i.launchTemplate.launchTemplateData.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.networkInterfaces){const e=null!=(S=i.launchTemplate.launchTemplateData.networkInterfaces.find((e=>0===e.deviceIndex)))?S:{};P.securityGroups=e.groups}return P}))},buildNewServerGroupCommandForPipeline:function(){return t.when({viewState:{requiresTemplateSelection:!0}})},buildServerGroupCommandFromPipeline:function(n,r){const s=qt.cloneDeep(r),o=Object.keys(s.availabilityZones)[0],c=s.launchTemplateOverridesForInstanceType?s.launchTemplateOverridesForInstanceType.map((e=>e.instanceType)):[s.instanceType],d=a.getCategoryForMultipleInstanceTypes("aws",c),p={account:s.account,region:o};return t.all([i(n,p),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}}}]);t("spinnaker.amazon.serverGroup.editAsgAdvancedSettings.modal.controller",["spinnaker.amazon.serverGroupCommandBuilder.service"]).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}]);t("spinnaker.amazon.serverGroup.details.rollback.controller",[$t]).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=ra(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=ra(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"}}]);t("spinnaker.amazon.scalingPolicy.scalingPolicySummary.component",[]).component("scalingPolicySummary",Xa(L(zl,"scalingPolicySummary"),["application","policy","serverGroup"]));t("spinnaker.amazon.scalingPolicy.module",["spinnaker.amazon.scalingPolicy.scalingPolicySummary.component"]);e.module("spinnaker.amazon.serverGroup.details.autoscaling.process.controller",[]).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=qt.chain(t.command).filter({enabled:!0}).map("name").value(),l=qt.chain(t.command).filter({enabled:!1}).map("name").value();this.isDirty=function(){const e=qt.chain(t.command).filter({enabled:!0}).map("name").value(),a=qt.chain(t.command).filter({enabled:!1}).map("name").value(),n=qt.intersection(l,e),r=qt.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=qt.chain(t.command).filter({enabled:!0}).map("name").value(),a=qt.chain(t.command).filter({enabled:!1}).map("name").value(),i=qt.intersection(l,e),o=qt.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}]);t("spinnaker.amazon.serverGroup.details.scheduledActions.editScheduledActions.modal.controller",[]).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}]);t("spinnaker.amazon.serverGroup.details.securityGroup.editSecurityGroups.modal.controller",[$t,Ie]).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=qt.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 ${V.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}]);t("spinnaker.amazon.serverGroup.details",["spinnaker.amazon.scalingPolicy.module","spinnaker.amazon.serverGroup.details.securityGroup.editSecurityGroups.modal.controller","spinnaker.amazon.serverGroup.details.autoscaling.process.controller","spinnaker.amazon.serverGroup.details.scheduledActions.editScheduledActions.modal.controller","spinnaker.amazon.serverGroup.editAsgAdvancedSettings.modal.controller","spinnaker.amazon.serverGroup.details.rollback.controller"]);t("spinnaker.amazon.serverGroup.transformer",[]).service("awsServerGroupTransformer",class{addComparator(e){if(e.comparisonOperator)switch(e.comparisonOperator){case"LessThanThreshold":e.comparator="&lt;";break;case"GreaterThanThreshold":e.comparator="&gt;";break;case"LessThanOrEqualToThreshold":e.comparator="&le;";break;case"GreaterThanOrEqualToThreshold":e.comparator="&ge;"}}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})),Vn.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"}}}}});t("spinnaker.amazon.subnet.renderer",[]).service("awsSubnetRenderer",class{render(e){return e.subnetType}});Lt.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=Sn.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 ${V.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 ${V.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}}});t("spinnaker.amazon.vpc",[]).component("vpcTag",Xa(L(ur,"vpcTag"),["vpcId"]));yr('.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 no="spinnaker.amazon";t("spinnaker.amazon",["spinnaker.amazon.react","spinnaker.amazon.pipeline.stage.bakeStage","spinnaker.amazon.pipeline.stage.cloneServerGroupStage","spinnaker.amazon.pipeline.stage.aws.destroyAsgStage","spinnaker.amazon.pipeline.stage.disableAsgStage","spinnaker.amazon.pipeline.stage.disableClusterStage","spinnaker.amazon.pipeline.stage.rollbackClusterStage","spinnaker.amazon.pipeline.stage.enableAsgStage","spinnaker.amazon.pipeline.stage.findAmiStage","spinnaker.amazon.pipeline.stage.findImageFromTagsStage","spinnaker.amazon.pipeline.stage.modifyScalingProcessStage","spinnaker.amazon.pipeline.stage.aws.resizeAsgStage","spinnaker.amazon.pipeline.stage.scaleDownClusterStage","spinnaker.amazon.pipeline.stage.aws.shrinkClusterStage","spinnaker.amazon.pipeline.stage.tagImageStage","spinnaker.amazon.serverGroup.details","spinnaker.amazon.common","spinnaker.amazon.serverGroup.transformer","spinnaker.amazon.instanceType.service","spinnaker.amazon.loadBalancer","spinnaker.amazon.function","spinnaker.amazon.instance.details.controller","spinnaker.amazon.securityGroup","spinnaker.amazon.subnet.renderer","spinnaker.amazon.vpc","spinnaker.amazon.search.searchResultFormatter","spinnaker.amazon.pipeline.stages.deployCloudFormationStage","spinnaker.amazon.cloudformation.entry.component","spinnaker.amazon.cloudformation.changetset.info.component","spinnaker.amazon.deployCloudFormation.service","spinnaker.application.instanceStatus.component","spinnaker.application.instanceTags.component","spinnaker.application.instanceSecurityGroups.component","spinnaker.application.instanceDns.component","spinnaker.application.amazonInstanceInformation.component","spinnaker.amazon.pipeline.stage.Aws.LambdaDeleteStage","spinnaker.amazon.pipeline.stage.Aws.LambdaDeploymentStage","spinnaker.amazon.pipeline.stage.Aws.LambdaInvokeStage","spinnaker.amazon.pipeline.stage.Aws.LambdaUpdateCodeStage"]).config((()=>{U.registerProvider("aws",{name:"Amazon",adHocInfrastructureWritesEnabled:Sn.adHocInfraWritesEnabled,logo:{path:"amazon.logo352d4e042476837f.svg"},image:{reader:Qn},serverGroup:{transformer:"awsServerGroupTransformer",detailsActions:tl,detailsGetter:nl,detailsSections:[Bl,$l,Ll,Rl,Ul,ql,Jl,Kl,_l,Xl,Ql,Wl,Dl,Hl],CloneServerGroupModal:_s,commandBuilder:"awsServerGroupCommandBuilder",configurationService:"awsServerGroupConfigurationService",scalingActivitiesEnabled:!0,TargetTrackingChart:ol,UpsertStepPolicyModal:kl,UpsertTargetTrackingModal:hl},instance:{instanceTypeService:"awsInstanceTypeService",detailsTemplateUrl:"amazon/src/instance/details/instanceDetails.html",detailsController:"awsInstanceDetailsCtrl"},loadBalancer:{transformer:Nr,detailsTemplateUrl:"amazon/src/loadBalancer/details/loadBalancerDetails.html",detailsController:"awsLoadBalancerDetailsCtrl",CreateLoadBalancerModal:gi,targetGroupDetailsTemplateUrl:"amazon/src/loadBalancer/details/targetGroupDetails.html",targetGroupDetailsController:"awsTargetGroupDetailsCtrl",ClusterContainer:Er,LoadBalancersTag:kr},function:{details:Xn,CreateFunctionModal:Wn,transformer:Gn},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 &rarr; Instance</dt>\n <dd ng-repeat="listener in ctrl.loadBalancer.elb.listenerDescriptions">\n {{listener.listener.protocol}}:{{listener.listener.loadBalancerPort}} &rarr;\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}} &rarr;</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}} &rarr; {{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{no as AMAZON_MODULE,Sn as AWSProviderSettings,ao as AWS_SERVER_GROUP_CONFIGURATION_SERVICE,Dl as AdvancedSettingsDetailsSection,wl as AlarmConfigurer,$l as AmazonCapacityDetailsSection,$r as AmazonCertificateReader,Pr as AmazonCertificateSelectField,Xn as AmazonFunctionDetails,cs as AmazonImageSelectInput,Bl as AmazonInfoDetailsSection,mr as AmazonInstanceWriter,gi as AmazonLoadBalancerChoiceModal,Er as AmazonLoadBalancerClusterContainer,wr as AmazonLoadBalancerDataUtils,kr as AmazonLoadBalancersTag,Xs as AmazonResizeServerGroupModal,kl as AmazonUpsertScalingPolicyModal,hl as AmazonUpsertTargetTrackingModal,Gn as AwsFunctionTransformer,Nr as AwsLoadBalancerTransformer,Ks as AwsModalFooter,Zn as AwsReactInject,_n as AwsReactInjector,to as AwsServerGroupConfigurationService,bl as COMPARATORS,Wn as CreateLambdaFunction,Nl as CreateScalingPolicyButton,rl as DateLineChart,cl as DimensionsEditor,jn as FunctionActions,$n as FunctionBasicInformation,Ll as HealthDetailsSection,ss as IPRangeRules,fr as InstanceDns,pr as InstanceInformation,vr as InstanceStatus,Rl as InstancesDistributionDetailsSection,eo as KeyPairsReader,Ul as LaunchConfigDetailsSection,ql as LaunchTemplateDetailsSection,ui as LoadBalancerTypes,Hl as LogsDetailsSection,il as MetricAlarmChart,pl as MetricSelector,Wl as PackageDetailsSection,fl as PolicyTypeSelectionModal,_l as ScalingPoliciesDetailsSection,vl as ScalingPolicyAdditionalSettings,zl as ScalingPolicySummary,Tl as ScalingPolicyWriter,Kl as ScalingProcessesDetailsSection,Xl as ScheduledActionsDetailsSection,Rs as SecurityGroupSelector,Jl as SecurityGroupsDetailsSection,js as ServerGroupAdvancedSettings,Vs as ServerGroupAdvancedSettingsCommon,ps as ServerGroupBasicSettings,gs as ServerGroupCapacity,Fs as ServerGroupInstanceType,Ls as ServerGroupLoadBalancers,Us as ServerGroupSecurityGroups,Os as ServerGroupSecurityGroupsRemoved,Ms as ServerGroupZones,Sl as StepPolicyAction,xl as StepPolicySummary,Yr as SubnetSelectField,Kr as SubnetSelectInput,Ql as TagsDetailsSection,br as TargetGroup,Ir as TargetGroupDetails,ul as TargetMetricFields,ml as TargetTrackingAdditionalSettings,ol as TargetTrackingChart,Pl as TargetTrackingSummary,Vn as VpcReader,hr as applyHealthCheckInfoToTargetGroups,gr as getAllTargetGroups,Ol 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 G,AccountTag as I,Overrides as A,CollapsibleSection as x,HelpContentsRegistry as P,REST as D,LabeledValue as z,timestamp as B,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 Ge,SECURITY_GROUP_READER as Ie,LOAD_BALANCER_READ_SERVICE as Ae,MANAGED_RESOURCE_DETAILS_INDICATOR as xe,APPLICATION_STATE_PROVIDER as Pe,Registry as De,BakeExecutionLabel as ze,AuthenticationService as Be,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,ToggleButtonGroup as gt,ToggleSize as ht,usePrevious as ft,NgReact as vt,PlatformHealthOverride as yt,MapEditor as bt,UserVerification as Et,TaskMonitorWrapper as wt,MinMaxDesiredChanges as Ct,ServerGroupWarningMessageService as St,ModalInjector as kt,ClusterTargetBuilder as Nt,ServerGroupReader as Tt,CloudMetricsReader as Gt,TaskMonitorModal as It,EntitySource as At,ViewChangesLink as xt,CapacityDetailsSection as Pt,ViewScalingActivitiesLink as Dt,ShowUserData as zt,SERVER_GROUP_COMMAND_REGISTRY_PROVIDER as Bt,setMatchingResourceSummary as Ft,INSTANCE_TYPE_SERVICE as Mt,SERVER_GROUP_WRITER as $t,ApplicationNameValidator as Lt}from"@spinnaker/core";import*as Rt from"react";import Ot,{useState as Vt,useEffect as Ut}from"react";import qt,{isEmpty as Ht,forOwn as Wt,uniqBy as jt,cloneDeep as Zt,flatten as _t,isNil as Kt,orderBy as Yt,isEqual as Xt,sortBy as Jt,filter as Qt,chain as ea,map as ta,pickBy as aa,groupBy as na,get as ra,uniq as ia,difference as sa,some as la,isNumber as oa,set as ca,partition as da,every as ua,values as pa,head as ma,extend as ga,isString as ha,intersection as fa,keyBy as va,find as ya,flatMap as ba,has as Ea,clone as wa,keys as Ca,xor as Sa}from"lodash";import ka from"classnames";import{Subject as Na,from as Ta,combineLatest as Ga,BehaviorSubject as Ia,of as Aa,Observable as xa}from"rxjs";import{map as Pa,distinctUntilChanged as Da,shareReplay as za,switchMap as Ba,withLatestFrom as Fa,takeUntil as Ma,tap as $a,mergeMap as La,catchError as Ra,debounceTime as Oa,take as Va}from"rxjs/operators";import{Dropdown as Ua,Modal as qa,Button as Ha,Tooltip as Wa,OverlayTrigger as ja,Checkbox as Za,ModalFooter as _a,MenuItem as Ka}from"react-bootstrap";import{$q as Ya}from"ngimport";import{react2angular as Xa}from"react2angular";import{UISref as Ja,UISrefActive as Qa}from"@uirouter/react";import{UIRouterContextComponent as en}from"@uirouter/react-hybrid";import tn from"@uirouter/angularjs";import an from"angular-ui-bootstrap";import nn from"react-select";import{SortableHandle as rn,arrayMove as sn,SortableElement as ln,SortableContainer as on}from"react-sortable-hoc";import{Form as cn,Field as dn}from"formik";import un from"react-virtualized-select";import{Chart as pn,LineController as mn,LineElement as gn,PointElement as hn,LinearScale as fn,Title as vn,TimeScale as yn,Tooltip as bn,Legend as En,Filler as wn}from"chart.js";import"chartjs-adapter-luxon";var Cn;const Sn=a.providers.aws||{defaults:{}};Sn&&(Sn.adHocInfraWritesEnabled=null==(Cn=Sn.adHocInfraWritesEnabled)||Cn,Sn.resetToOriginal=a.resetProvider("aws"));const kn={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:()=>{}};t("spinnaker.amazon.footer",[]).component("awsFooter",kn);t("spinnaker.amazon.common",["spinnaker.amazon.footer"]);class Nn extends Ot.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 Ot.createElement("div",{className:"form-group",style:{marginTop:"20px"}},Ot.createElement("div",{className:"well-compact alert alert-warning"},Ot.createElement("strong",null,"Note:")," a rolling push only updates the"," ",Ot.createElement("em",null,"launch ",Boolean(null==(e=Sn.serverGroups)?void 0:e.enableLaunchTemplates)?"template":"configuration")," ","for the auto scaling group.",Ot.createElement("br",null)," Changes to the following fields will be ignored:",Ot.createElement("ul",null,Ot.createElement("li",null,"Account, Region, Subnet Type"),Ot.createElement("li",null,"Capacity"),Ot.createElement("li",null,"Load Balancers"),Ot.createElement("li",null,"Health Check Configuration"),Ot.createElement("li",null,"Termination Policies, Enable Traffic flag"))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:t.termination.relaunchAllInstances,onChange:e=>this.handleChange("relaunchAllInstances",e.target.checked)}),Ot.createElement("b",null,"Relaunch all instances"),Ot.createElement(n,{id:"strategy.rollingPush.relaunchAll"})))),!t.termination.relaunchAllInstances&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},"Total relaunches",Ot.createElement(n,{id:"strategy.rollingPush.totalRelaunches"})),Ot.createElement("div",{className:"col-md-2"},Ot.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)&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},"Concurrent relaunches",Ot.createElement(n,{id:"strategy.rollingPush.concurrentRelaunches"})),Ot.createElement("div",{className:"col-md-2"},Ot.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)&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},"Order",Ot.createElement(n,{id:"strategy.rollingPush.order"})),Ot.createElement("div",{className:"col-md-3"},Ot.createElement("select",{className:"input input-sm",style:{width:"100px"},value:t.termination.order,onChange:e=>this.handleChange("order",e.target.value)},Ot.createElement("option",{value:"oldest"},"oldest first"),Ot.createElement("option",{value:"newest"},"newest first")))))}}var Tn;r.registerStrategy({label:"Rolling Push (not recommended)",description:`Updates the launch ${(null==(Tn=Sn.serverGroups)?void 0:Tn.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:Nn,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 Gn{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:Ht(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||Sn.defaults.account,cloudProvider:"aws",detail:"",region:e.defaultRegions.aws||Sn.defaults.region,envVariables:{},tracingConfig:{mode:"PassThrough"},kmskeyArn:"",vpcId:"",subnetIds:[],securityGroupIds:[],timeout:3,deadLetterConfig:{targetArn:""},operation:"",targetGroups:""}}}const In=(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+=,.@-_/]+`,An=(e,t)=>e.match(/^[0-9A-Za-z.-]*[^.]$/)?void 0:`Invalid S3 Bucket name. ${t} must match regular expression: [0-9A-Za-z.-]*[^.]$`,xn=(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.-]+:./`,Pn=(e,t)=>Ht(e)?`At least one ${t} is required`:void 0,Dn=(e,t)=>e.match(/^[0-9A-Za-z]*$/)?void 0:`Invalid String Value. ${t} must match regular expression: [0-9A-Za-z]`;class zn extends Ot.Component{constructor(e){super(e)}validate(e){const t=new i(e);return t.field("role","Role ARN").required().withValidators(In),t.validateForm()}render(){return Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-11"},Ot.createElement("div",{className:"sp-margin-m-bottom"},Ot.createElement(s,{name:"role",label:"Role ARN",input:e=>Ot.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"}),required:!0}))))}}const Bn=["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"],Fn="(Optional) Stack is naming components of a function, used to create vertical stacks of dependent services for integration testing.",Mn="(Optional) Detail is a string of free-form alphanumeric characters to describe any other variables in naming a function.";class $n extends Ot.Component{constructor(){super(...arguments),this.state={accounts:[],existingFunctionNames:[],regions:[]},this.props$=new Na,this.destroy$=new Na}validate(e){const t=new i(e);t.field("s3bucket","S3 Bucket Name").optional().withValidators(An);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(Pa((e=>e.formik.values))),t={account$:e.pipe(Pa((e=>e.credentials)),Da()),region$:e.pipe(Pa((e=>e.region)),Da()),functionName$:e.pipe(Pa((e=>e.functionName)),Da()),runtime$:e.pipe(Pa((e=>e.runtime)),Da()),s3bucket$:e.pipe(Pa((e=>e.s3bucket)),Da()),s3key$:e.pipe(Pa((e=>e.s3key)),Da()),handler$:e.pipe(Pa((e=>e.handler)),Da())},a=Ta(o.listAccounts("aws")).pipe(za(1)),n=Ga([t.account$,a]).pipe(Ba((([e,t])=>o.getRegionsForAccount(e))),za(1)),r=this.props.app.getDataSource("functions").data$,i=Ga([r,t.account$,t.region$]).pipe(Pa((([e,t,a])=>e.filter((e=>e.account===t&&e.region===a)).map((e=>e.functionName)))),za(1));n.pipe(Fa(t.region$),Ma(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(Ma(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=ka({well:!0,"alert-danger":!!t.functionName,"alert-info":!t.functionName});return Ot.createElement("div",{className:"container-fluid form-horizontal "},e&&Ot.createElement("div",{className:o},Ot.createElement("strong",null,"Your function will be named: "),Ot.createElement(n,{id:"aws.function.name"}),Ot.createElement("span",null,this.props.app.name,"-",a.functionName),Ot.createElement(s,{name:"functionName",input:()=>null})),Ot.createElement(s,{name:"credentials",label:"Account",input:e=>Ot.createElement(c,{...e,stringOptions:r.map((e=>e.name)),clearable:!0})}),Ot.createElement(s,{name:"region",label:"Region",input:e=>Ot.createElement(c,{...e,stringOptions:i.map((e=>e.name)),clearable:!0})}),Ot.createElement(s,{name:"functionName",label:"Function Name",help:Ot.createElement(n,{id:"aws.function.name"}),input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"runtime",label:"Runtime",help:Ot.createElement(n,{id:"aws.function.runtime"}),input:e=>Ot.createElement(c,{...e,stringOptions:Bn,clearable:!0})}),Ot.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Ot.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Ot.createElement(l,{...e,placeholder:"S3 bucket name"})}),Ot.createElement(s,{name:"s3key",label:"S3 Key",help:Ot.createElement(n,{id:"aws.function.s3key"}),input:e=>Ot.createElement(l,{...e,placeholder:"object.zip"})}),Ot.createElement(s,{name:"handler",label:"Handler",help:Ot.createElement(n,{id:"aws.function.handler"}),input:e=>Ot.createElement(l,{...e,placeholder:"filename.method"})}),Ot.createElement(s,{name:"publish",label:"Publish",input:e=>Ot.createElement(d,{...e})}))}}class Ln extends Ot.Component{constructor(e){super(e),this.validate=e=>{const t=new i(e);return t.field("deadLetterConfig.targetArn","Target ARN").optional().withValidators(xn),t.validateForm()}}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},"Dead Letter Config",Ot.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Ot.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Ot.createElement(l,{...e})}),"X-Ray Tracing",Ot.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Ot.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Ot.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}}class Rn extends Ot.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("kmskeyArn","KMS Key ARN").optional().withValidators(xn),t.validateForm()}}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},Ot.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Ot.createElement(u,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Ot.createElement(s,{name:"kmskeyArn",label:"Key ARN",help:Ot.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Ot.createElement(l,{...e})}))}}class On extends Ot.Component{constructor(){super(...arguments),this.validate=()=>({})}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},Ot.createElement(s,{name:"description",label:"Description",input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Ot.createElement(p,{...e,min:128,max:3008})}),Ot.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Ot.createElement(p,{...e,min:1,max:900})}),Ot.createElement(s,{name:"targetGroups",label:"Target Group Name",input:e=>Ot.createElement(l,{...e})}))}}class Vn extends Ot.Component{constructor(){super(...arguments),this.validate=e=>{const t=new i(e);return t.field("tags","Tag").required().withValidators(Pn),t.validateForm()}}render(){return Ot.createElement("div",{className:"container-fluid form-horizontal "},Ot.createElement(s,{name:"tags",input:e=>Ot.createElement(u,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}))}}class Un{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 qn extends Ot.Component{constructor(e){super(e),this.state={vpcOptions:[],accounts:null,regions:[],subnets:[],availableSubnets:[],securityGroups:null},this.props$=new Na,this.destroy$=new Na,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 Wt(e,(function(e,n){n===t.credentials&&Wt(e,(function(e,n){"aws"===n&&Wt(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(){Ta(Un.listVpcs()).pipe(Ma(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 jt(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(Ma(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 Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-11"},Ot.createElement("div",{className:"sp-margin-m-bottom"},a.credentials&&Ot.createElement(s,{name:"vpcId",label:"VPC Id",help:Ot.createElement(n,{id:"aws.function.vpc.id"}),input:t=>Ot.createElement(c,{...t,stringOptions:e.filter((e=>e.account===a.credentials)).map((e=>e.id)),clearable:!0}),onChange:this.setVpc,required:!1})),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Subnets "),Ot.createElement(n,{id:"aws.function.subnet"})),Ot.createElement("div",{className:"col-md-7"},0===r.length&&Ot.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC"),a.vpcId?Ot.createElement(f,{multi:!0,options:r,value:a.subnetIds,onChange:this.handleSubnetUpdate}):null)),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Security Groups "),Ot.createElement(n,{id:"aws.function.subnet"})),Ot.createElement("div",{className:"col-md-7"},0===i.length&&Ot.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC"),a.credentials&&a.vpcId?Ot.createElement(f,{multi:!0,options:i,value:a.securityGroupIds,onChange:this.handleSecurityGroupsUpdate}):null))))}}const Hn=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.submit=e=>{const{app:t}=this.props,{isNew:a}=this.state,n=Zt(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 Gn,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(Hn,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}`),Ot.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})=>Ot.createElement(Ot.Fragment,null,Ot.createElement(w,{label:"Basic information",wizard:i,order:a(),render:({innerRef:a})=>Ot.createElement($n,{ref:a,app:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Execution Role",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(zn,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Environment",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(Rn,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Tags",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(Vn,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Settings",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(On,{ref:e,formik:t,isNew:r,functionDef:n})}),Ot.createElement(w,{label:"Network",wizard:i,order:a(),render:({innerRef:a})=>Ot.createElement(qn,{ref:a,app:e,formik:t,isNew:r})}),Ot.createElement(w,{label:"Debugging and Error Handling",wizard:i,order:a(),render:({innerRef:e})=>Ot.createElement(Ln,{ref:e,formik:t,isNew:r,functionDef:n})}))})}};let Wn=Hn;Wn.defaultProps={closeModal:C,dismissModal:C};class jn extends Ot.Component{constructor(e){super(e),this.editFunction=()=>{const{functionDef:e}=this.props,{application:t}=this.state;Wn.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 Ot.createElement("div",{style:{display:"inline-block"}},Sn.adHocInfraWritesEnabled&&Ot.createElement(Ua,{className:"dropdown",id:"function-actions-dropdown"},Ot.createElement(Ua.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Ot.createElement("span",null,"Function Actions")),Ot.createElement(Ua.Menu,{className:"dropdown-menu"},Ot.createElement("li",{className:n?"":"disabled"},Ot.createElement("a",{className:"clickable",onClick:this.editFunction},"Edit Function")),t.functionName&&Ot.createElement("li",null,Ot.createElement("a",{className:"clickable",onClick:this.deleteFunction},"Delete Function")),a&&a.feature.entityTags&&Ot.createElement(N,{component:t,application:e,entityType:"function",onUpdate:this.entityTagUpdate}))))}}class Zn 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 _n=new Zn;var Kn=Object.defineProperty,Yn=Object.getOwnPropertyDescriptor;let Xn=class extends Ot.Component{constructor(e){super(e),this.destroy$=new Na,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))?Ta(_n.functionReader.getFunctionDetails("aws",t.account,t.region,t.functionName)).pipe(Ma(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;Ta(t.ready()).pipe(Ma(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 Ot.createElement(G,{loading:t});const n=Ot.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Last Modified "),Ot.createElement("dd",null,a.lastModified),Ot.createElement("dt",null,"In"),Ot.createElement("dd",null,Ot.createElement(I,{account:a.account})," ",a.region),Ot.createElement("dt",null,"VPC"),Ot.createElement("dd",null,a.vpcConfig?a.vpcConfig.vpcId:"Default"),Ot.createElement("dt",null,"Function ARN"),Ot.createElement("dd",null,a.functionArn),Ot.createElement("dt",null,"Revision ID"),Ot.createElement("dd",null,a.revisionId),Ot.createElement("dt",null,"Version"),Ot.createElement("dd",null,a.version)),r=Ot.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.eventSourceMappings&&0!==a.eventSourceMappings.length?a.eventSourceMappings.map((e=>Ot.createElement(Ot.Fragment,null,Ot.createElement("h5",null,Ot.createElement("strong",null,"Event Source")),Ot.createElement("dl",null,Ot.createElement("dt",null,"ARN"),Ot.createElement("dd",null,e.eventSourceArn),Ot.createElement("dt",null,"State"),Ot.createElement("dd",null,e.state))))):"None"),i=Ot.createElement("dl",{className:"horizontal-when-filters-collapsed dl-horizontal dl-narrow"},a.aliasConfigurations&&0!==a.aliasConfigurations.length?a.aliasConfigurations.map((e=>Ot.createElement(Ot.Fragment,null,Ot.createElement("h5",null,Ot.createElement("strong",null,"Alias Details")),Ot.createElement("dl",null,Ot.createElement("dt",null,"Name"),Ot.createElement("dd",null,e.name),Ot.createElement("dt",null,"ARN"),Ot.createElement("dd",null,e.aliasArn))))):"None"),s=Ot.createElement(x,{heading:"Function Details"},n),l=Ot.createElement(x,{heading:"Event Source Details"},r),o=Ot.createElement(x,{heading:"Alias Configuration Details"},i);return Ot.createElement(G,{loading:this.state.loading},Ht(this.state.functionDef)?"Function not found.":Ot.createElement(G.Header,{icon:Ot.createElement("i",{className:"fa fa-xs fa-fw fa-asterisk"}),name:this.state.functionDef.functionName},Ot.createElement("div",{className:"actions"},Ot.createElement(jn,{app:e,functionDef:a,functionFromParams:{account:this.state.functionDef.account,region:this.state.functionDef.region,functionName:this.state.functionDef.functionName}}))),Ht(this.state.functionDef)?"":s,Ht(this.state.functionDef)||Ht(this.state.functionDef.eventSourceMappings)?"":l,Ht(this.state.functionDef)||Ht(this.state.functionDef.aliasConfigurations)?"":o)}};Xn=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Yn(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&&Kn(t,a,i),i})([A("function.details","aws")],Xn);t("spinnaker.amazon.function",[]);const Jn={"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;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(Jn).forEach((e=>P.register(e,Jn[e])));class Qn{findImages(e){return!e.q||e.q.length<3?Ya.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 er,tr,ar,nr,rr,ir;const sr={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}]},lr=[{type:"general",label:"General Purpose",families:[sr,{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:[sr.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"}],or=null!=(ar=null==(tr=null==(er=Sn.instanceTypes)?void 0:er.exclude)?void 0:tr.categories)?ar:[],cr=null!=(ir=null==(rr=null==(nr=Sn.instanceTypes)?void 0:nr.exclude)?void 0:rr.families)?ir:[],dr=lr.filter((({type:e})=>!or.includes(e))).map((e=>Object.assign({},e,{families:e.families.filter((({type:e})=>!cr.includes(e)))})));t("spinnaker.amazon.instanceType.service",[]).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(dr)},getAvailableTypesForRegions:function(e,a){let n=[];return(a=a||[])&&a.length&&(n=e[a[0]]||[]),a.forEach((function(t){e[t]&&(n=qt.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 qt.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 qt.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=qt.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=qt.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=qt.flatten(null==(a=qt.find(lr,{type:t}))?void 0:a.families.map((e=>e.instanceTypes.map((e=>e.name)))));return qt.intersection(e,n)}}}]);const ur=({account:e,availabilityZone:t,instanceType:a,capacityType:n,launchTime:r,provider:i,region:s,serverGroup:l,showInstanceType:o})=>Ot.createElement(Ot.Fragment,null,Ot.createElement(z,{label:"Launched",value:r?B(r):"Unknown"}),Ot.createElement(z,{label:"In",value:Ot.createElement("div",null,Ot.createElement(I,{account:e}),t||"Unknown")}),o&&Ot.createElement(z,{label:"Type",value:a||"Unknown"}),o&&n&&Ot.createElement(z,{label:"Capacity Type",value:n||"Unknown"}),l&&Ot.createElement(z,{label:"Server Group",value:Ot.createElement("div",null,Ot.createElement(en,null,Ot.createElement(Ja,{to:"^.serverGroup",params:{region:s,accountId:e,serverGroup:l,provider:i}},Ot.createElement("a",null,l))))}));function pr(e){const{vpcId:t}=e,a=F((async()=>{const t=await Un.getVpcName(e.vpcId);return t?`${t} (${e.vpcId})`:`(${e.vpcId})`}),"None (EC2 Classic)",[t]),n=t?a.result:"None (EC2 Classic)";return Ot.createElement("span",{className:"vpc-tag"},n)}t("spinnaker.application.amazonInstanceInformation.component",[]).component("amazonInstanceInformation",Xa(L((({instance:e})=>{const{imageId:t,serverGroup:a,subnetId:n,vpcId:r}=e;return Ot.createElement(x,{heading:"Instance Information",defaultExpanded:!0},Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement(ur,{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&&Ot.createElement(z,{label:"VPC",value:Ot.createElement(pr,{vpcId:r})}),n&&Ot.createElement(z,{label:"Subnet",value:Ot.createElement(M,{subnetId:n})}),t&&Ot.createElement(z,{label:"Image ID",value:t})))}),"amazonInstanceInformation"),["instance"]));class mr 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 gr=e=>{const t=e.map((e=>e.targetGroups));return _t(t)},hr=(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||Kt(s.healthCheckPort)?s.port:s.healthCheckPort;e.healthCheckProtocol=null==(r=s.healthCheckProtocol)?void 0:r.toLowerCase(),e.healthCheckPath=`:${l}${null!=(i=s.healthCheckPath)?i:""}`}))}))};t("spinnaker.amazon.instance.details.controller",[tn,an]).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=gr(r.loadBalancers.data.filter((function(e){return"aws"===e.cloudProvider})));hr(n,e,t.account)}a.health&&n.forEach((function(e){const t=a.health.filter((function(t){return t.type===e.type}));t.length&&qt.defaults(e,t[0])})),e.healthMetrics=n}(a,t),e.instance=qt.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=qt.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=!Sn.adHocInfraWritesEnabled,e.detailsTemplateUrl=V.getValue("aws","instance.detailsTemplateUrl"),e.state={loading:!0,standalone:r.isStandalone,instancePort:qt.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 mr.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 mr.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"]),mr.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 mr.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 mr.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 mr.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 mr.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 mr.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 mr.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 fr=({instancePort:e,ipv6Addresses:t,permanentIps:a,privateDnsName:n,privateIpAddress:r,publicDnsName:i,publicIpAddress:s})=>{const l=e?`:${e}`:"";return Rt.createElement(W,{className:"horizontal-when-filters-collapsed"},n&&Rt.createElement(z,{label:"Private DNS Name",value:Rt.createElement(j,{text:n,url:`http://${n}${l}`})}),i&&Rt.createElement(z,{label:"Public DNS Name",value:Rt.createElement(j,{text:i,url:`http://${i}${l}`})}),r&&Rt.createElement(z,{label:"Private IP Address",value:Rt.createElement(j,{text:r,url:`http://${r}${l}`})}),Boolean(null==a?void 0:a.length)&&Rt.createElement(z,{label:"Permanent IP Address",value:a.map((e=>Rt.createElement(j,{key:e,text:e,url:`http://${e}${l}`})))}),s&&Rt.createElement(z,{label:"Public IP Address",value:Rt.createElement(j,{text:s,url:`http://${s}${l}`})}),Boolean(null==t?void 0:t.length)&&Rt.createElement(z,{label:"IPv6 Address"+(t.length>1?"es":""),value:t.map((e=>Rt.createElement(j,{key:e.ip,text:e.ip,url:e.url})))}))};t("spinnaker.application.instanceDns.component",[]).component("instanceDns",Xa(L(fr,"instanceDns"),["instancePort","ipv6Addresses","permanentIps","privateDnsName","privateIpAddress","publicDnsName","publicIpAddress"]));t("spinnaker.application.instanceSecurityGroups.component",[]).component("instanceSecurityGroups",Xa(L((({instance:e})=>{const{account:t,region:a,provider:n,securityGroups:r,vpcId:i}=e,s=Yt(r,["groupName"],["asc"]),l=U.get("Firewalls");return Ot.createElement(x,{heading:l,defaultExpanded:!0},Ot.createElement(en,null,Ot.createElement("ul",null,(s||[]).map((e=>Ot.createElement("li",{key:e.groupId},Ot.createElement(Ja,{to:"^.firewallDetails",params:{name:e.groupName,accountId:t,region:a,vpcId:i,provider:n}},Ot.createElement("a",null,e.groupName," (",e.groupId,")"))))))))}),"instanceSecurityGroups"),["instance"]));const vr=({healthMetrics:e,healthState:t,metricTypes:a,customHealthUrl:n,privateIpAddress:r})=>{const i=a.includes("LoadBalancer"),s=a.includes("TargetGroup");return Ot.createElement(x,{heading:"Status",defaultExpanded:!0},!e.length&&Ot.createElement("p",null,"Starting"===t?"Starting":"No health metrics found for this instance"),Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},e.sort(((e,t)=>e.type<t.type?-1:e.type>t.type?1:0)).map((e=>Ot.createElement(Ot.Fragment,{key:`${e.type}-${e.description}`},Ot.createElement("dt",null,Z(e.type)),Ot.createElement("dd",null,!a.includes(e.type)&&Ot.createElement("div",null,Ot.createElement(_,{value:"down"===e.state.toLowerCase()?e.description:"",placement:"left"},Ot.createElement("span",null,Ot.createElement("span",{className:`glyphicon glyphicon-${e.state}-triangle`}),Ot.createElement("span",null,Z(e.state)))),Ot.createElement("span",{className:"pad-left small"},e.healthCheckUrl&&Ot.createElement("a",{target:"_blank",href:e.healthCheckUrl},"Health Check"),e.healthCheckUrl&&e.statusPageUrl&&Ot.createElement("span",null," | "),e.statusPageUrl&&Ot.createElement("a",{target:"_blank",href:e.statusPageUrl},"Status"),n&&e.type===n.type&&Ot.createElement("span",null," ","|"," ",Ot.createElement("a",{target:"_blank",href:n.href},n.text)))),i&&"LoadBalancer"===e.type&&(e.loadBalancers||[]).map((e=>Ot.createElement(K,{key:`lb-${e.name}`,loadBalancer:e}))),s&&"TargetGroup"===e.type&&(e.targetGroups||[]).map((e=>Ot.createElement(K,{key:`tg-${e.name}`,loadBalancer:e,ipAddress:r})))))))))};t("spinnaker.application.instanceStatus.component",[]).component("instanceStatus",Xa(L(vr,"instanceStatus"),["healthMetrics","healthState","metricTypes","customHealthUrl","privateIpAddress"]));function yr(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("spinnaker.application.instanceTags.component",[]).component("instanceTags",Xa(L((({tags:e})=>{const t=Yt(e,["key"],["asc"]);return Ot.createElement(x,{heading:"Tags",defaultExpanded:!0},!e.length&&Ot.createElement("div",null,"No tags associated with this server"),e.length&&t.map((e=>Ot.createElement(z,{key:e.key,label:e.key,value:e.value}))))}),"instanceTags"),["tags"]));yr(".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 br extends Ot.Component{render(){const{targetGroup:e,showInstances:t,showServerGroups:a,loadBalancer:n}=this.props,r=Yt(e.serverGroups,["isDisabled","name"],["asc","desc"]).map((e=>Ot.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 Ot.createElement("div",{className:"target-group-container container-fluid no-padding"},Ot.createElement(Qa,{class:"active"},Ot.createElement(Ja,{to:".targetGroupDetails",params:i},Ot.createElement("div",{className:"clickable clickable-row row no-margin-y target-group-header"},Ot.createElement("div",{className:"col-md-8 target-group-title"},e.name),Ot.createElement("div",{className:"col-md-4 text-right"},Ot.createElement(X,{container:e.instanceCounts}))))),a&&r,!a&&t&&Ot.createElement(J,{serverGroups:e.serverGroups,instances:e.instances}))}}class Er extends Ot.Component{shouldComponentUpdate(e){return e.showInstances!==this.props.showInstances||e.showServerGroups!==this.props.showServerGroups||e.loadBalancer!==this.props.loadBalancer||(()=>!Xt((e.serverGroups||[]).map((e=>e.name)),(this.props.serverGroups||[]).map((e=>e.name))))()||(()=>!Xt((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=>Ot.createElement(br,{key:n.name,loadBalancer:e,targetGroup:n,showInstances:t,showServerGroups:a})));return Ot.createElement("div",{className:"cluster-container"},n)}return Ot.createElement(Q,{...this.props})}}class wr{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 Ya.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=_t(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 Cr extends Ot.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Ot.createElement("a",{onClick:this.onClick},Ot.createElement("span",{className:"name"},this.props.loadBalancer.name),Ot.createElement(X,{container:this.props.loadBalancer.instanceCounts}))}}class Sr extends Ot.Component{constructor(){super(...arguments),this.onClick=e=>{this.props.onItemClick(this.props.loadBalancer),e.nativeEvent.preventDefault()}}render(){return Ot.createElement(_,{value:`${this.props.label||"Load Balancer"}: ${this.props.loadBalancer.name}`},Ot.createElement("button",{className:"btn btn-link no-padding",onClick:this.onClick},Ot.createElement("span",{className:"badge badge-counter"},Ot.createElement("span",{className:"icon"},Ot.createElement("i",{className:"fa icon-sitemap"})))))}}class kr extends Ot.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})})),wr.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?Ot.createElement(ae,{size:"nano"}):null;const s="load-balancers-tag "+(i>1?"overflowing":""),l=Ot.createElement("div",{className:"menu-load-balancers"},r>0&&Ot.createElement("div",{className:"menu-load-balancers-header"},"Load Balancers"),Jt(e,"name").map((e=>Ot.createElement(Cr,{key:e.name,loadBalancer:e,onItemClick:this.showLoadBalancerDetails}))),n>0&&Ot.createElement("div",{className:"menu-load-balancers-header"},"Target Groups"),Jt(t,"name").map((e=>Ot.createElement(Cr,{key:e.name,loadBalancer:e,onItemClick:this.showTargetGroupDetails}))));return Ot.createElement("span",{className:s},i>1&&Ot.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"},Ot.createElement("button",{onClick:this.handleClick,className:"btn btn-link btn-multiple-load-balancers clearfix no-padding"},Ot.createElement("span",{className:"badge badge-counter"},Ot.createElement("span",{className:"icon"},Ot.createElement("i",{className:"fa icon-sitemap"}))," ",i))),1===e.length&&0===t.length&&Ot.createElement("span",{className:"btn-load-balancer"},Ot.createElement(Sr,{key:e[0].name,label:"Load Balancer",loadBalancer:e[0],onItemClick:this.showLoadBalancerDetails})),1===t.length&&0===e.length&&Ot.createElement("span",{className:"btn-load-balancer"},Ot.createElement(Sr,{key:t[0].name,label:"Target Group",loadBalancer:t[0],onItemClick:this.showTargetGroupDetails})))}}class Nr{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=_t(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=Qt(e.serverGroups,{isDisabled:!1});return e.provider=e.type,e.instances=ea(t).map("instances").flatten().value(),e.detachedInstances=ea(t).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Ya.all([Un.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=_t(ta(a.targetGroups,"serverGroups"))}e.loadBalancerType=e.loadBalancerType||"classic",e.provider=e.type,this.normalizeActions(e);const a=Qt(t,{isDisabled:!1});return e.instances=ea(a).map("instances").flatten().value(),e.detachedInstances=ea(a).map("detachedInstances").flatten().value(),this.updateHealthCounts(e),Un.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||Sn.defaults.account,region:e.defaultRegions.aws||Sn.defaults.region,vpcId:null,subnetType:Sn.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||Sn.defaults.account,region:e.defaultRegions.aws||Sn.defaults.region,vpcId:null,subnetType:Sn.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||Sn.defaults.account,region:e.defaultRegions.aws||Sn.defaults.region,vpcId:null,subnetType:Sn.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 Tr=Object.defineProperty,Gr=Object.getOwnPropertyDescriptor;let Ir=class extends Ot.Component{render(){return Ot.createElement("h3",null,"Target Group Details")}};Ir=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Gr(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&&Tr(t,a,i),i})([ie("loadBalancer.targetGroupDetails")],Ir);var Ar=Object.defineProperty,xr=Object.getOwnPropertyDescriptor;let Pr=class extends Ot.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 Ot.createElement("div",{style:{width:"100%"}},Ot.createElement(nn,{className:"input-sm",wrapperStyle:{width:"100%"},clearable:!0,required:!0,options:i,onChange:e=>a(e.value),value:n}),s&&Ot.createElement("div",{className:"small sp-margin-xs-top sp-margin-m-bottom sp-margin-m-left"},Ot.createElement("div",null,"Uploaded ",se(s.uploadDate)," (",B(s.uploadDate),")"),Ot.createElement("b",null,"Expires ",se(s.expiration))," (",B(s.expiration),")"))}};Pr=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?xr(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&&Ar(t,a,i),i})([ie("amazon.certificateSelectField")],Pr);const Dr=Ot.forwardRef(((e,t)=>Ot.createElement("div",{ref:t},Ot.createElement(s,{name:"idleTimeout",label:"Idle Timeout",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Ot.createElement(p,{...e,min:0})}),Ot.createElement(s,{name:"deletionProtection",label:"Protection",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Ot.createElement(d,{...e,text:"Enable delete protection"})}),Ot.createElement(s,{name:"dualstack",label:"Dualstack",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.albIpAddressType"}),input:e=>Ot.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})}))));yr(".configure-config-modal .StandardFieldLayout .sm-label-right {\n min-width: 160px;\n}\n");const zr=class extends Ot.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(zr,e)}render(){const{initialValues:e}=this.state;return Ot.createElement("div",{className:"configure-config-modal"},Ot.createElement(le,{initialValues:e,onSubmit:this.submit,validate:this.validate,render:({isValid:e})=>Ot.createElement(cn,{className:"form-horizontal"},Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Configure OIDC Client")),Ot.createElement(qa.Body,null,Ot.createElement(s,{name:"issuer",label:"Issuer",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter the OpenId Provider"})}),Ot.createElement(s,{name:"authorizationEndpoint",label:"Authorization Endpoint",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter OpenID provider server endpoint"})}),Ot.createElement(s,{name:"tokenEndpoint",label:"Token Endpoint",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter a URI for your token endpoint"})}),Ot.createElement(s,{name:"userInfoEndpoint",label:"User info Endpoint",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter a URI for your user info endpoint"})}),Ot.createElement(s,{name:"clientId",label:"Client ID",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter the client ID"})}),Ot.createElement(s,{name:"clientSecret",label:"Client secret",required:!0,input:e=>Ot.createElement(l,{...e,placeholder:"Enter the client secret"})})),Ot.createElement(qa.Footer,null,Ot.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Ot.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Client"})))}))}};let Br=zr;Br.defaultProps={closeModal:C,dismissModal:C};const Fr=class extends Ot.Component{constructor(e){super(e),this.close=e=>{this.props.dismissModal(e)},this.submit=e=>{const t=aa(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(Fr,e)}render(){return Ot.createElement("div",{className:"configure-config-modal"},Ot.createElement(le,{initialValues:this.initialValues,onSubmit:this.submit,render:({isValid:e})=>Ot.createElement(cn,{className:"form-horizontal"},Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Configure Redirect ",Ot.createElement(n,{id:"aws.loadBalancer.redirect"}))),Ot.createElement(qa.Body,null,Ot.createElement(s,{name:"host",label:"Host",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.host"})}),Ot.createElement(s,{name:"path",label:"Path",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.path"})}),Ot.createElement(s,{name:"port",label:"Port",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.port"})}),Ot.createElement(s,{name:"protocol",label:"Protocol",required:!1,input:e=>Ot.createElement(c,{...e,stringOptions:["HTTP","HTTPS","#{protocol}"],placeholder:"Select Protocol",clearable:!1,style:{width:"130px"}}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.protocol"})}),Ot.createElement(s,{name:"query",label:"Query",required:!1,input:e=>Ot.createElement(l,{...e}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.query"})}),Ot.createElement(s,{name:"statusCode",label:"Status Code",required:!0,input:e=>Ot.createElement(de,{...e,options:["HTTP_301","HTTP_302"]}),help:Ot.createElement(n,{id:"aws.loadBalancer.redirect.statusCode"})})),Ot.createElement(qa.Footer,null,Ot.createElement("button",{className:"btn btn-default",onClick:this.close,type:"button"},"Cancel"),Ot.createElement(ce,{isDisabled:!e,submitting:!1,isFormSubmit:!0,label:"Save Config"})))}))}};let Mr=Fr;Mr.defaultProps={closeModal:C,dismissModal:C};class $r{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=Jt(e,"serverCertificateName");return na(n,(e=>{const[,,,,t]=e.arn.split(":");return a[t]||"unknown"}))}))))}}const Lr=rn((()=>Ot.createElement("span",{className:"pipeline-drag-handle clickable glyphicon glyphicon-resize-vertical"}))),Rr={authenticateOidcConfig:{authorizationEndpoint:"",clientId:"",issuer:"",scope:"openid",sessionCookieName:"AWSELBAuthSessionCookie",tokenEndpoint:"",userInfoEndpoint:""},type:"authenticate-oidc"};class Or extends Ot.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=sn(t.rules,e.oldIndex,e.newIndex),this.updateListeners()},this.configureOidcClient=e=>{Br.show({config:e.authenticateOidcConfig}).then((t=>{e.authenticateOidcConfig=t,this.updateListeners()})).catch((()=>{}))},this.configureRedirect=e=>{Mr.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)||{...Rr};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:ra(Sn,"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=_t(e.map((e=>e.defaultActions))),a=_t(e.map((e=>e.rules)));return t.push(..._t(a.map((e=>e.actions)))),ia(t.map((e=>e.targetGroupName)))}validate(e){const t={},a=e.targetGroups.map((e=>e.name)),n=this.getAllTargetGroupsFromListeners(e.listeners),r=sa(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;jt(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||!la(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(){$r.listCertificates().then((e=>{this.setState({certificates:e})}))}loadOidcClients(){(class{static getOidcConfigsByApp(e){return D("/oidcConfigs").query({app:e}).get()}}).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),Ya.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},t.listeners.map(((e,i)=>Ot.createElement("div",{key:i,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Ot.createElement("div",{className:"wizard-pod-row-contents spread"},Ot.createElement("div",null,Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol"),Ot.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=>Ot.createElement("option",{key:e},e))))),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port"),Ot.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}))),Ot.createElement("div",null,Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(i)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))))),this.needsCert(e)&&Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Ot.createElement("div",{className:"wizard-pod-row-contents"},e.certificates.map(((e,r)=>Ot.createElement("div",{key:r,style:{width:"100%",display:"flex",flexDirection:"row"}},Ot.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=>Ot.createElement("option",{key:e},e)))),this.showCertificateSelect(e)&&Ot.createElement(Pr,{certificates:a,accountName:t.credentials,currentValue:e.name,app:this.props.app,onCertificateSelect:t=>this.handleCertificateChanged(e,t)}),!this.showCertificateSelect(e)&&Ot.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})))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Ot.createElement("table",{className:"table table-condensed packed rules-table"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{style:{width:"15px",padding:"0"}}),Ot.createElement("th",null,"If"),Ot.createElement("th",{style:{width:"315px"}},"Then"),Ot.createElement("th",{style:{width:"45px"}}))),Ot.createElement(Hr,{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&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(pe,{type:"error",message:e.listenerPorts})),e.listeners&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(pe,{type:"error",message:e.listeners})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}const Vr=ln((e=>Ot.createElement("tr",{className:"listener-rule"},Ot.createElement("td",{className:"handle"},Ot.createElement(Lr,null)),Ot.createElement("td",null,e.rule.conditions.map(((t,a)=>Ot.createElement("div",{key:a,className:"listener-rule-condition"},Ot.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)&&Ot.createElement("option",{value:"host-header"},"Host"),(1===e.rule.conditions.length||"path-pattern"===t.field)&&Ot.createElement("option",{value:"path-pattern"},"Path"),(1===e.rule.conditions.length||"http-request-method"===t.field)&&Ot.createElement("option",{value:"http-request-method"},"Method(s)")),"path-pattern"===t.field&&Ot.createElement(n,{id:"aws.loadBalancer.ruleCondition.path"}),"host-header"===t.field&&Ot.createElement(n,{id:"aws.loadBalancer.ruleCondition.host"}),"http-request-method"!==t.field&&Ot.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&&Ot.createElement("div",{className:"col-md-6 checkbox"},["DELETE","GET","PATCH","POST","PUT"].map((a=>Ot.createElement("label",{key:`${a}-checkbox`},Ot.createElement("input",{type:"checkbox",checked:t.values.includes(a),onChange:n=>e.handleHttpRequestMethodChanged(t,a,n.target.checked)}),a)))),Ot.createElement("span",{className:"remove-condition"},1===a&&Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeCondition(e.rule,a),style:{padding:"0"}},Ot.createElement(_,{value:"Remove Condition"},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))))))),1===e.rule.conditions.length&&Ot.createElement("div",{className:"add-new-container"},Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addCondition(e.rule)},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new condition")),Ot.createElement("span",{style:{minWidth:"15px"}}))),Ot.createElement("td",null,e.rule.actions.map(((t,a)=>Ot.createElement(Ur,{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})))),Ot.createElement("td",null,Ot.createElement(qr,{ruleIndex:e.ruleIndex,listener:e.listener,authenticateRuleToggle:e.authenticateRuleToggle,removeRule:e.removeRule,actions:e.rule.actions}))))),Ur=e=>{var t;if("authenticate-oidc"!==e.action.type){const t=e.action.redirectActionConfig||e.action.redirectConfig;return Ot.createElement("div",{className:"horizontal top"},Ot.createElement("select",{className:"form-control input-sm",style:{width:"80px"},value:e.action.type,onChange:t=>e.actionTypeChanged(t.target.value)},Ot.createElement("option",{value:"forward"},"forward to"),Ot.createElement("option",{value:"redirect"},"redirect to")),"forward"===e.action.type&&Ot.createElement("select",{className:"form-control input-sm",value:e.action.targetGroupName,onChange:t=>e.targetChanged(t.target.value),required:!0},Ot.createElement("option",{value:""}),ia(e.targetGroups.map((e=>e.name))).map((e=>Ot.createElement("option",{key:e},e)))),"redirect"===e.action.type&&Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Host"),Ot.createElement("dd",null,t.host),Ot.createElement("dt",null,"Path"),Ot.createElement("dd",null,t.path),Ot.createElement("dt",null,"Port"),Ot.createElement("dd",null,t.port),Ot.createElement("dt",null,"Protocol"),Ot.createElement("dd",null,t.protocol),Ot.createElement("dt",null,"Query"),Ot.createElement("dd",null,t.query),Ot.createElement("dt",null,"Status Code"),Ot.createElement("dd",null,t.statusCode),Ot.createElement("dt",null,Ot.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=ra(Sn,"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=>Ot.createElement("option",{key:e.clientId},e.clientId))):Ot.createElement("option",{disabled:!0},"No ",me.get("OIDC client")," config found");return Ot.createElement("div",{className:"horizontal middle",style:{height:"30px"}},Ot.createElement("span",{style:{whiteSpace:"pre"}},"auth with ",me.get("OIDC client")," "),n&&Ot.createElement("select",{className:"form-control input-sm",value:a,onChange:t=>e.oidcConfigChanged(e.oidcConfigs.find((e=>e.clientId===t.target.value))),required:!0},Ot.createElement("option",{value:""}),r),!n&&Ot.createElement("a",{onClick:()=>e.configureOidcClient(e.action),className:"clickable"},a||"Configure..."),Ot.createElement("span",{style:{whiteSpace:"pre"}},Ot.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 Ot.createElement("span",null,a&&Ot.createElement(Ot.Fragment,null,Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.authenticateRuleToggle(e.listener,e.ruleIndex),style:{padding:"0"}},Ot.createElement(_,{value:r},Ot.createElement("i",{className:i}))),Ot.createElement(n,{id:"aws.loadBalancer.oidcAuthentication"})),void 0!==e.ruleIndex&&e.ruleIndex>=0&&e.removeRule&&Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeRule(e.listener,e.ruleIndex),style:{padding:"0"}},Ot.createElement(_,{value:"Remove Rule"},Ot.createElement("i",{className:"far fa-fw fa-trash-alt"}))))},Hr=on((e=>Ot.createElement("tbody",null,Ot.createElement("tr",{className:"not-sortable"},Ot.createElement("td",null),Ot.createElement("td",null,"Default"),Ot.createElement("td",null,e.listener.defaultActions.map(((t,a)=>Ot.createElement(Ur,{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})))),Ot.createElement("td",null,Ot.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)=>Ot.createElement(Vr,{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}))),Ot.createElement("tr",{className:"not-sortable"},Ot.createElement("td",{colSpan:5},Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:()=>e.addRule(e.listener)},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new rule"))))))),Wr=(e,t,a)=>n=>ra(e,[t,a],[]).includes(n.toLowerCase())?`There is already a target group in ${t}:${a} with that name.`:null,jr=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 Zr extends Ot.Component{constructor(e){super(e),this.protocols=["HTTP","HTTPS"],this.targetTypes=["instance","ip","lambda"],this.destroy$=new Na,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=ia(_t(Qt(na(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(Wr(this.state.existingTargetGroupNames,e.credentials,e.region),jr(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=oa(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={};Ta(t.getDataSource("loadBalancers").refresh(!0)).pipe(Ma(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,ca(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=>Ot.createElement("option",{key:e},e))),s=this.targetTypes.map((e=>Ot.createElement("option",{key:e},e)));return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.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 Ot.createElement("div",{key:l,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"group-name-prefix"},e.name,"-"),Ot.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}),Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(l)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))),o.name&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(pe,{type:"error",message:o.name})))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},Ot.createElement(n,{id:"aws.targetGroup.targetType"})," ",Ot.createElement("span",null,"Target Type ")),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.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&&Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),Ot.createElement(n,{id:"aws.targetGroup.protocol"})," ",Ot.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)),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.createElement(n,{id:"aws.targetGroup.port"})," ",Ot.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}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},"lambda"!==a.targetType&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),"TCP"===a.healthCheckProtocol&&Ot.createElement(n,{id:"aws.targetGroup.healthCheckProtocol"})," ",Ot.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&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.createElement(n,{id:"aws.targetGroup.attributes.healthCheckPort.trafficPort"})," ",Ot.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":"")},Ot.createElement("option",{value:"traffic-port"},"Traffic Port"),Ot.createElement("option",{value:"manual"},"Manual"))," ",Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Path "),Ot.createElement(fe,{error:o.healthCheckPath,name:"healthCheckPath",required:!0,value:a.healthCheckPath,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckPath",e.target.value)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Timeout "),(c||d)&&Ot.createElement(n,{id:"aws.targetGroup.healthCheckTimeout"}),Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Interval "),Ot.createElement(ve,{error:o.healthCheckInterval,required:!0,value:a.healthCheckInterval,min:5,max:300,onChange:e=>this.targetGroupFieldChanged(l,"healthCheckInterval",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck Threshold"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Healthy "),Ot.createElement(ve,{error:o.healthyThreshold,value:a.healthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"healthyThreshold",e)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Unhealthy "),Ot.createElement(ve,{error:o.unhealthyThreshold,required:!0,value:a.unhealthyThreshold,min:2,max:10,onChange:e=>this.targetGroupFieldChanged(l,"unhealthyThreshold",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),"lambda"!==a.targetType?Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Dereg. Delay"),Ot.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Ot.createElement("input",{type:"checkbox",checked:a.attributes.stickinessEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.stickinessEnabled",e.target.checked)})," ",Ot.createElement("label",null,"Sticky"),Ot.createElement(n,{id:"aws.targetGroup.attributes.stickinessEnabled"}))),a.attributes.stickinessEnabled&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Duration "),Ot.createElement(n,{id:"aws.targetGroup.attributes.stickinessDuration"})," ",Ot.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"})))):Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",{className:"checkbox-inline",style:{paddingTop:"2px"}},Ot.createElement("input",{type:"checkbox",checked:a.attributes.multiValueHeadersEnabled,onChange:e=>this.targetGroupFieldChanged(l,"attributes.multiValueHeadersEnabled",e.target.checked)})," ",Ot.createElement("label",null,"Enable Multi Value Headers"))))))})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}}class _r extends Ot.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 Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Availability Zones"),e&&Ot.createElement("div",{className:"col-md-7"},Ot.createElement("p",{className:"form-control-static"},"Automatic Availability Zone Balancing:"),Ot.createElement("select",{className:"form-control input-sm",value:r?"true":"false",onChange:this.handleUsePreferredZonesChanged},Ot.createElement("option",{value:"true"},"Enabled"),Ot.createElement("option",{value:"false"},"Manual")),Ot.createElement("br",null),r&&Ot.createElement("div",null,Ot.createElement("p",{className:"form-control-static"},"Server group will be available in:"),Ot.createElement("ul",null,n.map((e=>Ot.createElement("li",{key:e},e))))),!r&&Ot.createElement("div",null,"Restrict server group instances to:",Ot.createElement(ye,{stringOptions:t,value:a,onChange:e=>this.handleSelectedZonesChanged(e.target.value)}))))}}function Kr(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=Ot.useMemo((()=>{const e=r||function(e,t,a){const{classicLaunchLockout:n,classicLaunchAllowlist:r}=Sn,i=Number(ra(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 Ot.useEffect((()=>{const e=m.some((e=>e.value===d));g&&(!e||"FIRST_RENDER"!==h)&&s(we({name:i,value:g.purpose}))}),[m]),l?Ot.createElement("p",{className:"form-control-static"},e.value||"None (EC2 Classic)"):Ot.createElement(de,{options:m,value:d,onChange:s,...u})}class Yr extends Rt.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=Sn.serverGroups)?void 0:e.recommendedSubnets)?t:[],h=null!=i?i:[Sn.defaults.subnetType],f=g.some((e=>m&&m.includes(e))),v=null==(a=Sn.serverGroups)?void 0:a.subnetWarning;return Rt.createElement("div",{className:"form-group"},Rt.createElement("div",{className:`col-md-${o} sm-label-right`},"VPC Subnet ",Rt.createElement(n,{id:l})),Rt.createElement("div",{className:"col-md-7"},d?Rt.createElement(Kr,{...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)&&Rt.createElement("div",{className:"alert alert-warning sp-margin-s-top horizontal center"},Rt.createElement("i",{className:"fa fa-exclamation-triangle sp-margin-s-top"}),Rt.createElement("div",{className:"sp-margin-s-left"},Rt.createElement(Ce,{message:v,style:{display:"inline-block",marginLeft:"2px"}})))))}}class Xr extends Ot.Component{constructor(){super(...arguments),this.state={accounts:void 0,availabilityZones:[],existingLoadBalancerNames:[],hideInternalFlag:!1,internalFlagToggled:!1,regions:[],subnets:[]},this.props$=new Na,this.destroy$=new Na,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(Kt(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!!(Sn&&Sn.loadBalancers&&Sn.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(Pa((e=>e.formik.values))),t=this.props$.pipe(Pa((e=>e.app.name)),Da()),a={account$:e.pipe(Pa((e=>e.credentials)),Da()),region$:e.pipe(Pa((e=>e.region)),Da()),subnetPurpose$:e.pipe(Pa((e=>e.subnetType)),Da()),stack$:e.pipe(Pa((e=>e.stack)),Da()),detail$:e.pipe(Pa((e=>e.detail)),Da())},n=Ta(o.listAccounts("aws")).pipe(za(1)),r=Ga([a.account$,n]).pipe(Ba((([e,t])=>o.getRegionsForAccount(e))),za(1)),i=this.props.app.getDataSource("loadBalancers").data$,s=Ga([i,a.account$,a.region$]).pipe(Pa((([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(Ba((([e,t])=>this.getAvailableSubnets(e,t))),Pa((e=>this.makeSubnetOptions(e))),za(1)),c=Ga([l,a.subnetPurpose$]).pipe(Pa((([e,t])=>e&&e.find((e=>e.purpose===t))))),d=c.pipe(Pa((e=>e?ia(e.availabilityZones).sort():[]))),u=a.region$.pipe(Fa(r),Pa((([e,t])=>t.find((t=>t.name===e)))),Pa((e=>e?e.availabilityZones:[]))),p=Ga([t,a.stack$,a.detail$]).pipe(Pa((([e,t,a])=>({app:e,stack:t,detail:a,cluster:re.getClusterName(e,t,a)}))));r.pipe(Fa(a.region$),Ma(this.destroy$)).subscribe((([e,t])=>{e.some((e=>e.name===t))||this.props.formik.setFieldValue("region",e[0]&&e[0].name)})),u.pipe(Ma(this.destroy$)).subscribe((e=>{this.props.formik.setFieldValue("regionZones",e)})),c.pipe(Ma(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(Ma(this.destroy$)).subscribe((e=>{this.props.formik.setFieldValue("moniker",e),this.props.formik.setFieldValue("name",e.cluster)})),Ga([n,r,d,s,l]).pipe(Ma(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=>ea(a).filter({account:e,region:t}).reject({target:"ec2"}).reject({purpose:null}).value()))}makeSubnetOptions(e){const t=na(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:ia(e.map((e=>e.vpcId))),availabilityZones:ia(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=ka({"col-md-12":!0,well:!0,"alert-danger":!!t.name,"alert-info":!t.name});return Ot.createElement("div",{className:"container-fluid form-horizontal"},!r&&Ot.createElement("div",{style:{height:"200px"}},Ot.createElement(ae,{size:"medium"})),r&&Ot.createElement("div",{className:"modal-body"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:c},Ot.createElement("strong",null,"Your load balancer will be named: "),Ot.createElement("span",null,a.name),Ot.createElement(n,{id:"aws.loadBalancer.name"}),Ot.createElement(dn,{type:"text",style:{display:"none"},className:"form-control input-sm no-spel",name:"name"}),t.name&&Ot.createElement(pe,{type:"error",message:t.name}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Ot.createElement("div",{className:"col-md-7"},Ot.createElement(Se,{value:a.credentials,onChange:e=>this.accountUpdated(e.target.value),accounts:r,provider:"aws"}))),Ot.createElement(ke,{labelColumns:3,component:a,field:"region",account:a.credentials,onChange:this.regionUpdated,regions:l}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Ot.createElement(n,{id:"aws.loadBalancer.stack"})),Ot.createElement("div",{className:"col-md-3"},Ot.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.stack?"invalid":""),value:a.stack,name:"stack",onChange:this.stackChanged})),Ot.createElement("div",{className:"col-md-6 form-inline"},Ot.createElement("label",{className:"sm-label-right"},Ot.createElement("span",null,"Detail ",Ot.createElement(n,{id:"aws.loadBalancer.detail"})," ")),Ot.createElement("input",{type:"text",className:"form-control input-sm no-spel "+(t.detail?"invalid":""),value:a.detail,name:"detail",onChange:this.detailChanged})),t.stack&&Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement(pe,{type:"error",message:t.stack})),t.detail&&Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement(pe,{type:"error",message:t.detail}))),Ot.createElement(_r,{credentials:a.credentials,region:a.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:a.regionZones,allZones:i}),Ot.createElement(Yr,{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&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("b",null,"Internal")," ",Ot.createElement(n,{id:"aws.loadBalancer.internal"})),Ot.createElement("div",{className:"col-md-7 checkbox"},Ot.createElement("label",null,Ot.createElement(dn,{name:"isInternal",onChange:this.internalFlagChanged,render:({field:{value:e,...t}})=>Ot.createElement("input",{type:"checkbox",...t,checked:!!e})}),"Create an internal load balancer")))))}}class Jr extends Ot.Component{constructor(e){super(e),this.destroy$=new Na,this.props$=new Na,this.refresh$=new Na,this.clearRemoved=()=>{this.setState({removed:[]},(()=>this.props.formik.validateForm()))},this.handleSecurityGroupsChanged=e=>{this.props.formik.setFieldValue("securityGroups",e.map((e=>e.value)))};const t=ra(Sn,"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]=da((()=>{const t=e.concat(r).sort();return ia((a?n:[]).concat(t))})(),(e=>!!i(e))),o=s.map((e=>i(e).name));Xt(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($a((()=>this.onRefreshStart())),Ba((()=>h.cacheInitializer.refreshCache("securityGroups"))),La((()=>h.securityGroupReader.getAllSecurityGroups())),$a((()=>this.onRefreshComplete()))),t=this.props$.pipe(Pa((e=>e.formik.values))),a=t.pipe(Pa((e=>e.vpcId)),Da());Ga([a,e]).pipe(Fa(t),Pa((([[e,t],a])=>{const n=t[a.credentials]||{};return(n.aws&&n.aws[a.region]||[]).filter((t=>e===t.vpcId)).sort()}))).pipe(Fa(t),Ma(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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",null,r.length>0&&Ot.createElement("div",{className:"form-group"},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"}),"The following ",U.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,r.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:this.clearRemoved},"Okay"))))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},U.get("Firewalls")),Ot.createElement("div",{className:"col-md-9"},!a&&Ot.createElement("div",{style:{paddingTop:"13px"}},Ot.createElement(ae,{size:"small"})),a&&Ot.createElement(un,{multi:!0,value:e,options:t,onChange:this.handleSecurityGroupsChanged,clearable:!1}))),Ot.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Ot.createElement("div",{className:"col-md-9 col-md-offset-3"},Ot.createElement("p",null,n&&Ot.createElement("span",null,Ot.createElement("span",{className:"fa fa-sync-alt fa-spin"})," "),U.get("Firewalls"),!n&&Ot.createElement("span",null," last refreshed ",B(i)),n&&Ot.createElement("span",null," refreshing...")),Ot.createElement("p",null,"If you're not finding a ",U.get("firewall")," that was recently added,"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.refresh$.next()},"click here")," ","to refresh the list.")))))}}yr(".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 Qr=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ra(Sn,"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=Zt(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?Nr.convertApplicationLoadBalancerForEditing(e.loadBalancer):Nr.constructNewApplicationLoadBalancerTemplate(e.app);this.state={includeSecurityGroups:!!t.vpcId,isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(Qr,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}`),Ot.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 Ot.createElement(Ot.Fragment,null,l&&Ot.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Ot.createElement(Xr,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),o&&Ot.createElement(w,{label:U.get("Firewalls"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Ot.createElement(Jr,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Ot.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(Zr,{ref:a,app:e,formik:t,isNew:r,loadBalancer:n})}),Ot.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(Or,{ref:a,app:e,formik:t})}),Ot.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(Dr,{ref:e})}))}})}};let ei=Qr;ei.defaultProps={closeModal:C,dismissModal:C};yr(".AmazonLoadBalancer-AdvancedSettings .StandardFieldLayout .sm-label-right {\n width: 180px;\n}\n");class ti extends Ot.Component{render(){const{values:e}=this.props.formik,{maxValue:t}=ge;return Ot.createElement("div",{className:"form-group AmazonLoadBalancer-AdvancedSettings"},Ot.createElement(s,{name:"healthTimeout",label:"Timeout",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.healthTimeout"}),input:t=>Ot.createElement(p,{...t,min:0,max:e.healthInterval}),validate:t(e.healthInterval,"Timeout must be less than the health interval.")}),Ot.createElement(s,{name:"healthInterval",label:"Interval",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.healthInterval"}),input:e=>Ot.createElement(p,{...e,min:0})}),Ot.createElement(s,{name:"healthyThreshold",label:"Healthy Threshold",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.healthyThreshold"}),input:e=>Ot.createElement(p,{...e,min:0})}),Ot.createElement(s,{name:"unhealthyThreshold",label:"Unhealthy Threshold",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.unhealthyThreshold"}),input:e=>Ot.createElement(p,{...e,min:0})}),Ot.createElement(s,{name:"idleTimeout",label:"Idle Timeout",required:!0,help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.idleTimeout"}),input:e=>Ot.createElement(p,{...e,min:0})}),Ot.createElement("div",{className:"col-md-12"},Ot.createElement("p",null,"Additional configuration options (cross-zone load balancing, session stickiness, access logs) are available via the AWS console.")))}}class ai extends Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},"Ping"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{style:{width:"35%"}},"Protocol"),Ot.createElement("th",{style:{width:"30%"}},"Port"),Ot.createElement("th",null,this.requiresHealthCheckPath()&&Ot.createElement("span",null,"Path")))),Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement(s,{name:"healthCheckProtocol",required:!0,input:e=>Ot.createElement(de,{...e,options:["HTTP","HTTPS","SSL","TCP"]})})),Ot.createElement("td",null,Ot.createElement(s,{name:"healthCheckPort",required:!0,input:e=>Ot.createElement(p,{...e,min:1,max:65534})})),Ot.createElement("td",null,this.requiresHealthCheckPath()&&Ot.createElement(s,{name:"healthCheckPath",input:e=>Ot.createElement(l,{...e}),required:!0,onChange:this.healthCheckPathChanged})))))))}}yr(".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 ni extends Ot.Component{constructor(){super(...arguments),this.protocols=["HTTP","HTTPS","TCP","SSL"],this.secureProtocols=["HTTPS","SSL"],this.certificateTypes=ra(Sn,"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(){$r.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 Ot.createElement(Pr,{certificates:a,accountName:t.credentials,currentValue:e.sslCertificateName,app:this.props.app,onCertificateSelect:t=>this.handleListenerCertificateChanged(e,t)})}return Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal create-classic-load-balancer-wizard-listeners"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",null,"External Protocol"),Ot.createElement("th",null,"External Port"),Ot.createElement("th",null),Ot.createElement("th",null,"Internal Protocol"),Ot.createElement("th",null,"Internal Port"),Ot.createElement("th",null))),Ot.createElement("tbody",null,e.listeners.map(((e,t)=>Ot.createElement(Ot.Fragment,{key:t},Ot.createElement("tr",{key:t+"-main"},Ot.createElement("td",null,Ot.createElement("select",{className:"form-control input-sm",value:e.externalProtocol,onChange:t=>this.listenerExternalProtocolChanged(e,t.target.value)},this.protocols.map((e=>Ot.createElement("option",{key:e},e))))),Ot.createElement("td",null,Ot.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.externalPort,onChange:t=>this.listenerExternalPortChanged(e,t.target.value),required:!0})),Ot.createElement("td",{className:"small",style:{paddingTop:"10px"}},"→"),Ot.createElement("td",null,Ot.createElement("select",{className:"form-control input-sm",value:e.internalProtocol,onChange:t=>this.listenerInternalProtocolChanged(e,t.target.value)},this.protocols.map((e=>Ot.createElement("option",{key:e},e))))),Ot.createElement("td",null,Ot.createElement("input",{className:"form-control input-sm",type:"number",min:"0",value:e.internalPort,onChange:t=>this.listenerInternalPortChanged(e,t.target.value),required:!0})),Ot.createElement("td",null,Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(t)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"})))),this.secureProtocols.includes(e.externalProtocol)&&Ot.createElement("tr",{key:t+"-ssl"},Ot.createElement("td",{colSpan:5,style:{borderTopWidth:0}},Ot.createElement("div",{className:"horizontal space-between"},Ot.createElement("div",{className:"sm-label-right"},"Certificate"),this.certificateTypes.length>1&&Ot.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=>Ot.createElement("option",{key:e},e)))),this.renderCertificateSelector(e)))))))),Ot.createElement("tfoot",null,Ot.createElement("tr",null,Ot.createElement("td",{colSpan:5},Ot.createElement("button",{className:"add-new col-md-12",onClick:this.addListener,type:"button"},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),Ot.createElement("span",null," Add new port mapping")))))))))}}const ri=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ra(Sn,"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=Zt(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?Nr.convertClassicLoadBalancerForEditing(e.loadBalancer):Nr.constructNewClassicLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(ri,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}`),Ot.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})=>Ot.createElement(Ot.Fragment,null,l&&Ot.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Ot.createElement(Xr,{app:e,formik:t,isNew:r,forPipelineConfig:a,loadBalancer:n,ref:i})}),!!t.values.vpcId&&Ot.createElement(w,{label:U.get("Firewall"),wizard:s,order:i(),render:({innerRef:e,onLoadingChanged:a})=>Ot.createElement(Jr,{formik:t,isNew:r,onLoadingChanged:a,ref:e})}),Ot.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(ni,{ref:a,formik:t,app:e})}),Ot.createElement(w,{label:"Health Check",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(ai,{ref:e,formik:t})}),Ot.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(ti,{ref:e,formik:t})}))})}};let ii=ri;ii.defaultProps={closeModal:C,dismissModal:C};const si=Ot.forwardRef(((e,t)=>Ot.createElement("div",{ref:t},Ot.createElement(s,{name:"deletionProtection",label:"Protection",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.deletionProtection"}),input:e=>Ot.createElement(d,{...e,text:"Enable deletion protection"})}),Ot.createElement(s,{name:"loadBalancingCrossZone",label:"Cross-Zone Load Balancing",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.loadBalancingCrossZone"}),input:e=>Ot.createElement(d,{...e,text:"Distribute traffic across zones"})}),e.showDualstack&&Ot.createElement(s,{name:"dualstack",label:"Dualstack",help:Ot.createElement(n,{id:"loadBalancer.advancedSettings.nlbIpAddressType"}),input:e=>Ot.createElement(d,{...e,text:"Assign Ipv4 and IPv6"})}))));function li({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 Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Certificate"),Ot.createElement("div",{className:"wizard-pod-row-contents"},e.map(((e,a)=>Ot.createElement("div",{key:a,style:{width:"100%",display:"flex",flexDirection:"row"}},Ot.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=>Ot.createElement("option",{key:e},e)))),l(e)&&Ot.createElement(Pr,{certificates:t,accountName:o.credentials,currentValue:e.name,app:n,onCertificateSelect:t=>s(e,t)}),!l(e)&&Ot.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 oi extends Ot.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:ra(Sn,"loadBalancers.certificateTypes",["iam","acm"]),oidcConfigs:void 0}}getAllTargetGroupsFromListeners(e){const t=_t(e.map((e=>e.defaultActions))),a=_t(e.map((e=>e.rules)));return t.push(..._t(a.map((e=>e.actions)))),ia(t.map((e=>e.targetGroupName)))}validate(e){const t={},a=e.targetGroups.map((e=>e.name)),n=this.getAllTargetGroupsFromListeners(e.listeners),r=sa(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 jt(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(){$r.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},t.listeners.map(((e,r)=>Ot.createElement("div",{key:r,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Listen On"),Ot.createElement("div",{className:"wizard-pod-row-contents spread"},Ot.createElement("div",null,Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol"),Ot.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=>Ot.createElement("option",{key:e},e))))),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port"),Ot.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}))),Ot.createElement("div",null,Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeListener(r)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))))),Ot.createElement("div",null,"TLS"===e.protocol&&Ot.createElement(li,{availableCertificates:e.certificates,formik:this.props.formik,app:this.props.app,certificateTypes:n,certificates:a})),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title",style:{height:"30px"}},"Rules"),Ot.createElement("div",{className:"wizard-pod-row-contents",style:{padding:"0"}},Ot.createElement("table",{className:"table table-condensed packed rules-table"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{style:{width:"10px",padding:"0"}}),Ot.createElement("th",{style:{width:"226px"}},"If"),Ot.createElement("th",{style:{width:"75px"}},"Then"),Ot.createElement("th",null,"Target"),Ot.createElement("th",{style:{width:"30px"}}))),Ot.createElement("tbody",null,Ot.createElement("tr",{className:"not-sortable"},Ot.createElement("td",null),Ot.createElement("td",null,"Default"),Ot.createElement("td",null,"forward to"),Ot.createElement("td",null,Ot.createElement("select",{className:"form-control input-sm",value:e.defaultActions[0].targetGroupName,onChange:t=>this.handleDefaultTargetChanged(e,t.target.value),required:!0},Ot.createElement("option",{value:""}),ia(t.targetGroups.map((e=>e.name))).map((e=>Ot.createElement("option",{key:e},e))))),Ot.createElement("td",null)))))))))),e.listenerPorts&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(pe,{type:"error",message:e.listenerPorts})),e.listeners&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(pe,{type:"error",message:e.listeners})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addListener},Ot.createElement("span",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new listener")))))))))}}class ci extends Ot.Component{constructor(e){super(e),this.protocols=["TCP","UDP"],this.healthProtocols=["TCP","HTTP","HTTPS"],this.targetTypes=["instance","ip"],this.destroy$=new Na,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=ia(_t(Qt(na(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(Wr(this.state.existingTargetGroupNames,e.credentials,e.region),jr(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={};Ta(t.getDataSource("loadBalancers").refresh(!0)).pipe(Ma(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];ca(i,t,a),"healthyThreshold"===t&&ca(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=>Ot.createElement("option",{key:e},e))),s=this.healthProtocols.map((e=>Ot.createElement("option",{key:e},e))),l=this.targetTypes.map((e=>Ot.createElement("option",{key:e},e)));return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},a.targetGroups.map(((a,o)=>{const c=t.targetGroups&&t.targetGroups[o]||{};return Ot.createElement("div",{key:o,className:"wizard-pod"},Ot.createElement("div",null,Ot.createElement("div",{className:"wizard-pod-row header"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Group Name"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"group-name-prefix"},e.name,"-"),Ot.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}),Ot.createElement("a",{className:"sm-label clickable",onClick:()=>this.removeTargetGroup(o)},Ot.createElement("span",{className:"glyphicon glyphicon-trash"}))),c.name&&Ot.createElement("div",{className:"wizard-pod-row-errors"},Ot.createElement(pe,{type:"error",message:c.name})))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},Ot.createElement(n,{id:"aws.targetGroup.targetType"})," ",Ot.createElement("span",null,"Target Type ")),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("select",{className:"form-control input-sm",value:a.targetType,onChange:e=>this.targetGroupFieldChanged(o,"targetType",e.target.value),disabled:o<r},l))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Backend Connection"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),Ot.createElement(n,{id:"aws.targetGroup.protocol"})," ",Ot.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)),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.createElement(n,{id:"aws.targetGroup.port"})," ",Ot.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}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Healthcheck"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Protocol "),Ot.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)),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Port "),Ot.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&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Path "),Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Timeout "),Ot.createElement(ve,{error:c.healthCheckTimeout,required:!0,value:a.healthCheckTimeout,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckTimeout",e)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Interval "),Ot.createElement(ve,{error:c.healthCheckInterval,required:!0,value:a.healthCheckInterval,onChange:e=>this.targetGroupFieldChanged(o,"healthCheckInterval",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},Ot.createElement(n,{id:"aws.targetGroup.nlbHealthcheckThreshold"})," ",Ot.createElement("span",null,"Healthcheck Threshold ")),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement(ve,{error:c.healthyThreshold,value:a.healthyThreshold,onChange:e=>this.targetGroupFieldChanged(o,"healthyThreshold",e)}))))),Ot.createElement("div",{className:"wizard-pod-row"},Ot.createElement("div",{className:"wizard-pod-row-title"},"Attributes"),Ot.createElement("div",{className:"wizard-pod-row-contents"},Ot.createElement("div",{className:"wizard-pod-row-data"},Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement("label",null,"Dereg. Delay"),Ot.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelay"})," ",Ot.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)})),Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement(d,{name:"deregistrationDelayConnectionTermination",text:"Connection Termination",checked:a.attributes.deregistrationDelayConnectionTermination,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.deregistrationDelayConnectionTermination",e.target.checked)}}),Ot.createElement(n,{id:"aws.targetGroup.attributes.deregistrationDelayConnectionTermination"})),"instance"!==a.targetType&&Ot.createElement("span",{className:"wizard-pod-content"},Ot.createElement(d,{name:"preserveClientIp",text:"Preserve Client IP",checked:a.attributes.preserveClientIp,onChange:e=>{this.targetGroupFieldChanged(o,"attributes.preserveClientIp",e.target.checked)}}),Ot.createElement(n,{id:"aws.targetGroup.attributes.preserveClientIp"})))))))})),Ot.createElement("table",{className:"table table-condensed packed"},Ot.createElement("tbody",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("button",{type:"button",className:"add-new col-md-12",onClick:this.addTargetGroup},Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign"})," Add new target group"))))))))}}const di=class extends Ot.Component{constructor(e){super(e),this._isUnmounted=!1,this.certificateTypes=ra(Sn,"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=Zt(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?Nr.convertNetworkLoadBalancerForEditing(e.loadBalancer):Nr.constructNewNetworkLoadBalancerTemplate(e.app);this.state={isNew:!e.loadBalancer,loadBalancerCommand:t,taskMonitor:null}}static show(e){return b.show(di,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 Ot.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})=>Ot.createElement(Ot.Fragment,null,o&&Ot.createElement(w,{label:"Location",wizard:s,order:i(),render:({innerRef:i})=>Ot.createElement(Xr,{app:e,forPipelineConfig:a,formik:t,isNew:r,loadBalancer:n,ref:i})}),Ot.createElement(w,{label:"Target Groups",wizard:s,order:i(),render:({innerRef:a})=>Ot.createElement(ci,{ref:a,formik:t,app:e,isNew:r,loadBalancer:n})}),Ot.createElement(w,{label:"Listeners",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(oi,{ref:e,formik:t})}),Ot.createElement(w,{label:"Advanced Settings",wizard:s,order:i(),render:({innerRef:e})=>Ot.createElement(si,{ref:e,showDualstack:!t.values.isInternal&&ua(t.values.targetGroups,{targetType:"instance"})})}))})}};let ui=di;ui.defaultProps={closeModal:C,dismissModal:C};const pi=[{type:"application",label:"Application",sublabel:"ALB",description:"Highly configurable, application-focused balancer. HTTP and HTTPS only.",component:ei},{type:"network",label:"Network",sublabel:"NLB",description:"Basic, high-performance balancer with fixed IP.",component:ui},{type:"classic",label:"Classic",sublabel:"Legacy",description:"Previous generation balancer (ELB).",component:ii}],mi=class extends Ot.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:pi,selectedChoice:pi[0]}}static show(e){return b.show(mi,{...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=Sn.createLoadBalancerWarnings&&Sn.createLoadBalancerWarnings[n.type];return Ot.createElement(Ot.Fragment,null,Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Select Type of Load Balancer")),Ot.createElement(qa.Body,null,Ot.createElement("div",{className:"modal-body"},Ot.createElement("div",{className:"card-choices"},r.map((e=>Ot.createElement("div",{key:e.type,className:"card "+(n===e?"active":""),onClick:()=>this.choiceSelected(e)},Ot.createElement("h3",{className:"load-balancer-label"},e.label),Ot.createElement("h3",null,"(",e.sublabel,")"),Ot.createElement("div",null,e.description))))),Ot.createElement(Ot.Fragment,null,i.length>0&&i.map((e=>Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"})," ",e.reason))))),!!s&&Ot.createElement("div",{className:"alert alert-warning"},Ot.createElement("p",null,Ot.createElement("i",{className:"fa fa-exclamation-triangle"}),Ot.createElement(Ce,{message:s,style:{display:"inline-block",marginLeft:"2px"}}))),Ot.createElement("div",{className:"load-balancer-description"}))),Ot.createElement(qa.Footer,null,Ot.createElement(Ha,{onClick:this.choose},"Configure Load Balancer ",Ot.createElement("span",{className:"glyphicon glyphicon-chevron-right"}))))}};let gi=mi;gi.defaultProps={closeModal:C,dismissModal:C};class hi extends Ot.Component{constructor(e){super(e),this.editLoadBalancer=()=>{const{loadBalancer:e}=this.props,{application:t}=this.state;pi.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:ra(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&&pa(l).filter((e=>e)).length)&&!s.length;return Ot.createElement("div",{style:{display:"inline-block"}},Sn.adHocInfraWritesEnabled&&Ot.createElement(Ua,{className:"dropdown",id:"load-balancer-actions-dropdown"},Ot.createElement(Ua.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},Ot.createElement("span",null,"Load Balancer Actions")),Ot.createElement(Ua.Menu,{className:"dropdown-menu"},r&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.editLoadBalancer},"Edit Load Balancer"),!r&&Ot.createElement("li",{className:"disabled"},Ot.createElement("a",null,"Edit Load Balancer"," ",Ot.createElement(n,{content:`The application <b>${o}</b> must be configured before this load balancer can be edited.`}))),c&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.deleteLoadBalancer},"Delete Load Balancer"),!c&&Ot.createElement("li",{className:"disabled"},Ot.createElement("a",null,"Delete Load Balancer"," ",Ot.createElement(n,{content:"You must detach all instances before you can delete this load balancer."}))),a&&a.feature.entityTags&&Ot.createElement(N,{component:t,application:e,entityType:"loadBalancer",onUpdate:this.entityTagUpdate}))))}}const fi="spinnaker.amazon.loadBalancer.details.loadBalancerActions.component";t(fi,[]).component("loadBalancerActions",Xa(L(hi,"loadBalancerActions"),["app","loadBalancer","loadBalancerFromParams"]));class vi{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=Jt(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 ma(e.map((e=>e.purpose)))||""}}vi.$inject=["$scope","$state","$q","loadBalancer","app","securityGroupReader","loadBalancerReader"];t("spinnaker.amazon.loadBalancer.details.controller",[tn,Ie,fi,Ae,xe]).controller("awsLoadBalancerDetailsCtrl",vi);class yi{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))}}yi.$inject=["$scope","$q","$state","targetGroup","app"];t("spinnaker.amazon.loadBalancer.details.targetGroupDetails.controller",[tn,xe]).controller("awsTargetGroupDetailsCtrl",yi);t("spinnaker.amazon.loadBalancer.targetGroup.states",[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:Ir,$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)}]);t("spinnaker.amazon.loadBalancer",["spinnaker.amazon.loadBalancer.details.controller","spinnaker.amazon.loadBalancer.details.targetGroupDetails.controller",fi,"spinnaker.amazon.loadBalancer.targetGroup.states"]);t("spinnaker.amazon.pipeline.stage.bake.executionDetails.controller",[tn]).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"===ra(e.stage,"context.status.result")&&!e.stage.failureMessage},s=()=>n.synchronizeSection(e.configSections,i);s(),e.$on("$stateChangeSuccess",s)}]);t("spinnaker.amazon.pipeline.stage.bakeStage",["spinnaker.amazon.pipeline.stage.bake.executionDetails.controller"]).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:ze,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=Be.getAuthenticatedUser().name),e.viewState={loading:!0,roscoMode:a.feature.roscoMode||"function"==typeof a.feature.roscoSelector&&a.feature.roscoSelector(e.stage),minRootVolumeSize:Sn.minRootVolumeSize,showVmTypeSelector:!0,bakeWarning:Sn.bakeWarning,dockerBakeWarning:Sn.dockerBakeWarning,showDockerPreview:Sn.dockerBakeryDeprecated&&"docker"===e.stage.storeType,showMigrationFields:"Started"!==e.pipeline.migrationStatus,showStoreType:!Sn.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&&qt.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(){qt.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&&qt.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')}]);t("spinnaker.amazon.pipeline.stage.cloneServerGroupStage",[]).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=qt.get(e,"application.attributes.providerSettings.aws.useAmiBlockDeviceMappings",!1),t.copySourceCustomBlockDeviceMappings=!1),this.targetClusterUpdated=()=>{if(t.targetCluster){const a=Le.monikerClusterNameFilter(t.targetCluster),n=qt.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},qt.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)=>{qt.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 bi=[{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 Ei extends Ot.Component{constructor(e){super(e);const{value:t}=this.props,a=bi.filter((e=>e.value===t))[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Ot.createElement("div",null,Ot.createElement("b",null," ",this.state.label," "),Ot.createElement("br",null),Ot.createElement("small",null," ",this.state.description," "))}}function wi(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 Ot.createElement("div",{className:"form-horizontal"},Ot.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=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:(t,a)=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue(t,a)},input:e=>Ot.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))})}),Ot.createElement(s,{label:"Function Name",name:"functionName",input:e=>Ot.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:l})}),Ot.createElement(s,{label:"Target Version",name:"version",input:t=>Ot.createElement(c,{...t,clearable:!1,options:bi,optionRenderer:t=>Ot.createElement(Ei,{config:e,value:t.value,showingDetails:!0})})}),"$PROVIDED"===t.version?Ot.createElement(s,{label:"Version Number",name:"versionNumber",input:e=>Ot.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?Ot.createElement(s,{name:"retentionNumber",help:Ot.createElement(n,{content:"The number of Lambda versions to retain"}),label:"Prior Versions to Retain",input:e=>Ot.createElement(p,{...e,min:1,max:100})}):null)}function Ci(e){const{stage:t,name:a,current:n}=e;return Ot.createElement(Re,{name:a,current:n},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," ",Ot.createElement("b",null," Status: ")," ","done"===t.outputs.deleteTask?"COMPLETE":t.outputs.deleteTask," "),Ot.createElement("p",null," ",Ot.createElement("b",null," Deleted Version: ")," ",t.outputs["deleteTask:deleteVersion"]?t.outputs["deleteTask:deleteVersion"]:"N/A"," ")))}function Si(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()}(Ci||(Ci={})).title="Delete Lambda Stage";const ki={key:"Aws.LambdaDeleteStage",label:"AWS Lambda Delete",description:"Delete an AWS Lambda Function",component:function(e){return Ot.createElement("div",{className:"DeleteLambdaStageConfig"},Ot.createElement(Ue,{...e,validate:Si,onChange:e.updateStage,render:e=>Ot.createElement(wi,{...e})}))},executionDetailsSections:[Ci,Ve],validateFn:Si};t("spinnaker.amazon.pipeline.stage.Aws.LambdaDeleteStage",[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(ki)}));t("spinnaker.amazon.cloudformation.changetset.info.component",[]).component("cloudFormationChangeSetInfo",Xa(L((e=>{const{stage:t,stageconfig:a}=e,[n,r]=Vt(t.changeSetName?t.changeSetName:"ChangeSet-${execution['id']}"),[i,s]=Vt(t.executeChangeSet),[o,u]=Vt(t.actionOnReplacement);return Ot.createElement("div",null,Ot.createElement("hr",null),Ot.createElement("h4",null,"ChangeSet Configuration"),Ot.createElement(qe,{label:"ChangeSet Name"},Ot.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}})),Ot.createElement(qe,{label:"Execute ChangeSet"},Ot.createElement(d,{checked:i,onChange:e=>{return t=e.target.checked,s(t),void a.updateStageField({executeChangeSet:t});var t}})),i&&Ot.createElement(qe,{label:"If ChangeSet contains a replacement","help-key":"aws.cloudformation.changeSet.options"},Ot.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 Ni{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()}}}Ni.$inject=["$scope"];const Ti={bindings:{command:"<",templateBody:"<"},controller:Ni,controllerAs:"ctrl",template:'\n <yaml-editor\n value="ctrl.rawTemplateBody"\n on-change="ctrl.handleChange"\n ></yaml-editor>'};t("spinnaker.amazon.cloudformation.entry.component",[]).component("cloudFormationTemplateEntry",Ti);class Gi extends Rt.Component{constructor(e){super(e)}render(){const{stage:e,current:t,name:a}=this.props;return Rt.createElement(Re,{name:a,current:t},Rt.createElement(We,{item:e}),Rt.createElement(Oe,{stage:e,message:e.failureMessage}))}}Gi.title="Task Status";class Ii{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((()=>{ga(this.$scope.pipeline,e)}))};const t={accounts:o.getAllAccountDetailsForProvider("aws"),artifactAccounts:o.getArtifactAccounts()};Ya.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}}Ii.$inject=["$scope"];const Ai=e=>{const{execution:t,stage:a,application:n}=e,[r,i]=Vt(!1),[s,l]=Vt(""),[o,c]=Vt(!1),d=e=>{i(!0),l(e),c(!1),_n.evaluateCloudFormationChangeSetExecutionService.evaluateExecution(n,t,a,e)},u=e=>a.judgmentStatus===e||r&&s===e;return Ot.createElement("div",null,Ot.createElement("div",null,Ot.createElement("p",null,"This ChangeSet contains a replacement, which means there will be ",Ot.createElement("b",null,"potential data loss")," when executed."),Ot.createElement("p",null,"How do you want to proceed?"),Ot.createElement("div",{className:"action-buttons"},Ot.createElement("button",{className:"btn btn-danger",onClick:()=>{d("execute")},disabled:r},u("Execute")&&Ot.createElement(ae,{mode:"circular"}),a.context.stopButtonLabel||"Execute"),Ot.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("skip")}},u("Skip")&&Ot.createElement(ae,{mode:"circular"}),a.context.skipButtonLabel||"Skip"),Ot.createElement("button",{className:"btn btn-primary",disabled:r,onClick:()=>{d("fail")}},u("Fail")&&Ot.createElement(ae,{mode:"circular"}),a.context.FailButtonLabel||"Fail"))),o&&Ot.createElement("div",{className:"error-message"},"There was an error recording your decision. Please try again."))};class xi extends Rt.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 Rt.createElement(Re,{name:r,current:n},s?Rt.createElement(Ai,{key:a.refId,application:e,execution:t,stage:a}):Rt.createElement("div",null,l?Rt.createElement("div",null,Rt.createElement("dl",{className:"no-margin"},Rt.createElement("dt",null,"ChangeSet Name"),Rt.createElement("dd",null,a.context.changeSetName),Rt.createElement("dt",null,"Replacement"),Rt.createElement("dd",null,String(i)),a.context.changeSetExecutionChoice&&Rt.createElement("div",null,Rt.createElement("dt",null,"Judgment"),Rt.createElement("dd",null,a.context.changeSetExecutionChoice),Rt.createElement("dt",null,"Judged By"),Rt.createElement("dd",null,a.context.lastModifiedBy)))):Rt.createElement("div",null,"No changeSets found")))}}xi.title="Change Set Execution";class Pi extends Rt.Component{render(){if(!this.props.executionMarker)return Rt.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=Rt.createElement("div",null,Rt.createElement("div",null,Rt.createElement("b",null,e.name)),Rt.createElement(Ai,{stage:e.masterStage,application:this.props.application,execution:this.props.execution}));return Rt.createElement(ne,{template:t},this.props.children)}const t=Rt.createElement(Wa,{id:e.id},e.name);return Rt.createElement(ja,{placement:"top",overlay:t},Rt.createElement("span",null,this.props.children))}}class Di extends Rt.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,Rt.createElement("span",{className:"fa fa-child"})):null}}t("spinnaker.amazon.pipeline.stages.deployCloudFormationStage",[]).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:[Gi,xi],executionLabelComponent:Pi,producesArtifacts:!0,supportsCustomTimeout:!0,validators:[],markerIcon:Di,accountExtractor:e=>e.account?[e.account]:[],configAccountExtractor:e=>e.account?[e.account]:[],artifactExtractor:Ke.accumulateArtifacts(["stackArtifactId","requiredArtifactIds"]),artifactRemover:Ye.removeArtifactFromFields(["stackArtifactId","requiredArtifactIds"])})})).controller("DeployCloudFormationStackConfigController",Ii),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 zi{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)))}}zi.$inject=["executionService"];function Bi(e,t){return Object.entries(t).forEach((([t,a])=>{var n;e[t]||ha(n=a)&&(Kt(n)||""===n)||(e[t]=a)})),e}function Fi(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 Ot.createElement("div",null,Ot.createElement(s,{label:"Account",name:"account",input:e=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("enableLambdaAtEdge",!1),e.formik.setFieldValue("region",t)},input:e=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.filter((e=>e.name===t.account)).flatMap((e=>e.regions)).map((e=>e.name))})}),Ot.createElement(s,{name:"functionUid",label:"Function Name",onChange:t=>{e.formik.setFieldValue("functionUid",t),a()},help:Ot.createElement(n,{id:"aws.function.name"}),input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"stackName",label:"Stack",help:Ot.createElement(n,{content:Fn}),onChange:t=>{e.formik.setFieldValue("stackName",t),a()},input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"detailName",label:"Detail",help:Ot.createElement(n,{content:Mn}),onChange:t=>{e.formik.setFieldValue("detailName",t),a()},input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"aliasNames",label:"Alias Name",help:Ot.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=>Ot.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}))):[]})}),Ot.createElement(s,{name:"runtime",label:"Runtime",help:Ot.createElement(n,{id:"aws.function.runtime"}),input:e=>Ot.createElement(c,{...e,stringOptions:Bn,clearable:!0})}),Ot.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Ot.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Ot.createElement(l,{...e,placeholder:"S3 bucket name"})}),Ot.createElement(s,{name:"s3key",label:"S3 Key",help:Ot.createElement(n,{id:"aws.function.s3key"}),input:e=>Ot.createElement(l,{...e,placeholder:"object.zip"})}),Ot.createElement(s,{name:"handler",label:"Handler",help:Ot.createElement(n,{id:"aws.function.handler"}),input:e=>Ot.createElement(l,{...e,placeholder:"filename.method"})}),Ot.createElement(s,{name:"publish",label:"Publish",help:Ot.createElement(n,{id:"aws.function.publish"}),input:e=>Ot.createElement(d,{...e})}))}t("spinnaker.amazon.deployCloudFormation.service",[Xe]).service("evaluateCloudFormationChangeSetExecutionService",zi);function Mi(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=jt(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 Ot.createElement("div",null,Ot.createElement(s,{name:"vpcId",label:"VPC Id",input:e=>Ot.createElement(c,{...e,onChange:a,isLoading:"PENDING"===r,stringOptions:o,clearable:!0})}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Subnets ")),0===d.length?Ot.createElement("div",{className:"form-control-static"},"No subnets found in the selected account/region/VPC "):Ot.createElement("div",{className:"col-md-6"},Ot.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)}}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Security Groups ")),0===u.length?Ot.createElement("div",{className:"form-control-static"},"No security groups found in the selected account/region/VPC "):Ot.createElement("div",{className:"col-md-6"},Ot.createElement(f,{multi:!0,options:u,value:t.securityGroupIds,onChange:t=>{const a=t.map((e=>e.value));e.formik.setFieldValue("securityGroupIds",a)}}))))}function $i(){return Ot.createElement(s,{name:"role",label:"Role ARN",input:e=>Ot.createElement(l,{...e,placeholder:"Enter role ARN",name:"role"})})}function Li(e){const{values:t}=e.formik;return Ot.createElement("div",null,Ot.createElement(s,{name:"triggerArns",label:"Event ARNs",help:Ot.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=>Ot.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}))):[]})}),Ot.createElement(s,{name:"batchsize",label:"Event Batch Size",input:e=>Ot.createElement(p,{...e,min:1,max:1e3})}))}const Ri="Validate AWS Lambda function configuration against Lambda@Edge requirements. This will not enable Lambda@Edge on this function. ";function Oi(e){const{values:t}=e.formik;return"us-east-1"!==t.region?Ot.createElement("div",{className:"horizontal center"},"Lambda@Edge is only available in region us-east-1."):Ot.createElement("div",null,Ot.createElement(s,{name:"enableLambdaAtEdge",label:"Enable Lambda@Edge Validation",help:Ot.createElement(n,{content:Ri}),input:e=>Ot.createElement(d,{...e})}))}function Vi(e){const{values:t,errors:a}=e.formik,r=ka({well:!0,"alert-danger":!!a.functionName,"alert-info":!a.functionName});return Ot.createElement("div",{className:"form-horizontal"},Ot.createElement("div",{className:r},Ot.createElement("strong",null,"Your function will be named: "),Ot.createElement(n,{id:"aws.function.name"}),Ot.createElement("span",null,t.functionName?t.functionName:e.application.name),Ot.createElement(s,{name:"functionName",input:()=>null})),Ot.createElement("h4",null,"Basic Settings"),Ot.createElement(Fi,{...e}),Ot.createElement("h4",null," Execution Role "),Ot.createElement($i,null),Ot.createElement("h4",null," Environment "),!0!==t.enableLambdaAtEdge?Ot.createElement(Ot.Fragment,null,Ot.createElement(s,{name:"envVariables",label:"Env Variables",input:e=>Ot.createElement(u,{...e,allowEmptyValues:!0,addButtonLabel:"Add"})}),Ot.createElement(s,{name:"encryptionKMSKeyArn",label:"Key ARN",help:Ot.createElement(n,{id:"aws.function.kmsKeyArn"}),input:e=>Ot.createElement(l,{...e})})):Ot.createElement("div",{className:"horizontal center"},"Environment variables not available with Lambda@Edge functions."),Ot.createElement("h4",null," Tags "),Ot.createElement(s,{name:"tags",input:e=>Ot.createElement(u,{...e,allowEmptyValues:!1,addButtonLabel:"Add"})}),Ot.createElement("h4",null," Settings "),Ot.createElement(s,{name:"description",label:"Description",input:e=>Ot.createElement(l,{...e})}),Ot.createElement(s,{name:"layers",label:"Layer ARNs",help:Ot.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=>Ot.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}))):[]})}),Ot.createElement(s,{name:"reservedConcurrentExecutions",label:"Reserved Concurrency",help:Ot.createElement(n,{content:"The total number of current executions of your Lambda function that can be instantiated at any time."}),input:e=>Ot.createElement(p,{...e,min:0,max:3e3})}),Ot.createElement(s,{name:"memorySize",label:"Memory (MB)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.memorySize"}),input:e=>Ot.createElement(p,{...e,min:128,max:!0===t.enableLambdaAtEdge?128:3008})}),Ot.createElement(s,{name:"timeout",label:"Timeout (seconds)",help:Ot.createElement(n,{id:"aws.functionBasicSettings.timeout"}),input:e=>Ot.createElement(p,{...e,min:1,max:!0===t.enableLambdaAtEdge?5:900})}),Ot.createElement(Oi,{...e}),Ot.createElement("h4",null," Network "),!0!==t.enableLambdaAtEdge?Ot.createElement(Mi,{...e}):Ot.createElement("div",{className:"horizontal center"},"VPC configuration not available with Lambda@Edge functions."),Ot.createElement("h4",null," Event Triggers "),Ot.createElement(Li,{...e}),Ot.createElement("h4",null," Debugging and Error Handling "),"Dead Letter Config",Ot.createElement(s,{name:"deadLetterConfig.targetArn",label:"Target ARN",help:Ot.createElement(n,{id:"aws.function.deadletterqueue"}),input:e=>Ot.createElement(l,{...e})}),"X-Ray Tracing",Ot.createElement(s,{name:"tracingConfig.mode",label:"Mode",help:Ot.createElement(n,{id:"aws.function.tracingConfig.mode"}),input:e=>Ot.createElement(c,{...e,stringOptions:["Active","PassThrough"],clearable:!0})}))}function Ui(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(Dn),t.field("detailName","Detail Name").optional().withValidators(Dn),t.field("s3bucket","S3 Bucket Name").required().withValidators(An),t.field("role","Role ARN").required().withValidators(In),t.field("triggerArns","Trigger ARNs").optional().withValidators(((e,t)=>e.map((e=>xn(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 qi(e){const{stage:t,current:a,name:n}=e;return Ot.createElement(Re,{name:n,current:a},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," ",Ot.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Ot.createElement("p",null," ",Ot.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}(qi||(qi={})).title="Lambda Deployment Stage";const Hi={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 Ot.createElement("div",{className:"LambdaDeploymentConfig"},Ot.createElement(Ue,{...e,stage:Bi(e.stage,t),validate:Ui,onChange:e.updateStage,render:e=>Ot.createElement(Vi,{...e})}))},executionDetailsSections:[qi,Ve],validateFn:Ui};t("spinnaker.amazon.pipeline.stage.Aws.LambdaDeploymentStage",[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Hi)}));t("spinnaker.amazon.pipeline.stage.aws.destroyAsgStage",[]).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')}]);t("spinnaker.amazon.pipeline.stage.disableAsgStage",[]).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')}]);t("spinnaker.amazon.pipeline.stage.disableClusterStage",[]).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')}]);t("spinnaker.amazon.pipeline.stage.enableAsgStage",[]).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')}]);e.module("spinnaker.amazon.pipeline.stage.findAmiStage",[]).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')}]);function Wi(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 Ot.createElement("div",null,Ot.createElement(s,{name:"timeout",label:"Timeout",input:e=>Ot.createElement(p,{...e,min:0,max:900})}),Ot.createElement(s,{name:"executionCount",label:"Execution Count",input:e=>Ot.createElement(p,{...e,min:0,max:100})}),Ot.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 ji(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 Ot.createElement("div",{className:"form-horizontal"},Ot.createElement("h4",null," Basic Settings "),Ot.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=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===r,stringOptions:n.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Ot.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))})}),Ot.createElement(s,{label:"Function Name",name:"functionName",input:e=>Ot.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:i})}),Ot.createElement(s,{label:"Alias",name:"aliasName",input:e=>Ot.createElement(l,{...e})}),Ot.createElement("h4",null," Invoke Settings "),Ot.createElement(Wi,{...e}))}function Zi(e){const{stage:t}=e;return Ot.createElement(Re,{name:e.name,current:e.current},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," Function Name: ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Ot.createElement("p",null," ","Deployed Alias:"," ",t.outputs["deployment:aliasDeployed"]?t.outputs["deployment:aliasDeployed"]:"N/A"," "),Ot.createElement("p",null," ","Deployed Major Version:"," ",t.outputs["deployment:majorVersionDeployed"]?t.outputs["deployment:majorVersionDeployed"]:"N/A"," ")))}function _i(e){const t=new i(e);return t.field("triggerArns","Trigger ARNs").optional().withValidators(((e,t)=>e.map((e=>xn(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("spinnaker.amazon.pipeline.stage.findImageFromTagsStage",[]).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')}]),(Zi||(Zi={})).title="Invoke Lambda Stage";const Ki={key:"Aws.LambdaInvokeStage",label:"AWS Lambda Invoke",description:"Invoke a Lambda function",component:function(e){return Ot.createElement("div",{className:"InvokeLambdaStageConfig"},Ot.createElement(Ue,{...e,validate:_i,onChange:e.updateStage,render:e=>Ot.createElement(ji,{...e})}))},executionDetailsSections:[Zi,Ve],validateFn:_i};t("spinnaker.amazon.pipeline.stage.Aws.LambdaInvokeStage",[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(Ki)}));t("spinnaker.amazon.pipeline.stage.modifyScalingProcessStage",[]).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')}]);t("spinnaker.amazon.pipeline.stage.aws.resizeAsgStage",[]).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')}]);function Yi(e){const{values:t}=e.formik;return Ot.createElement("div",null,Ot.createElement(s,{name:"triggerArns",label:"Event ARNs",help:Ot.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=>Ot.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}),Ot.createElement(s,{name:"batchsize",label:"Event Batch Size",input:e=>Ot.createElement(p,{...e,min:1,max:10}),required:!1}))}function Xi(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 Ot.createElement("div",null,Ot.createElement(s,{name:"destroyOnFail",label:"On Fail",input:e=>Ot.createElement(d,{text:"Destroy latest lambda version on fail.",...e})}),Ot.createElement(s,{name:"timeout",label:"Timeout",input:e=>Ot.createElement(p,{...e,min:0,max:900})}),Ot.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}),Ot.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("spinnaker.amazon.pipeline.stage.rollbackClusterStage",[]).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 Ji=[{label:"Lambda Invocation",value:"$LAMBDA"}];function Qi(e){const{values:t}=e.formik;return Ot.createElement("div",null,Ot.createElement(s,{label:"Health Check Type",name:"healthCheckType",input:e=>Ot.createElement(c,{...e,clearable:!1,options:Ji})}),t.healthCheckType?function(e,t){switch(e){case"$LAMBDA":return Ot.createElement(Xi,{...t});case"$WEIGHTED":case"$BLUEGREEN":default:return null}}(t.healthCheckType,e):null)}const es=[{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 ts extends Ot.Component{constructor(e){super(e);const{value:t}=this.props,a=es.filter((e=>e.value===t))[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Ot.createElement("div",null,Ot.createElement("b",null," ",this.state.label," "),Ot.createElement("br",null),Ot.createElement("small",null," ",this.state.description," "))}}const as=[{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 ns extends Ot.Component{constructor(e){super(e);const{value:t}=this.props,a=as.filter((e=>e.value===t))[0];this.state={label:a.label,value:a.value,description:a.description}}render(){return Ot.createElement("div",null,Ot.createElement("b",null," ",this.state.label," ")," ",Ot.createElement("br",null),Ot.createElement("small",null," ",this.state.description," "))}}function rs(e){const{values:t}=e.formik,{functions:a}=e.application;return Ot.createElement("div",{className:"form-horizontal"},Ot.createElement(s,{label:"Target Version",name:"versionNameA",onChange:t=>{e.formik.setFieldValue("trafficPercentA",100),e.formik.setFieldValue("versionNameA",t)},input:e=>Ot.createElement(c,{...e,clearable:!1,options:as,optionRenderer:e=>Ot.createElement(ns,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameA?Ot.createElement(s,{label:"Version Number",name:"versionNumberA",input:e=>Ot.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,Ot.createElement(s,{name:"trafficPercentA",label:"Traffic %",input:e=>Ot.createElement(p,{...e,min:0,max:100,value:100,disabled:!0})}))}function is(e){const{values:t}=e.formik,{functions:a}=e.application;return Ot.createElement("div",{className:"form-horizontal"},Ot.createElement(s,{label:"Target Version",name:"versionNameA",input:e=>Ot.createElement(c,{...e,clearable:!1,options:as,optionRenderer:e=>Ot.createElement(ns,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameA?Ot.createElement(s,{label:"Version Number",name:"versionNumberA",input:e=>Ot.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,Ot.createElement(s,{name:"trafficPercentA",label:"Traffic %",input:e=>Ot.createElement(p,{...e,min:0,max:100})}),Ot.createElement(s,{label:"Version Name",name:"versionNameB",input:e=>Ot.createElement(c,{...e,clearable:!1,options:as,optionRenderer:e=>Ot.createElement(ns,{value:e.value,showingDetails:!0})})}),"$PROVIDED"===t.versionNameB?Ot.createElement(s,{label:"Version Number",name:"versionNumberB",input:e=>Ot.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,Ot.createElement(s,{name:"trafficPercentB",label:"Traffic %",input:e=>Ot.createElement(p,{...e,min:0,max:100,disabled:!0,value:t.trafficPercentA||0===t.trafficPercentA?100-t.trafficPercentA:null})}))}function ss(e){const{values:t}=e.formik;return Ot.createElement("div",{className:"form-horizontal"},t.deploymentStrategy?function(e,t){switch(e){case"$SIMPLE":return Ot.createElement(rs,{...t});case"$WEIGHTED":return Ot.createElement(is,{...t});case"$BLUEGREEN":return Ot.createElement(Qi,{...t});default:return null}}(t.deploymentStrategy,e):null)}function ls(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 Ot.createElement("div",{className:"form-horizontal"},Ot.createElement("h4",null," Basic Settings "),Ot.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=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Ot.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))})}),Ot.createElement(s,{label:"Function Name",name:"functionName",input:e=>Ot.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:d})}),Ot.createElement(s,{label:"Alias",name:"aliasName",input:e=>Ot.createElement(l,{...e})}),Ot.createElement("h4",null," Alias Settings "),Ot.createElement(Yi,{...e}),Ot.createElement(s,{name:"provisionedConcurrentExecutions",label:"Provisioned Concurrency",help:Ot.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?Ot.createElement(p,{...e,min:0,max:0}):Ot.createElement(p,{...e,min:0,max:3e3}),required:!1}),Ot.createElement("h4",null," Deployment Strategy "),Ot.createElement(s,{label:"Strategy",name:"deploymentStrategy",help:Ot.createElement(n,{content:""}),input:t=>Ot.createElement(c,{...t,clearable:!1,options:es,optionRenderer:t=>Ot.createElement(ts,{config:e,value:t.value,showingDetails:!0})})}),t.deploymentStrategy?Ot.createElement(ss,{...e}):null)}function os(e){const{stage:t}=e;return Ot.createElement(Re,{name:e.name,current:e.current},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," Function Name: ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Ot.createElement("p",null," ","Deployed Alias:"," ",t.outputs["deployment:aliasDeployed"]?t.outputs["deployment:aliasDeployed"]:"N/A"," "),Ot.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=>xn(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 ds={key:"Aws.LambdaTrafficRoutingStage",label:"AWS Lambda Route",description:"Route traffic across various versions of your Lambda function",component:function(e){return Ot.createElement("div",{className:"RouteLambdaStageConfig"},Ot.createElement(Ue,{...e,validate:cs,onChange:e.updateStage,render:e=>Ot.createElement(ls,{...e})}))},executionDetailsSections:[os,Ve],validateFn:cs};t("spinnaker.amazon.pipeline.stage.Aws.LambdaTrafficRoutingStage",[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(ds)}));t("spinnaker.amazon.pipeline.stage.scaleDownClusterStage",[]).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')}]);t("spinnaker.amazon.pipeline.stage.aws.shrinkClusterStage",[]).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')}]);function us(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 Ot.createElement("div",{className:"form-horizontal"},Ot.createElement("h4",null," Basic Settings "),Ot.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=>Ot.createElement(c,{...e,clearable:!1,isLoading:"PENDING"===i,stringOptions:r.map((e=>e.name))})}),Ot.createElement(s,{label:"Region",name:"region",onChange:t=>{e.formik.setFieldValue("functionName",null),e.formik.setFieldValue("region",t)},input:e=>Ot.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))})}),Ot.createElement(s,{label:"Function Name",name:"functionName",input:e=>Ot.createElement(c,{clearable:!1,disabled:!(t.account&&t.region),placeholder:t.account&&t.region?"Select...":"Select an Account and Region...",...e,stringOptions:u})}),Ot.createElement(s,{name:"s3bucket",label:"S3 Bucket",help:Ot.createElement(n,{id:"aws.function.s3bucket"}),input:e=>Ot.createElement(l,{...e,placeholder:"S3 bucket name"})}),Ot.createElement(s,{name:"s3key",label:"S3 Key",help:Ot.createElement(n,{id:"aws.function.s3key"}),input:e=>Ot.createElement(l,{...e,placeholder:"object.zip"})}),Ot.createElement(s,{name:"publish",label:"Publish",help:Ot.createElement(n,{id:"aws.function.publish"}),input:e=>Ot.createElement(d,{...e})}))}t("spinnaker.amazon.pipeline.stage.tagImageStage",[]).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 ps(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(An),t.validateForm()}function ms(e){const{stage:t,current:a,name:n}=e;return Ot.createElement(Re,{name:n,current:a},Ot.createElement(Oe,{stage:t,message:t.outputs.failureMessage}),Ot.createElement("div",null,Ot.createElement("p",null," ",Ot.createElement("b",null," Function Name: ")," ",t.outputs.functionName?t.outputs.functionName:"N/A"," "),Ot.createElement("p",null," ",Ot.createElement("b",null," Function ARN: ")," ",t.outputs.functionARN?t.outputs.functionARN:"N/A"," ")))}yr(""),(ms||(ms={})).title="Lambda Update Code Stage";const gs={key:"Aws.LambdaUpdateCodeStage",label:"AWS Lambda Update Code",description:"Update code for a single AWS Lambda Function",component:function(e){return Ot.createElement("div",{className:"LambdaUpdateCodeConfig"},Ot.createElement(Ue,{...e,validate:ps,onChange:e.updateStage,render:e=>Ot.createElement(us,{...e})}))},executionDetailsSections:[ms,Ve],validateFn:ps};t("spinnaker.amazon.pipeline.stage.Aws.LambdaUpdateCodeStage",[]).config((function(){a.feature.lambdaAdditionalStages&&De.pipeline.registerStage(gs)}));t("spinnaker.amazon.react",[]).run(["$injector",function(e){_n.initialize(e)}]);t("spinnaker.amazon.search.searchResultFormatter",[]).factory("awsSearchResultFormatter",(function(){return{securityGroups:function(e){return Un.getVpcName(e.vpcId).then((function(t){const a=t?e.region+" - "+t.toLowerCase():e.region;return e.name+" ("+a+")"}))}}}));t("spinnaker.amazon.securityGroup.baseConfig.controller",[tn,Ie]).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||[];Un.listVpcs().then((function(n){const r=qt.groupBy(n.filter((e=>e.account===t)),"label");e.allVpcs=n;const i=[];qt.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=Sn.classicLaunchLockout;if(!r.id&&a){if(Number(qt.get(n,"attributes.createTs",0))>=a&&(e.hideClassic=!0,!r.vpcId&&t.length)){let a;if(Sn.defaults.vpc){const e=t.find((e=>e.label===Sn.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=>Sn.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=qt.find(e.allVpcs,{id:t});s=qt.find(e.allVpcs,{account:a,region:n,name:r.name}).id}const o=qt.get(l,[a,"aws",n].join("."),[]).filter((e=>e.vpcId===s)).map((e=>e.name));r=qt.uniq(r.concat(o)),i=i.length?qt.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 Na,e.coordinatesChanged=new Na,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?qt.filter(t[a].aws[n],{vpcId:r}):t,e.availableSecurityGroups=qt.map(i,"name");const s=Sn.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")}}]);e.module("spinnaker.amazon.securityGroup.clone.controller",["spinnaker.amazon.securityGroup.baseConfig.controller"]).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=qt.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=qt.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')}]);e.module("spinnaker.amazon.securityGroup.create.controller",[tn,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')}]);e.module("spinnaker.amazon.securityGroup.edit.controller",[tn]).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=qt.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=qt.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 hs={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=Sn)?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=ia(n.concat(d)),r=r.length?fa(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)}}}};t("spinnaker.amazon.securityGroup.configure.ingressRuleGroupSelector",[]).component("ingressRuleGroupSelector",hs),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 fs=Object.defineProperty,vs=Object.getOwnPropertyDescriptor;let ys=class extends Ot.Component{render(){return null}};ys=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?vs(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&&fs(t,a,i),i})([ie("aws.securityGroup.details.custom")],ys);t("spinnaker.amazon.securityGroups.details.custom.component",[]).component("securityGroupDetailsCustom",Xa(L(ys,"securityGroupDetailsCustom"),["securityGroupDetails","ctrl","scope"]));e.module("spinnaker.amazon.securityGroup.details.controller",[tn,Ie,"spinnaker.amazon.securityGroup.clone.controller",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 Un.getVpcName(e.vpcId).then((t=>(e.vpcName=t,e)))})).then((function(a){if(t.state.loading=!1,!a||qt.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=qt.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=qt.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=!Sn.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 bs=Object.defineProperty,Es=Object.getOwnPropertyDescriptor;let ws=class extends Ot.Component{render(){const e=this.props.ipRules||[],t=`IP Range Rules (${e.length})`;return Ot.createElement(x,{heading:t},e.map((e=>Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},Ot.createElement(z,{label:"IP Range",value:e.address}),Ot.createElement(z,{label:"Port Ranges",value:e.rules.map((t=>"-1"===t.protocol?Ot.createElement("span",null,"All ports and protocols",e.rules.length>1?Ot.createElement("div",null,Ot.createElement("em",null,"Additional port ranges are specified, but redundant:")):null):Ot.createElement("div",null,Ot.createElement("span",null,t.protocol,":",t.startPort," → ",t.endPort))))})))))}};ws=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Es(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&&bs(t,a,i),i})([ie("aws.securityGroup.ip.rules")],ws);t("spinnaker.amazon.securityGroups.details.securityGroups.component",[]).component("ipRangeRules",Xa(L(ws,"ipRangeRules"),["ipRules"]));class Cs{resolveIndexedSecurityGroup(e,t,a){return Cs.resolveIndexedSecurityGroup(e,t,a)}static resolveIndexedSecurityGroup(e,t,a){return e[t.account][t.region][a]}}t("spinnaker.amazon.securityGroup.reader",[]).service("awsSecurityGroupReader",Cs);t("spinnaker.amazon.securityGroup.transformer",[]).factory("awsSecurityGroupTransformer",(function(){return{normalizeSecurityGroup:function(e){return Un.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=na(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}}));t("spinnaker.amazon.securityGroup",["spinnaker.amazon.securityGroup.reader","spinnaker.amazon.securityGroup.clone.controller","spinnaker.amazon.securityGroup.configure.ingressRuleGroupSelector","spinnaker.amazon.securityGroup.baseConfig.controller","spinnaker.amazon.securityGroup.create.controller","spinnaker.amazon.securityGroup.edit.controller","spinnaker.amazon.securityGroup.details.controller","spinnaker.amazon.securityGroup.transformer","spinnaker.amazon.securityGroups.details.securityGroups.component","spinnaker.amazon.securityGroups.details.custom.component"]);class Ss extends Ot.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 Ot.createElement(ot,{cloudProvider:"aws",application:e,command:t,onDismiss:a,onTemplateSelected:n,templateSelectionText:r})}}class ks extends Ot.Component{constructor(){super(...arguments),this.state={errorMessage:null,selectionMode:"packageImages",searchString:"",searchResults:null,isSearching:!1,packageImages:null,isLoadingPackageImages:!0},this.awsImageReader=new Qn,this.props$=new Na,this.searchInput$=new Na,this.destroy$=new Na,this.sortImagesBy$=new Ia("ts"),this.buildImageMenu=e=>{const{ImageMenuHeading:t,ImageLabel:a}=this,{options:n}=e;return Ot.createElement("div",{className:"Select-menu-outer"},Ot.createElement("div",{className:"Select-menu",role:"listbox"},n.length>0&&Ot.createElement(t,null),n.map((t=>Ot.createElement(a,{key:t.imageName,option:t,params:e})))))},this.ImageMenuHeading=()=>{const e=this.sortImagesBy$.value;return Ot.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)"}},Ot.createElement("b",null,"Sort by: "),Ot.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("ts")},"ts"===e?Ot.createElement("b",null,"timestamp (newest first)"):"timestamp (newest first)"),Ot.createElement("span",null," | "),Ot.createElement("a",{className:"clickable sp-padding-xs-xaxis",onClick:()=>this.setSortImagesBy("name")},"name"===e?Ot.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 Ot.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"},Ot.createElement("div",null,n.imageName),Ot.createElement("div",{className:"small"},Ot.createElement("b",null,"Created: "),n.attributes.creationDate,Ot.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)):Ya.when(null)}searchForImages(e){return e&&e.length>=3?this.awsImageReader.findImages({q:e}):Ya.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(Pa((e=>e.region)),Da()),{value:t,region:a,credentials:n,application:r}=this.props;this.setState({isLoadingPackageImages:!0});const i=this.fetchPackageImages(t,a,n,r),s=Ta(i).pipe(Ra((e=>(console.error(e),this.setState({errorMessage:"Unable to load package images"}),Aa([])))),$a((()=>this.setState({isLoadingPackageImages:!1})))),l=Ga([s,e,this.sortImagesBy$]).pipe(Pa((([e,t,a])=>{const n=e.filter((e=>!!e.amis[t]));return this.sortImages(n,a)}))),o=this.searchInput$.pipe($a((e=>this.setState({searchString:e}))),Da(),Oa(250)).pipe($a((()=>this.setState({isSearching:!0}))),Ba((e=>this.searchForImages(e))),Ra((e=>(console.error(e),this.setState({errorMessage:"Unable to search for images"}),Aa([])))),$a((()=>this.setState({isSearching:!1}))));Ga([o,e,this.sortImagesBy$]).pipe(Pa((([e,t,a])=>{const{searchString:n}=this.state;if(0===e.length&&/ami-[0-9a-f]{8,17}/.exec(n)){return[ks.makeFakeImage(n,n,t)].filter((e=>!!e))}const r=e.filter((e=>!!e.amis[t]));return this.sortImages(r,a)}))).pipe(Ma(this.destroy$)).subscribe((e=>this.setState({searchResults:e}))),l.pipe(Ma(this.destroy$)).subscribe((e=>{this.setState({packageImages:e}),this.selectImage(this.findMatchingImage(e,this.props.value))})),e.pipe(Ba((e=>{const t=this.props.value;if("packageImages"===this.state.selectionMode)return l.pipe(Pa((e=>this.findMatchingImage(e,t))));{const a=!!(t&&t.amis&&t.amis[e]);return Aa(a?t:void 0)}})),Ma(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 Ot.createElement(Ot.Fragment,null,Ot.createElement("span",null,e.imageName),Ot.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?Ot.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 Ot.createElement("div",{className:"col-md-9"},Ot.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?Ot.createElement("div",{className:"col-md-9"},Ot.createElement(f,{...m,menuRenderer:this.buildImageMenu,isLoading:i,placeholder:"Pick an image",noResultsText:h,options:o,onChange:r}),g,Ot.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Ot.createElement(n,{id:"aws.serverGroup.allImages"})):Ot.createElement("div",{className:"col-md-9"},Ot.createElement(f,{...m,isLoading:i,disabled:!0,options:[e].filter((e=>!!e))}),g,Ot.createElement("button",{type:"button",className:"link",onClick:()=>this.setState({selectionMode:"searchAllImages"})},"Search All Images")," ",Ot.createElement(n,{id:"aws.serverGroup.allImages"}))}}const Ns=e=>e&&e.includes("${");class Ts extends Ot.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=Sn.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=Sn)?void 0:t.serverGroups)?void 0:a.enableIPv6)&&(null==(r=null==(n=Sn)?void 0:n.serverGroups)?void 0:r.setIPv6InTest)&&"test"===g.environment),null==(i=Sn.serverGroups)?void 0:i.enableIMDSv2){const t=!(null==(o=null==(l=null==(s=Sn)?void 0:s.serverGroups)?void 0:l.accountDenyListIMDSv2)?void 0:o.includes(e)),a=null==(c=Sn.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=ks.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,Ns(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,Ns(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 Ot.createElement("div",{className:"container-fluid form-horizontal"},r.regionIsDeprecated(r)&&Ot.createElement("div",{className:"form-group row"},Ot.createElement("div",{className:"col-md-12 error-message"},Ot.createElement("div",{className:"alert alert-danger"},"You are deploying into a deprecated region within the ",r.credentials," account!"))),Ot.createElement(ct,{app:e,formik:t}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Account"),Ot.createElement("div",{className:"col-md-7"},Ot.createElement(Se,{value:r.credentials,onChange:e=>this.accountUpdated(e.target.value),readOnly:c.credentials,accounts:o,provider:"aws"}))),Ot.createElement(ke,{readOnly:c.region,labelColumns:3,component:r,field:"region",account:r.credentials,regions:r.backingData.filtered.regions,onChange:this.regionUpdated}),Ot.createElement(Yr,{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}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Stack ",Ot.createElement(n,{id:"aws.serverGroup.stack"})),Ot.createElement("div",{className:"col-md-7"},Ot.createElement("input",{type:"text",className:"form-control input-sm no-spel",value:r.stack,onChange:e=>this.stackChanged(e.target.value)}))),a.stack&&Ot.createElement("div",{className:"form-group row slide-in"},Ot.createElement("div",{className:"col-sm-9 col-sm-offset-2 error-message"},Ot.createElement("span",null,a.stack))),Ot.createElement(dt,{app:e,formik:t}),r.viewState.imageSourceText&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Image Source"),Ot.createElement("div",{className:"col-md-7",style:{marginTop:"5px"}},Ot.createElement(Ce,{tag:"span",message:r.viewState.imageSourceText}))),!r.viewState.disableImageSelection&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Image ",Ot.createElement(n,{id:"aws.serverGroup.imageName"})),Ns(r.amiName)?Ot.createElement(dn,{name:"amiName"}):Ot.createElement(ks,{onChange:e=>this.imageChanged(e),value:this.state.selectedImage,application:e,credentials:r.credentials,region:r.region})),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Traffic ",Ot.createElement(n,{id:"aws.serverGroup.traffic"})),Ot.createElement("div",{className:"col-md-9 checkbox"},Ot.createElement("label",null,Ot.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&&Ot.createElement(ut,{command:r,onFieldChange:this.onStrategyFieldChange,onStrategyChange:this.strategyChanged}),!r.viewState.hideClusterNamePreview&&Ot.createElement(pt,{createsNewCluster:i,latestServerGroupName:null==s?void 0:s.name,mode:r.viewState.mode,namePreview:l,navigateToLatestServerGroup:this.navigateToLatestServerGroup}),Ot.createElement(mt,{reason:r.reason,onChange:this.handleReasonChanged}))}}class Gs extends Ot.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?Ot.createElement("div",null,Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("p",null,"Sets up auto-scaling constraints for this server group."),Ot.createElement("p",null,"To set min, max, and desired instance counts to the same value use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!0)},"Simple Mode"),"."))),!a.useSourceCapacity&&"editPipeline"===e.viewState.mode&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Capacity"),Ot.createElement("div",{className:"col-md-9 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:e.useSourceCapacity,value:"true",id:"useSourceCapacityTrue",onChange:this.useSourceCapacityUpdated}),"Copy the capacity from the current server group",Ot.createElement(n,{id:"serverGroupCapacity.useSourceCapacityTrue"}))),e.useSourceCapacity&&Ot.createElement("div",{className:"col-md-9 col-md-offset-3 radio",style:{paddingLeft:"35px"}},Ot.createElement("div",null,"If no current server group is found,",Ot.createElement(nn,{clearable:!1,value:!!e.preferSourceCapacity,options:this.preferSourceCapacityOptions,onChange:this.preferSourceCapacityChanged})),e.preferSourceCapacity&&Ot.createElement("div",null,Ot.createElement("b",null,"Fallback values"),Ot.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged}))),Ot.createElement("div",{className:"col-md-9 col-md-offset-3 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:!e.useSourceCapacity,value:"false",id:"useSourceCapacityFalse",onChange:this.useSourceCapacityUpdated}),"Let me specify the capacity",Ot.createElement(n,{id:"serverGroupCapacity.useSourceCapacityFalse"})))),(!e.useSourceCapacity||"editPipeline"!==e.viewState.mode)&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-9 col-md-offset-3"},Ot.createElement(t,{command:e,fieldChanged:this.capacityFieldChanged})))):Ot.createElement("div",null,Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("p",null,"Sets the min, max, and desired instance counts to the same value."),Ot.createElement("p",null," ","To set capacity for auto-scaling, use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.setSimpleCapacity(!1)},"Advanced Mode"),"."))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Number of Instances"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(ve,{value:e.capacity.desired,min:0,onChange:this.simpleInstancesChanged}))))}}class Is extends Ot.Component{render(){const{command:{capacity:{min:e,max:t,desired:a}},fieldChanged:n}=this.props;return Ot.createElement("div",null,Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-2"},"Min"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(ve,{value:e,min:0,max:"number"==typeof t?t:void 0,onChange:e=>n("min",e),required:!0}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-2"},"Max"),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(ve,{value:t,min:"number"==typeof e?e:void 0,onChange:e=>n("max",e),required:!0}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-2"},"Desired"),Ot.createElement("div",{className:"col-md-8"},Ot.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 As extends Ot.Component{validate(e){const t={};(e.capacity.min<0||e.capacity.max<0||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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement(Gs,{command:t,setFieldValue:e,MinMaxDesired:Is}))),Ot.createElement("div",{className:"row"},Ot.createElement("div",{className:"col-md-12"},Ot.createElement("div",{className:"form-group form-inline",style:{marginTop:"20px"}},Ot.createElement("div",{className:"col-md-12"},"Consider deployment successful when"," ",Ot.createElement(dn,{type:"number",name:"targetHealthyDeployPercentage",min:"0",max:"100",className:"form-control input-sm inline-number",required:!0})," ","percent of instances are healthy.")))))}}function xs(e){return Ot.createElement("div",null,Ot.createElement("h4",{style:{marginTop:"10px"}},"This application is"),e.instanceProfileList.map((t=>Ot.createElement("div",{key:t.type,className:"instance-profile-header profile-button"},Ot.createElement("button",{type:"button",onClick:()=>e.handleProfileChange(t.type),className:e.currentProfile===t.type?"instance-profile active":"instance-profile"},e.currentProfile===t.type&&Ot.createElement("span",{className:"far fa-check-circle selected-indicator"}),Ot.createElement("div",{className:"panel-heading"},Ot.createElement("h4",null,Ot.createElement("span",{className:`glyphicon glyphicon-${t.icon}`}),Ot.createElement("div",null,t.label))))))))}function Ps(e){const{selectedInstanceTypes:t,currentProfile:a}=e,n=_n.awsInstanceTypeService.isBurstingSupportedForAllTypes(t),r=!!_n.awsInstanceTypeService.getInstanceTypesInCategory(t,a).length,[i,s]=Vt(!1);return Ut((()=>{t&&t.length&&(n||e.setUnlimitedCpuCredits(void 0),s(n)),a&&s(t&&t.length>0&&n&&r)}),[a,t]),Ot.createElement("div",{className:"row",style:{fontSize:"110%"}},i&&Ot.createElement("div",null,Ot.createElement(gt,{toggleSize:ht.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 Ds(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":"",G=`${null==(n=e.instanceType)?void 0:n.defaultVCpus} vCPU | ${null==(r=e.instanceType)?void 0:r.memoryInGiB} Gib Memory ${T}`,I=(null==(i=e.instanceType)?void 0:i.instanceStorageSupported)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.createElement("span",{className:"select-option-label-attributes"},`Instance Storage: ${qt.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)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.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)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.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)&&Ot.createElement("span",null,Ot.createElement("br",null),Ot.createElement("span",{className:"select-option-label-attributes"},(null==(k=e.instanceType)?void 0:k.currentGeneration)?"Current Generation":"Previous Generation"));return Ot.createElement("span",null,Ot.createElement("span",{className:"select-option-label"},null==(N=e.instanceType)?void 0:N.name),Ot.createElement("br",null),Ot.createElement("span",{className:"select-option-label-attributes"},G),I,A,x,P)}yr(".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 zs=({min:e,max:t})=>{const a=Ot.createElement(Ot.Fragment,null,Ot.createElement("span",{className:"cost"},"$".repeat(e)),"$".repeat(4-e)),n=Ot.createElement(Ot.Fragment,null,Ot.createElement("span",{className:"cost"},"$".repeat(Math.min(4,t))),"$".repeat(4-Math.min(4,t)));return Ot.createElement("span",{className:"cost-factor"},a,t?` - ${n}`:"")};function Bs(e){var t,a;const n=!!e.selectedType,[r,i]=Vt(""),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=Ot.createElement(Ds,{instanceType:e.selectedTypeInfo});u=Ot.createElement("tr",{key:s,className:"sortable clickable"},Ot.createElement("td",null,Ot.createElement(Fs,null)),Ot.createElement("td",null,`${s} `,Ot.createElement(ne,{placement:"right",template:a,className:"custom-profile"},Ot.createElement("span",{className:"clickable help-field"},Ot.createElement("i",{className:"small glyphicon glyphicon-info-sign"})))),Ot.createElement("td",{title:"Enter optional weight (allowed values: 1 to 999)."},Ot.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)})),Ot.createElement("td",null,Ot.createElement("div",null,Ot.createElement("span",null,Ot.createElement("a",{className:"btn btn-sm btn-link clickable",onClick:()=>e.removeInstanceType(s),style:{padding:"5px"}},Ot.createElement(_,{value:"Remove instance type"},Ot.createElement("span",{className:"glyphicon glyphicon-trash"})))))))}else{const{cpu:t,memory:i,cpuCreditsPerHour:p,storage:m,costFactor:g}=e.instanceTypeDetails;u=Ot.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?Ot.createElement("td",null,Ot.createElement(Fs,null)):Ot.createElement("td",null),Ot.createElement("td",null,Ot.createElement(Za,{id:`selectInstanceType-${s}`,checked:!!n,disabled:o,onChange:()=>{n?e.removeInstanceType(s):c(s,r)}})),Ot.createElement("td",null,s),Ot.createElement("td",null,t),Ot.createElement("td",null,i),p?Ot.createElement("td",null,p):Ot.createElement("td",{title:"Cpu credits not applicable to instance type."},"-"),"EBS"===m.type&&Ot.createElement("td",null,"EBS Only"),"SSD"===m.type&&Ot.createElement("td",null,m.count+"x"+m.size),Ot.createElement("td",null,Ot.createElement(zs,{min:g})),Ot.createElement("td",{title:o?"":"Enter optional weight (allowed values: 1 to 999)."},Ot.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 Fs=rn((()=>Ot.createElement(_,{value:"Drag to change priority"},Ot.createElement("span",{className:"instance-type-drag-handle glyphicon glyphicon-resize-vertical"}))));function Ms(e){return Ot.createElement($s,{isCustom:e.isCustom,selectedInstanceTypesMap:e.selectedInstanceTypesMap,selectedInstanceTypesInfo:e.selectedInstanceTypesInfo,removeInstanceType:e.removeInstanceType,addOrUpdateInstanceType:e.addOrUpdateInstanceType,instanceTypeDetails:e.isCustom?null:new Map(Object.entries(va(_t(e.profileFamiliesDetails.map((e=>e.instanceTypes))),"name"))),onSortEnd:t=>e.handleSortEnd(t),distance:1})}const $s=on((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)=>Ot.createElement(Ls,{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=sa(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)=>Ot.createElement(Ls,{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=>Ot.createElement(Bs,{key:a,isCustom:!1,instanceTypeDetails:t.get(a),addOrUpdateInstanceType:e.addOrUpdateInstanceType})))}return Ot.createElement("tbody",null,n,t?null:r)})),Ls=ln((e=>Ot.createElement(Bs,{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 Rs(e){return Ot.createElement("div",{className:"custom-profile"},Ot.createElement(nn,{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=>Ot.createElement(Ds,{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=qt.toLower(e.trim());return t.match(/\d+\s*vcpu/)&&n>=qt.toNumber(t.split("vcpu")[0].trim())||t.match(/\d+\s*gib/)&&r>=qt.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=>Ot.createElement(Ot.Fragment,null,e.name),onChange:t=>e.addOrUpdateInstanceType(t.name,void 0)})," ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypesSelect"}))}function Os(e){let t;return t=e.isCustom?Ot.createElement("p",null,"Choose the instance types that best suit the needs of your application."):Ot.createElement(Ot.Fragment,null,Ot.createElement("p",null,Ot.createElement("b",null,e.profileLabel)),Ot.createElement("ul",null,e.profileDescriptionArr.map(((e,t)=>Ot.createElement("li",{key:t},e))))),Ot.createElement("div",{className:"row sub-section"},Ot.createElement("h4",null,"Instance Types"),Ot.createElement("div",{className:"description"},t,Ot.createElement("p",null,"Learn about AWS recommended best practices in"," ",Ot.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"),"."),Ot.createElement("i",null,Ot.createElement("b",null,"Note:"),Ot.createElement("ul",null,Ot.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."),Ot.createElement("li",null,"Some instance types might not be available for the selected configuration.")))))}function Vs(e){let t,a,r,i;return e.isCustom?(t=Ot.createElement("th",null),a=Ot.createElement("th",null,"Instance Type ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypes"})),r=null,i=Ot.createElement("th",null)):(t=Ot.createElement(Ot.Fragment,null,Ot.createElement("th",null),Ot.createElement("th",null)),a=Ot.createElement("th",null,"InstanceType"),r=Ot.createElement(Ot.Fragment,null,Ot.createElement("th",null,"vCPU"),Ot.createElement("th",null,"Mem (GiB)"),e.showCpuCredits&&Ot.createElement("th",null,"CPU Credits"),Ot.createElement("th",null,"Storage (GB)",Ot.createElement(n,{id:"aws.serverGroup.storageType"})),Ot.createElement("th",null,"Cost")),i=null),Ot.createElement("thead",null,Ot.createElement("tr",null,t,a,r,Ot.createElement("th",null,"Weight ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})),i))}function Us(e){return e.isCustom?Ot.createElement("tfoot",null,Ot.createElement("tr",null,Ot.createElement("td",null,Ot.createElement("span",{className:"glyphicon glyphicon-plus-sign",style:{paddingTop:"8px"}})),Ot.createElement("td",{colSpan:2},Ot.createElement(Rs,{availableInstanceTypesList:e.availableInstanceTypesList,addOrUpdateInstanceType:e.addOrUpdateInstanceType})),Ot.createElement("td",null))):null}function qs(e){return e.dirty.instanceType||e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0?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"}),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:"),Ot.createElement("ul",null,e.dirty.instanceType&&Ot.createElement("li",{key:e.dirty.instanceType},e.dirty.instanceType),e.dirty.launchTemplateOverridesForInstanceType&&e.dirty.launchTemplateOverridesForInstanceType.length>0&&e.dirty.launchTemplateOverridesForInstanceType.map((e=>Ot.createElement("li",{key:e.instanceType},e.instanceType,e.weightedCapacity?" with weight "+e.weightedCapacity:"")))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>e.clearWarnings()},"Okay")))):null}function Hs(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=sn(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=Sn.serverGroups)?void 0:t.enableCpuCredits,c=Array.from(n.keys()),d=Ot.createElement("div",null,Ot.createElement(Ps,{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 Ot.createElement("div",{className:"row sub-section"},Ot.createElement(Os,{isCustom:u,profileLabel:t,profileDescriptionArr:a||i.map((e=>e.description))}),Ot.createElement(qs,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Ot.createElement("table",{className:"table table-hover"},Ot.createElement(Vs,{isCustom:u,showCpuCredits:c}),Ot.createElement(Ms,{isCustom:u,profileFamiliesDetails:i,selectedInstanceTypesMap:n,addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r})))}{const t=!0;return Ot.createElement("div",{className:"row sub-section"},Ot.createElement(Os,{isCustom:t}),Ot.createElement(qs,{dirty:e.viewState.dirty,clearWarnings:e.clearWarnings}),o&&d,Ot.createElement("table",{className:"table table-hover"},Ot.createElement(Vs,{isCustom:t}),Ot.createElement(Ms,{isCustom:t,selectedInstanceTypesMap:n,selectedInstanceTypesInfo:e.availableInstanceTypesList.filter((e=>c.includes(e.name))),addOrUpdateInstanceType:l,removeInstanceType:s,handleSortEnd:r}),Ot.createElement(Us,{isCustom:t,availableInstanceTypesList:e.availableInstanceTypesList.filter((e=>!c.includes(e.name))),addOrUpdateInstanceType:l})))}}function Ws(e,t,a){const n=ra(e.values,t);Ot.useEffect((()=>{void 0===n&&void 0!==a&&e.setFieldValue(t,a)}),[t,a,n])}function js(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 Ot.useEffect((()=>{"lowest-price"!==t.spotAllocationStrategy?a("spotInstancePools",void 0):void 0===t.spotInstancePools&&a("spotInstancePools",2)}),[t.spotAllocationStrategy]),Ws(e.formik,"spotAllocationStrategy","capacity-optimized"),Ws(e.formik,"onDemandAllocationStrategy","prioritized"),Ws(e.formik,"onDemandBaseCapacity",0),Ws(e.formik,"onDemandPercentageAboveBaseCapacity",100),Ot.createElement("div",{className:"InstancesDistribution row sub-section form-group"},Ot.createElement("h4",null,"Instances Distribution"),Ot.createElement("div",{className:"description"},"Diversify and distribute instance types across purchase options."," ",Ot.createElement(n,{id:"aws.serverGroup.instancesDistribution"})),Ot.createElement("br",null),Ot.createElement(s,{label:"Spot Allocation Strategy",name:"spotAllocationStrategy",help:Ot.createElement(n,{id:"aws.serverGroup.spotAllocationStrategy"}),input:e=>Ot.createElement(c,{...e,mode:"PLAIN",options:r})}),"lowest-price"===e.formik.values.spotAllocationStrategy&&Ot.createElement(s,{label:"Spot Instance Pools Count",name:"spotInstancePools",help:Ot.createElement(n,{id:"aws.serverGroup.spotInstancePoolCount"}),input:e=>Ot.createElement(p,{...e})}),Ot.createElement(s,{label:"On-Demand Allocation Strategy",name:"onDemandAllocationStrategy",help:Ot.createElement(n,{id:"aws.serverGroup.odAllocationStrategy"}),input:e=>Ot.createElement(l,{...e,disabled:!0})}),Ot.createElement(s,{label:"On-Demand Base Capacity",name:"onDemandBaseCapacity",help:Ot.createElement(n,{id:"aws.serverGroup.odBase"}),input:e=>Ot.createElement(p,{...e})}),Ot.createElement(s,{label:"On-Demand Percentage Above Base Capacity",name:"onDemandPercentageAboveBaseCapacity",help:Ot.createElement(n,{id:"aws.serverGroup.odPercentAboveBase"}),input:e=>Ot.createElement(p,{...e})}),Ot.createElement(s,{label:"Spot Max Price",name:"spotPrice",help:Ot.createElement(n,{id:"aws.serverGroup.spotMaxPrice"}),input:e=>Ot.createElement(_,{value:"Recommended to leave empty and use AWS default i.e. On-Demand price"},Ot.createElement(l,{...e,placeholder:"Recommended to leave empty and use AWS default i.e. On-Demand price"}))}))}function Zs(e){const{instanceTypeDetails:t,setUnlimitedCpuCredits:a}=e,{values:n,setFieldValue:r}=e.formik,{instanceType:i,launchTemplateOverridesForInstanceType:s}=n;Ut((()=>{!s&&i&&e.formik.setFieldValue("launchTemplateOverridesForInstanceType",[{instanceType:n.instanceType,priority:1}])}));const l=n.launchTemplateOverridesForInstanceType?n.launchTemplateOverridesForInstanceType:void 0,o=new Map(Object.entries(va(l,"instanceType"))),[c,d]=Vt(n.viewState.instanceProfile||"custom"),u=ft(c);return t&&t.length>0?Ot.createElement("div",{className:"advanced-mode-selector"},Ot.createElement(xs,{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=_n.awsInstanceTypeService.getInstanceTypesInCategory(l.map((e=>e.instanceType)),e),a=l.filter((e=>t.includes(e.instanceType)));r("launchTemplateOverridesForInstanceType",a),n.launchTemplateOverridesChanged(n)}},instanceProfileList:t}),Ot.createElement(js,{formik:e.formik}),Ot.createElement(Hs,{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 _s(e){var t,a;const{command:n}=e,{InstanceArchetypeSelector:r,InstanceTypeSelector:i}=vt,s=null==(t=Sn.serverGroups)?void 0:t.enableLaunchTemplates,l=null==(a=Sn.serverGroups)?void 0:a.enableCpuCredits,o=t=>{n.instanceTypeChanged(n),e.setFieldValue("instanceType",t)};return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"row"},Ot.createElement(r,{command:n,onTypeChanged:o,onProfileChanged:t=>{e.setFieldValue("viewState",{...n.viewState,instanceProfile:t})}}),Ot.createElement(qs,{dirty:n.viewState.dirty,clearWarnings:e.clearWarnings}),Ot.createElement("div",{style:{padding:"0 15px"}},n.viewState.instanceProfile&&"custom"!==n.viewState.instanceProfile&&Ot.createElement(i,{command:n,onTypeChanged:o}))),s&&l&&Ot.createElement("div",{className:"row"},Ot.createElement(Ps,{unlimitedCpuCredits:n.unlimitedCpuCredits,selectedInstanceTypes:[n.instanceType],currentProfile:n.viewState.instanceProfile,setUnlimitedCpuCredits:e.setUnlimitedCpuCredits})))}function Ks(e){var t;const{instanceTypeDetails:a}=e,{values:r,setFieldValue:i}=e.formik,s=null==(t=Sn.serverGroups)?void 0:t.enableLaunchTemplates,l=r.viewState.useSimpleInstanceTypeSelector,[o,c]=Vt(r.unlimitedCpuCredits);Ut((()=>{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?Ot.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Ot.createElement("div",null,Ot.createElement("p",null,"Switch to",Ot.createElement("a",{className:"clickable",onClick:()=>u(!0)},Ot.createElement("span",null," Simple Mode")),"."),Ot.createElement("i",null,Ot.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.")),Ot.createElement(Zs,{formik:e.formik,instanceTypeDetails:a,setUnlimitedCpuCredits:c,clearWarnings:d})):Ot.createElement("div",{className:"container-fluid form-horizontal",style:{padding:"0 15px"}},Ot.createElement("div",null,Ot.createElement("span",null,"To configure mixed server groups and/or multiple instance types,"),!s&&Ot.createElement("span",null,Ot.createElement("a",{href:"https://spinnaker.io/docs/setup/other_config/server-group-launch-settings/aws-ec2/launch-templates-setup/"},Ot.createElement("span",null," enable launch templates")),Ot.createElement("span",null," and")),Ot.createElement("span",null,Ot.createElement("a",{className:s?"clickable":"disabled",onClick:s?()=>u(!1):()=>{}},Ot.createElement("span",null," use Advanced Mode ")),Ot.createElement(n,{id:"aws.serverGroup.advancedMode"}),"."),Ot.createElement("p",null),s&&Ot.createElement("i",null,Ot.createElement("b",null,"Note:")," If an instance type is already selected in simple mode, it will be preserved in advanced mode.")),Ot.createElement(_s,{command:r,setUnlimitedCpuCredits:c,setFieldValue:i,clearWarnings:d}))}yr(".InstancesDistribution .StandardFieldLayout_Label {\n min-width: 300px;\n}\n");class Ys extends Ot.Component{constructor(){super(...arguments),this.state={instanceTypeDetails:[]},this.props$=new Na,this.destroy$=new Na}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."),la(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>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(_n.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?Ot.createElement(Ks,{formik:this.props.formik,instanceTypeDetails:s}):Ot.createElement("h5",{className:"text-center"},"Please select an image.")}}class Xs extends Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement(_r,{credentials:e.credentials,region:e.region,onChange:this.handleAvailabilityZonesChanged,selectedZones:e.availabilityZones,allZones:e.backingData.filtered.availabilityZones,usePreferredZones:e.viewState.usePreferredZones}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("b",null,"AZ Rebalance")),Ot.createElement("div",{className:"col-md-7 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",onChange:this.rebalanceToggled,checked:!e.processIsSuspended(e,"AZRebalance")}),"Keep instances evenly distributed across zones"))))}}const Js=e=>({value:e,label:e});class Qs extends Ot.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(Js);c=Ot.createElement(Ot.Fragment,null,i.targetGroups&&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"}),"The following target groups could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,i.targetGroups.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("targetGroups")},"Okay")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Target Groups "),Ot.createElement(n,{id:"aws.loadBalancer.targetGroups"})),Ot.createElement("div",{className:"col-md-7"},0===t.length&&Ot.createElement("div",{className:"form-control-static"},"No ",Ot.createElement("b",null,null!=(e=this.props.targetGroupTypeHelpText)?e:"instance")," target groups found in the selected account/region/VPC"),t.length>0&&Ot.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(Js),t=(r.backingData.filtered.vpcLoadBalancers||[]).map(Js),a=r.vpcLoadBalancers&&r.vpcLoadBalancers.length>0;d=Ot.createElement(Ot.Fragment,null,i.loadBalancers&&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"}),"The following load balancers could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,i.loadBalancers.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:()=>this.clearWarnings("loadBalancers")},"Okay")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"Classic Load Balancers "),Ot.createElement(n,{id:"aws.loadBalancer.loadBalancers"})),Ot.createElement("div",{className:"col-md-7"},0===e.length&&Ot.createElement("div",{className:"form-control-static"},"No load balancers found in the selected account/region/VPC"),e.length>0&&Ot.createElement(f,{multi:!0,options:e,value:r.loadBalancers,onChange:this.loadBalancersChanged}))),!r.vpcId&&Ot.createElement("div",{className:"form-group"},!a&&!o&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-8 col-md-offset-3"},Ot.createElement("a",{className:"clickable",onClick:()=>this.setState({showVpcLoadBalancers:!0})},"Add VPC Load Balancers"))),a&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-4 sm-label-right"},Ot.createElement("b",null,"VPC Load Balancers")),Ot.createElement("div",{className:"col-md-8"},t.length>0&&Ot.createElement(f,{multi:!0,options:t,value:r.vpcLoadBalancers,onChange:this.vpcLoadBalancersChanged})))),!s&&Ot.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Ot.createElement("div",{className:"col-md-8 col-md-offset-4"},l&&Ot.createElement("p",null,Ot.createElement("span",{className:"fa fa-sync-alt fa-spin"}),Ot.createElement("span",null," refreshing...")),!l&&Ot.createElement("p",null,"If you are looking for a load balancer or target group from a different application, ",Ot.createElement("br",null),Ot.createElement("a",{className:"clickable",onClick:this.refreshLoadBalancers},"click here")," ","to load all load balancers."))))}return Ot.createElement("div",{className:"container-fluid form-horizontal"},c,d)}}class el extends Ot.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 Ot.createElement(Ot.Fragment,null,Ot.createElement("div",{className:"form-group"},!r&&Ot.createElement("div",{className:"col-md-3 sm-label-right"},Ot.createElement("b",null,U.get("Firewalls")),a&&Ot.createElement(n,{key:a})),Ot.createElement("div",{className:"col-md-8"},Ot.createElement(un,{ignoreAccents:!0,options:l,onChange:this.onChange,value:t,multi:!0}))),Ot.createElement("div",{className:"form-group small",style:{marginTop:"20px"}},Ot.createElement("div",{className:`col-md-${r?12:9} col-md-offset-${r?0:3}`},Ot.createElement("p",null,i&&Ot.createElement("span",null,Ot.createElement("span",{className:"fa fa-sync-alt fa-spin"})),U.get("Firewalls"),!i&&Ot.createElement("span",null," last refreshed ",B(s)),i&&Ot.createElement("span",null," refreshing...")),Ot.createElement("p",null,"If you're not finding a ",U.get("firewall")," that was recently added,"," ",Ot.createElement("a",{className:"clickable",onClick:this.refreshSecurityGroups},"click here")," ","to refresh the list."))))}}class tl extends Ot.Component{render(){const{command:e,onClear:t,removed:a}=this.props,n=(e&&e.viewState.dirty.securityGroups||[]).concat(a||[]);return 0===n.length?null: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"}),"The following ",U.get("firewalls")," could not be found in the selected account/region/VPC and were removed:"),Ot.createElement("ul",null,n.map((e=>Ot.createElement("li",{key:e},e)))),Ot.createElement("p",{className:"text-right"},Ot.createElement("a",{className:"btn btn-sm btn-default dirty-flag-dismiss clickable",onClick:t},"Okay"))))}}tl.defaultProps={onClear:C};class al extends Ot.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 Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement(tl,{command:e,onClear:this.acknowledgeRemovedGroups}),Ot.createElement(el,{command:e,availableGroups:e.backingData.filtered.securityGroups,groupsToEdit:e.securityGroups,onChange:this.onChange}))}}class nl extends Ot.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=Sn.serverGroups;return Ot.createElement("div",{className:"container-fluid form-horizontal"},Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Cooldown")),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(dn,{type:"text",required:!0,name:"cooldown",className:"form-control input-sm no-spel"}))," ","seconds"),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Enabled Metrics "),Ot.createElement(n,{id:"aws.serverGroup.enabledMetrics"})),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{multi:!0,value:a.enabledMetrics,options:a.backingData.enabledMetrics.map((e=>({label:e,value:e}))),onChange:e=>t("enabledMetrics",e.map((e=>e.value)))}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Health Check Type")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{value:a.healthCheckType,clearable:!1,placeholder:"Select...",options:a.backingData.healthCheckTypes.map((e=>({label:e,value:e}))),onChange:e=>t("healthCheckType",e.value)}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Health Check Grace Period")),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(dn,{type:"text",required:!0,className:"form-control input-sm no-spel",name:"healthCheckGracePeriod"}))," ","seconds"),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Termination Policies")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{multi:!0,value:a.terminationPolicies,options:a.backingData.terminationPolicies.map((e=>({label:e,value:e}))),onChange:e=>t("terminationPolicies",e.map((e=>e.value)))}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Key Name")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(nn,{value:a.keyPair,required:!0,clearable:!1,options:i.map((e=>({label:e,value:e}))),onChange:e=>t("keyPair",e.value)}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Ramdisk Id (optional)")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(dn,{type:"text",name:"ramdiskId",className:"form-control input-sm no-spel"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"IAM Instance Profile (optional)")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(dn,{type:"text",className:"form-control input-sm no-spel",name:"iamRole"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"UserData (optional) "),Ot.createElement(n,{id:"aws.serverGroup.base64UserData"})),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(dn,{type:"text",className:"form-control input-sm no-spel",name:"base64UserData"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Instance Monitoring "),Ot.createElement(n,{id:"aws.serverGroup.instanceMonitoring"})),Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:a.instanceMonitoring,onChange:e=>t("instanceMonitoring",e.target.checked)})," ","Enforce Instance Monitoring"," "))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"EBS Optimized")),Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:a.ebsOptimized,onChange:e=>t("ebsOptimized",e.target.checked)})," ","Optimize Instances for EBS"))),(null==s?void 0:s.enableIMDSv2)&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"IMDSv2 "),Ot.createElement(n,{id:"aws.serverGroup.imdsv2"})),Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",checked:!0===a.requireIMDSv2,onChange:e=>t("requireIMDSv2",e.target.checked)})," ","Require IMDSv2"," "))),!Sn.disableSpotPricing&&a.viewState.useSimpleInstanceTypeSelector&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Spot Instances Price (optional)")," ",Ot.createElement(n,{id:"aws.serverGroup.spotMaxPrice"})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(dn,{type:"text",className:"form-control input-sm",name:"spotPrice"}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"AMI Block Device Mappings")),Ot.createElement("div",{className:"col-md-6 radio"},Ot.createElement("div",null,Ot.createElement("label",null,Ot.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("source"),checked:"source"===r,name:"blockDeviceMappingsSource"}),"Copy from current server group ",Ot.createElement(n,{id:"aws.blockDeviceMappings.useSource"}))),Ot.createElement("div",null,Ot.createElement("label",null,Ot.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("ami"),checked:"ami"===r,name:"blockDeviceMappingsSource"}),"Prefer AMI block device mappings ",Ot.createElement(n,{id:"aws.blockDeviceMappings.useAMI"}))),Ot.createElement("div",null,Ot.createElement("label",null,Ot.createElement("input",{type:"radio",onChange:()=>this.selectBlockDeviceMappingsSource("default"),checked:"default"===r,name:"blockDeviceMappingsSource"}),"Defaults for selected instance type ",Ot.createElement(n,{id:"aws.blockDeviceMappings.useDefaults"}))))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,`Associate ${(null==s?void 0:s.enableIPv6)?"IPv6 (Recommended)":"Public IPv4"} Address`),Ot.createElement(n,{id:"serverGroup.ipv6"})),(null==s?void 0:s.enableIPv6)&&Ot.createElement("div",{className:"col-md-6 checkbox"},Ot.createElement("label",null,Ot.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)&&Ot.createElement("div",null,Ot.createElement("div",{className:"col-md-2 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:!0===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!0),id:"associatePublicIpAddressTrue"}),"Yes")),Ot.createElement("div",{className:"col-md-2 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:!1===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",!1),id:"associatePublicIpAddressFalse"}),"No")),Ot.createElement("div",{className:"col-md-2 radio"},Ot.createElement("label",null,Ot.createElement("input",{type:"radio",checked:null===a.associatePublicIpAddress,onChange:()=>t("associatePublicIpAddress",null),id:"associatePublicIpAddressDefault"}),"Default")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Scaling Processes")),Ot.createElement("div",{className:"col-md-6 checkbox"},a.backingData.scalingProcesses.map((e=>Ot.createElement("div",{key:e.name},Ot.createElement("label",null,Ot.createElement("input",{type:"checkbox",onChange:()=>this.toggleSuspendedProcess(e.name),checked:!a.suspendedProcesses.includes(e.name)})," ",e.name," ",Ot.createElement(n,{content:e.description}))))))),e.attributes.platformHealthOnlyShowOverride&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-5 sm-label-right"},Ot.createElement("b",null,"Task Completion")),Ot.createElement("div",{className:"col-md-6"},Ot.createElement(yt,{interestingHealthProviderNames:a.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"sm-label-left"},Ot.createElement("b",null,"Tags (optional)"),Ot.createElement(n,{id:"aws.serverGroup.tags"})),Ot.createElement(bt,{model:a.tags,allowEmpty:!0,onChange:this.tagsChanged})))}}var rl=Object.defineProperty,il=Object.getOwnPropertyDescriptor;let sl=class extends Ot.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 Ot.createElement(nl,{formik:e,app:t,ref:this.handleRef})}};sl=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?il(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&&rl(t,a,i),i})([ie("aws.serverGroup.advancedSettings")],sl);class ll extends Ot.Component{constructor(){super(...arguments),this.ref=Ot.createRef()}validate(e){return this.ref&&this.ref.current?this.ref.current.validate(e):{}}render(){const{app:e,formik:t}=this.props;return Ot.createElement(sl,{formik:t,app:e,ref:this.ref})}}const ol=class extends Ot.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),_n.awsServerGroupConfigurationService.configureSubnetPurposes(e)},this.configureCommand=()=>{const{application:e,command:t}=this.props;_n.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=ra(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(ol,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?Ot.createElement(Ss,{app:e,command:t,onDismiss:a,onTemplateSelected:this.templateSelected}):Ot.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})=>Ot.createElement(Ot.Fragment,null,Ot.createElement(w,{label:"Basic Settings",wizard:r,order:n(),render:({innerRef:t})=>Ot.createElement(Ts,{ref:t,formik:a,app:e})}),Ot.createElement(w,{label:"Load Balancers",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(Qs,{ref:e,formik:a})}),Ot.createElement(w,{label:U.get("Firewalls"),wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(al,{ref:e,formik:a})}),Ot.createElement(w,{label:t.viewState.useSimpleInstanceTypeSelector?"Instance Type":"Instance Types",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(Ys,{ref:e,formik:a})}),Ot.createElement(w,{label:"Capacity",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(As,{ref:e,formik:a})}),Ot.createElement(w,{label:"Availability Zones",wizard:r,order:n(),render:({innerRef:e})=>Ot.createElement(Xs,{ref:e,formik:a})}),Ot.createElement(w,{label:"Advanced Settings",wizard:r,order:n(),render:({innerRef:t})=>Ot.createElement(ll,{ref:t,formik:a,app:e})}))})}};let cl=ol;cl.defaultProps={closeModal:C,dismissModal:C};class dl extends Ot.Component{constructor(){super(...arguments),this.state={verified:!1,requireVerification:!1},this.handleVerification=e=>{this.setState({verified:e})}}componentDidMount(){o.accounts$.pipe(Va(1),Pa((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 Ot.createElement(_a,null,Ot.createElement("form",{onSubmit:()=>(this.props.onSubmit(),!1)},i&&Ot.createElement(Et,{expectedValue:e,onValidChange:this.handleVerification})),Ot.createElement("button",{className:"btn btn-default",onClick:t},"Cancel"),Ot.createElement("button",{type:"submit",className:"btn btn-primary",onClick:a,disabled:!n||i&&!r},"Submit"))}}dl.defaultProps={isValid:!0};const ul=class extends Ot.Component{constructor(e){super(e),this.formikRef=Ot.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:aa({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(ul,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 Ot.createElement("div",null,Ot.createElement("p",null,"Sets min, max, and desired instance counts to the same value."),Ot.createElement("p",null,"To allow autoscaling, use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Current size"),Ot.createElement("div",{className:"col-md-4"},Ot.createElement("div",{className:"horizontal middle"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:a.desiredCapacity,disabled:!0}),Ot.createElement("div",{className:"sp-padding-xs-xaxis"},"instances")))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Ot.createElement("div",{className:"col-md-4"},Ot.createElement("div",{className:"horizontal middle"},Ot.createElement(s,{name:"desired",input:e=>Ot.createElement(p,{...e,min:0}),touched:!0,onChange:t=>{e.setFieldValue("min",t),e.setFieldValue("max",t)}}),Ot.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 Ot.createElement("div",null,Ot.createElement("p",null,"Sets up autoscaling for this server group."),Ot.createElement("p",null,"To disable autoscaling, use the"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Simple Mode"),"."),Ot.createElement("div",{className:"form-group bold"},Ot.createElement("div",{className:"col-md-2 col-md-offset-3"},"Min"),Ot.createElement("div",{className:"col-md-2"},"Max"),Ot.createElement("div",{className:"col-md-2"},"Desired")),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Current"),Ot.createElement("div",{className:"col-md-2"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:n.minSize,disabled:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:n.maxSize,disabled:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement("input",{type:"number",className:"NumberInput form-control",value:n.desiredCapacity,disabled:!0}))),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Resize to"),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(s,{name:"min",input:e=>Ot.createElement(p,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Ot.createElement(Ot.Fragment,null,e),touched:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(s,{name:"max",input:e=>Ot.createElement(p,{...e,min:0}),onChange:()=>this.autoIncrementDesiredIfNeeded(),layout:({input:e})=>Ot.createElement(Ot.Fragment,null,e),touched:!0})),Ot.createElement("div",{className:"col-md-2"},Ot.createElement(s,{name:"desired",input:e=>Ot.createElement(p,{...e,min:0,disabled:this.isDesiredControlledByAutoscaling()}),layout:({input:e})=>Ot.createElement(Ot.Fragment,null,e),touched:!0}))),!!r&&Ot.createElement("div",{className:"col-md-offset-3 col-md-9"},Ot.createElement(pe,{message:r,type:"error"})))}renderCapacityConstraintSelector(){return Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement(s,{name:"enforceCapacityConstraints",input:e=>Ot.createElement(Ot.Fragment,null,Ot.createElement(d,{...e,text:"Enforce Capacity Constraints"}),Ot.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?Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-7 col-md-offset-3"},Ot.createElement("div",{className:"well-compact alert alert-warning"},Ot.createElement("b",null,"Warning"),": this server group has",1===i.length&&Ot.createElement("span",null," a scaling policy. "),i.length>1&&Ot.createElement("span",null," scaling policies. "),!r&&Ot.createElement("span",null,"Scaling policies will not take effect in Simple Mode. Switch to"," ",Ot.createElement("a",{className:"clickable",onClick:()=>this.toggleAdvancedMode()},"Advanced Mode"),"."),r&&Ot.createElement("span",null,"Scaling policies will not take effect when ",Ot.createElement("b",null,"Min")," is the same as ",Ot.createElement("b",null,"Max"),".")))):this.isDesiredControlledByAutoscaling()?Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-8 col-md-offset-1"},Ot.createElement("div",{className:"well-compact alert alert-warning"},Ot.createElement("p",null,Ot.createElement("b",null,"Desired")," capacity is managed by Autoscaling Policies."),Ot.createElement("p",null,"If you need to scale ",Ot.createElement("b",null,"down")," this server group, set ",Ot.createElement("b",null,"Max")," to the new desired size."),Ot.createElement("p",null,"If you need to scale ",Ot.createElement("b",null,"up")," this server group, set ",Ot.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 Ot.createElement(Ot.Fragment,null,Ot.createElement(wt,{monitor:this.state.taskMonitor}),Ot.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 Ot.createElement(Ot.Fragment,null,Ot.createElement(oe,{dismiss:this.close}),Ot.createElement(qa.Header,null,Ot.createElement(qa.Title,null,"Resize ",e.name)),Ot.createElement(qa.Body,null,Ot.createElement(cn,{className:"form-horizontal"},t&&this.renderAdvancedMode(a),!t&&this.renderSimpleMode(a),this.renderScalingPolicyWarning(a),this.renderCapacityConstraintSelector(),n&&Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-8 col-md-offset-3"},Ot.createElement(yt,{interestingHealthProviderNames:this.state.interestingHealthProviderNames,platformHealthType:"Amazon",onChange:this.platformHealthOverrideChanged,showHelpDetails:!0}))),Ot.createElement(mt,{reason:a.values.reason,onChange:e=>a.setFieldValue("reason",e)}),Ot.createElement("div",{className:"form-group"},Ot.createElement("div",{className:"col-md-3 sm-label-right"},"Changes"),Ot.createElement("div",{className:"col-md-9 sm-control-field"},Ot.createElement(Ct,{current:i,next:s}))))),Ot.createElement(dl,{onSubmit:()=>this.submit(a.values),onCancel:this.close,isValid:a.isValid,account:e.account}))}}))}};let pl=ul;pl.defaultProps={closeModal:C,dismissModal:C};var ml=Object.defineProperty,gl=Object.getOwnPropertyDescriptor;let hl=class extends Ot.Component{constructor(){super(...arguments),this.resizeServerGroup=()=>{pl.show(this.props)}}render(){return Ot.createElement(Ka,{onClick:this.resizeServerGroup},"Resize")}};hl=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?gl(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&&ml(t,a,i),i})([ie("AmazonServerGroupActions.resize")],hl);class fl extends Ot.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"};St.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};St.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=Yt(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]),kt.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=ya(e.clusters,{name:a.cluster,account:a.account,serverGroups:[]});return Qt(t.serverGroups,{isDisabled:!0,region:a.region})},allServerGroups:()=>n,application:()=>e}})},this.cloneServerGroup=()=>{const{app:e,serverGroup:t}=this.props;_n.awsServerGroupCommandBuilder.buildServerGroupCommandFromExisting(e,t).then((a=>{const n=`Clone ${t.name}`;cl.show({title:n,application:e,command:a})}))}}isEnableLocked(){if(this.props.serverGroup.isDisabled){if((this.props.serverGroup.runningTasks||[]).filter((e=>ra(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||ra(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=Nt.buildClusterTargets(t);return Ot.createElement(Ot.Fragment,null,Sn.adHocInfraWritesEnabled&&Ot.createElement(Ua,{className:"dropdown",id:"server-group-actions-dropdown"},Ot.createElement(Ua.Toggle,{className:"btn btn-sm btn-primary dropdown-toggle"},"Server Group Actions"),Ot.createElement(Ua.Menu,{className:"dropdown-menu"},this.isRollbackEnabled()&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.rollbackServerGroup},"Rollback"),this.isRollbackEnabled()&&Ot.createElement("li",{role:"presentation",className:"divider"}),Ot.createElement(hl,{application:e,serverGroup:t}),!t.isDisabled&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.disableServerGroup},"Disable"),this.hasDisabledInstances()&&!this.isEnableLocked()&&Ot.createElement(Ge,{resource:t,application:e,onClick:this.enableServerGroup},"Enable"),this.isEnableLocked()&&Ot.createElement("li",{className:"disabled"},Ot.createElement(Wa,{value:"Cannot enable this server group until resize operation completes",placement:"left"},Ot.createElement("a",null,Ot.createElement("span",{className:"small glyphicon glyphicon-lock"})," Enable"))),Ot.createElement(Ge,{resource:t,application:e,onClick:this.destroyServerGroup},"Destroy"),Ot.createElement("li",null,Ot.createElement("a",{className:"clickable",onClick:this.cloneServerGroup},"Clone")),n&&Ot.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 vl{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 yl(e,t){const{app:a,serverGroup:n}=e;return new xa((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=>{Tt.getServerGroup(a.name,n.accountId,n.region,n.name).then((a=>{Object.assign(a,e,{account:n.accountId});const i=_n.awsServerGroupTransformer.normalizeServerGroupDetails(a);if(o.getAccountDetails(i.account).then((e=>{i.accountDetails=e,r.next(i)})),Ht(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=vl.getDisabledDate(i),r.next(i)}}),t)}),t)}))}function bl(e){const t=Rt.useRef(),a=Rt.useRef(),{lines:n,className:r="",style:i={}}=e;return Rt.useEffect((()=>{return t?(a.current=(e=t.current,new pn(e,{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}}}})),()=>{var e;return null==(e=a.current)?void 0:e.destroy()}):null;var e}),[t.current]),Rt.useEffect((()=>{const e=a.current;e&&n&&(e.options.animation=!1,e.data.datasets=n,e.update())}),[a.current,n]),Rt.createElement("canvas",{ref:t,...i,className:r})}function El(e){return e.serverGroup&&e.alarm?Rt.createElement(wl,{...e}):null}function wl(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]);if("PENDING"===m)return Rt.createElement("div",{className:"flex-container-v middle center sp-margin-xl"},Rt.createElement(ae,null));if("REJECTED"===m)return Rt.createElement(Rt.Fragment,null,Rt.createElement("div",null,"no data"),Rt.createElement("div",null,"something went wrong fetching stats"));if(0===g.datapoints.length)return Rt.createElement(Rt.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:e.average})))},y={label:"threshold",borderWidth:1,borderColor:"red",data:[{x:f,y:n.threshold},{x:h,y:n.threshold}]};return Rt.createElement(bl,{lines:[v,y]})}pn.register(mn,gn,hn,fn,vn,yn,bn,En,wn);const Cl={ASGAverageCPUUtilization:"CPUUtilization",ASGAverageNetworkIn:"NetworkIn",ASGAverageNetworkOut:"NetworkOut"},Sl=({config:e,serverGroup:t,updateUnit:a})=>{const[n,r]=Rt.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});Rt.useEffect((()=>{(()=>{var a;const i=null==e?void 0:e.customizedMetricSpecification,s={...n,dimensions:(null==i?void 0:i.dimensions)||[{name:"AutoScalingGroupName",value:t.name}],metricName:(null==i?void 0:i.metricName)||Cl[null==(a=null==e?void 0:e.predefinedMetricSpecification)?void 0:a.predefinedMetricType],namespace:(null==i?void 0:i.namespace)||"AWS/EC2",threshold:null==e?void 0:e.targetValue};i&&(s.statistic=null==i?void 0:i.statistic),r(s)})()}),[e]);return Rt.createElement(El,{alarm:n,onChartLoaded:e=>{a&&a(e.unit)},serverGroup:t})};yr("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 kl=({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=ba(e,(e=>e.dimensions));return ia(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 Rt.createElement("div",null,Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-12 small"},Rt.createElement("h5",null,"Dimensions"))),n.map(((t,n)=>Rt.createElement("div",{key:`dimension-${n}`,className:"row dimensions-row horizontal middle"},Rt.createElement("div",{className:"col-md-6"},Rt.createElement(c,{onChange:e=>i("name",e.target.value,n),value:t.name,stringOptions:r})),Rt.createElement(l,{onChange:e=>i("value",e.target.value,n),value:t.value}),!e.disableEditingDimensions&&Rt.createElement("div",{className:"col-md-1",onClick:()=>(t=>{const n=e.dimensions.filter(((e,a)=>a!==t));a(n)})(n)},Rt.createElement("a",null,Rt.createElement("i",{className:"glyphicon glyphicon-trash clickable"})))))),!e.disableEditingDimensions&&Rt.createElement("div",{className:"row"},Rt.createElement("div",null,Rt.createElement("button",{type:"button",className:"btn btn-block btn-xs add-new",onClick:()=>{const e=[...n,{}];a(e)}},Rt.createElement("span",{className:"glyphicon glyphicon-plus-sign sp-margin-xs-left"}),"Add dimension"))))},Nl=["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"];yr(".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 Tl=({alarm:e,updateAlarm:t,serverGroup:a})=>{var r,i;const s=((null==(i=null==(r=Sn)?void 0:r.metrics)?void 0:i.customNamespaces)||[]).concat(Nl),[l,o]=Rt.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 Rt.useEffect((()=>{m&&v(m)}),[m]),l?Rt.createElement("div",{className:"MetricSelector"},Rt.createElement("div",{className:"horizontal middle"},Rt.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"}),Rt.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"})),Rt.createElement("div",{className:"vertical"},!Boolean(u.length)&&Rt.createElement("span",{className:"input-label"},Rt.createElement("b",null,"Note:")," no metrics found for selected namespace + dimensions"),Rt.createElement("a",{className:"clickable",onClick:f},Rt.createElement("span",{className:"sp-margin-s-yaxis sp-margin-xs-right"},"Only show metrics for this auto scaling group"),Rt.createElement(n,{id:"aws.scalingPolicy.search.restricted"}))),Rt.createElement(kl,{alarm:e,serverGroup:a,updateAvailableMetrics:a=>{const n={...e,dimensions:a};t(n)}})):Rt.createElement("div",{className:"MetricSelector horizontal middle"},Rt.createElement(c,{value:m,onChange:e=>v(e.target.value),options:u,clearable:!1,inputClassName:"sp-margin-s-right simple-input"}),Rt.createElement("a",{className:"clickable",onClick:f},Rt.createElement("span",{className:"sp-margin-xs-right"},"Search all metrics"),Rt.createElement(n,{id:"aws.scalingPolicy.search.all"})))};yr(".TargetMetricFields .metric-select-input {\n font-size: 12px;\n width: 180px;\n}\n.TargetMetricFields .target-input {\n width: 120px;\n}\n");const Gl=({allowDualMode:e,cloudwatch:t,command:a,isCustomMetric:n,serverGroup:r,toggleMetricType:i,updateCommand:s})=>{var l,o;const[d,u]=Rt.useState(null),m=(e,t)=>{const n=Zt(a);ca(n,e,t),s(n)};return Rt.createElement("div",{className:"TargetMetricFields sp-margin-l-xaxis"},Rt.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&&Rt.createElement("p",null,Rt.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.'),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Metric"),Rt.createElement("div",{className:"col-md-10 content-fields"},!n&&Rt.createElement(c,{value:null==(l=a.targetTrackingConfiguration.predefinedMetricSpecification)?void 0:l.predefinedMetricType,stringOptions:["ASGAverageCPUUtilization","ASGAverageNetworkOut","ASGAverageNetworkIn"],onChange:e=>m("targetTrackingConfiguration.predefinedMetricSpecification.predefinedMetricType",e.target.value),inputClassName:"metric-select-input"}),n&&Rt.createElement(Tl,{alarm:a.targetTrackingConfiguration.customizedMetricSpecification,serverGroup:r,updateAlarm:e=>{m("targetTrackingConfiguration.customizedMetricSpecification",e)}}),e&&Rt.createElement("a",{className:"clickable",onClick:()=>{const e=Zt(a);n?(ca(e,"targetTrackingConfiguration.predefinedMetricSpecification",{predefinedMetricType:"ASGAverageCPUUtilization"}),ca(e,"targetTrackingConfiguration.customizedMetricSpecification",null)):(ca(e,"targetTrackingConfiguration.predefinedMetricSpecification",null),ca(e,"targetTrackingConfiguration.customizedMetricSpecification",{metricName:"CPUUtilization",namespace:"AWS/EC2",dimensions:[{name:"AutoScalingGroupName",value:r.name}],statistic:"Average"})),s(e),i(n?"predefined":"custom")}},n?"Use a predefined metric":"Select a custom metric"))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Target"),Rt.createElement("div",{className:"col-md-10 content-fields horizontal"},n&&Rt.createElement("div",{className:"horizontal middle"},Rt.createElement(c,{value:null==(o=a.targetTrackingConfiguration.customizedMetricSpecification)?void 0:o.statistic,stringOptions:["Average","Maximum","Minimum","SampleCount","Sum"],onChange:e=>m("targetTrackingConfiguration.customizedMetricSpecification.statistic",e.target.value),inputClassName:"form-control input-sm target-input"}),Rt.createElement("span",{className:"sp-margin-xs-xaxis"},"of")),Rt.createElement("div",{className:"horizontal middle"},Rt.createElement(p,{value:a.targetTrackingConfiguration.targetValue,onChange:e=>m("targetTrackingConfiguration.targetValue",Number.parseInt(e.target.value)),inputClassName:"form-control input-sm sp-margin-xs-right"}),Rt.createElement("span",null,d)))),Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement(Sl,{config:a.targetTrackingConfiguration,serverGroup:r,unit:d,updateUnit:e=>u(e)}))))};yr(".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 Il=({command:e,cooldowns:t,policyName:a,updateCommand:r})=>{var i;const s=(t,a)=>{const n={...e};ca(n,t,a),r(n)},l=null==(i=e.targetTrackingConfiguration)?void 0:i.disableScaleIn;return Rt.createElement("div",{className:"section-body TargetTrackingAdditionalSettings"},a&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},a)),Boolean(e.estimatedInstanceWarmup)&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static"},"Instances need"),Rt.createElement(p,{value:e.estimatedInstanceWarmup,onChange:e=>s("estimatedInstanceWarmup",Number.parseInt(e.target.value)),inputClassName:"form-control number-input-sm sp-margin-xs-xaxis"}),Rt.createElement("span",{className:"input-label"}," seconds to warm up "))),Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Scale In"),Rt.createElement("div",{className:"col-md-9"},Rt.createElement("div",{className:"checkbox"},Rt.createElement(d,{text:"Disable Scale-downs",checked:l,onChange:e=>s("targetTrackingConfiguration.disableScaleIn",e.target.checked)}),Rt.createElement("div",{className:"small"},Rt.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."),Rt.createElement("p",null,"This is useful when you have special requirements, such as gradual or delayed scale-down."))))),Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},l&&Rt.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&&Rt.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&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-3 sm-label-right"},Rt.createElement("span",{className:"sp-margin-xs-right"},"Scale In Cooldown"),Rt.createElement(n,{id:"titus.autoscaling.scaleIn.cooldown"})),Rt.createElement("div",{className:"col-md-9 horizontal middle"},Rt.createElement(p,{value:e.targetTrackingConfiguration.scaleInCooldown,onChange:e=>s("targetTrackingConfiguration.scaleInCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Rt.createElement("span",{className:"input-label"}," seconds "))),t&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-3 sm-label-right"},Rt.createElement("span",{className:"sp-margin-xs-right"},"Scale Out Cooldown"),Rt.createElement(n,{id:"titus.autoscaling.scaleOut.cooldown"})),Rt.createElement("div",{className:"col-md-9 horizontal middle"},Rt.createElement(p,{value:e.targetTrackingConfiguration.scaleOutCooldown,onChange:e=>s("targetTrackingConfiguration.scaleOutCooldown",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis number-input-sm"}),Rt.createElement("span",{className:"input-label"}," seconds "))))},Al={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=Al.buildAlarm(a,t.region,t.name),s.minAdjustmentMagnitude=null!=(n=a.minAdjustmentMagnitude)?n:1,(null==(r=a.stepAdjustments)?void 0:r.length)?s.step=Al.buildStepPolicy(a,s.alarm.threshold,s.cooldown):s.simple=Al.buildSimplePolicy(a)),"TargetTracking"===e&&(s.estimatedInstanceWarmup=null!=(i=a.estimatedInstanceWarmup)?i:600,s.targetTrackingConfiguration={...a.targetTrackingConfiguration}),s},prepareCommandForUpsert:(e,t)=>{const a=Zt(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}},xl=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i;const[s,l]=Rt.useState(Boolean(null==(i=n.targetTrackingConfiguration)?void 0:i.customizedMetricSpecification)),[o,c]=Rt.useState({});Rt.useEffect((()=>{const e=Al.buildNewCommand("TargetTracking",r,n);c(e)}),[]);const d=n.policyName?"Update":"Create";return Rt.createElement(It,{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:()=>Rt.createElement("div",{className:"modal-body"},Rt.createElement("h4",{className:"section-heading"},"Target Metric"),Rt.createElement(Gl,{allowDualMode:!0,cloudwatch:!1,command:o,isCustomMetric:s,serverGroup:r,toggleMetricType:e=>l("custom"===e),updateCommand:c}),Rt.createElement("h4",{className:"section-heading"},"Additional Settings"),Rt.createElement(Il,{command:o,cooldowns:!1,policyName:n.policyName,updateCommand:c}))})};function Pl(e){const[t,a]=Ot.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 Ot.createElement(qa,{show:!0,onHide:e.showCallback},Ot.createElement(qa.Header,{closeButton:!0},Ot.createElement("h3",null,"Select a policy type")),Ot.createElement(qa.Body,null,Ot.createElement("div",{className:"card-choices"},Ot.createElement("div",{className:s,onClick:r,id:"targetTracking"},Ot.createElement("h3",null,"Target Tracking"),Ot.createElement("div",null,"Continuously adjusts the size of the ASG to keep a specified metric at the target value")),Ot.createElement("div",{className:i,onClick:r,id:"step"},Ot.createElement("h3",null,"Step"),Ot.createElement("div",null,"Rule-based scaling, with the ability to define different scaling amounts depending on the magnitude of the alarm breach"))),o&&Ot.createElement(pe,{type:"info",message:Ot.createElement(n,{id:l,expand:!0})}),e.warnOnMinMaxCapacity&&Ot.createElement(pe,{type:"warning",message:Ot.createElement(Ot.Fragment,null,Ot.createElement("p",null,"This server group's ",Ot.createElement("em",null,"min")," and ",Ot.createElement("em",null,"max")," capacity are identical, so scaling policies will have ",Ot.createElement("b",null,"no effect.")),Ot.createElement("p",null,"Scaling policies work by adjusting the server group's ",Ot.createElement("em",null,"desired")," capacity to a value between the min and max."))})),Ot.createElement(qa.Footer,null,Ot.createElement("button",{className:"btn btn-default",onClick:e.showCallback},"Cancel"),Ot.createElement("button",{className:"btn btn-primary",disabled:!t,onClick:()=>{e.typeSelectedCallback(t)}},"Next")))}yr(".ScalingPolicyAdditionalSettings .section-additional-settings .row {\n margin-bottom: 10px;\n}\n.ScalingPolicyAdditionalSettings .section-additional-settings .number-input-sm {\n width: 60px;\n}\n");const Dl=({command:e,isInstanceType:t,isNew:a,operator:r,updateCommand:i})=>{var s,l,o,c;const d=(t,a)=>{const n={...e};ca(n,t,a),i(n)};return Rt.createElement("div",{className:"ScalingPolicyAdditionalSettings"},Rt.createElement("h4",{className:"section-heading"},"Additional Settings"),Rt.createElement("div",{className:"section-body section-additional-settings"},!a&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Policy Name"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"},e.name))),!t&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Adjustment Step"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"},`${r} instances in increments of at least `),Rt.createElement(p,{value:e.minAdjustmentMagnitude,onChange:e=>d("minAdjustmentMagnitude",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-xaxis input-sm number-input-sm"}),Rt.createElement("span",{className:"input-label"}," instance(s) "))),Boolean(e.simple)&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Cooldown"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"}," Wait at least "),Rt.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"}),Rt.createElement("span",{className:"input-label"}," seconds before another scaling event "))),Boolean(null==(l=e.step)?void 0:l.estimatedInstanceWarmup)&&"Remove"!==r&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Warmup"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement("span",{className:"form-control-static select-placeholder"},"Instances need"),Rt.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"}),Rt.createElement("span",{className:"input-label"}," seconds to warm up after each step "))),Boolean(null==(o=e.step)?void 0:o.cooldown)&&"Remove"!==r&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},Rt.createElement("span",{className:"sp-margin-xs-right"},"Cooldown"),Rt.createElement(n,{id:`${e.cloudProvider||e.provider}.autoscaling.cooldown`})),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.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"}),Rt.createElement("span",{className:"input-label"}," seconds ")))))};yr(".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 zl=["Average","Maximum","Minimum","SampleCount","Sum"],Bl=[{label:">=",value:"GreaterThanOrEqualToThreshold"},{label:">",value:"GreaterThanThreshold"},{label:"<=",value:"LessThanOrEqualToThreshold"},{label:"<",value:"LessThanThreshold"}],Fl=[{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}],Ml=({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]=Rt.useState(null==e?void 0:e.unit),m=ft(o);Rt.useEffect((()=>{if(n&&void 0!==m){const t={scalingAdjustment:1,["max"===o?"metricIntervalLowerBound":"metricIntervalUpperBound"]:e.threshold};r([t])}}),[o]),Rt.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 Rt.createElement("div",{className:"AlarmConfigurer"},t&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-12"},Rt.createElement("div",{className:"alert alert-warning"},Rt.createElement("p",null,Rt.createElement("i",{className:"fa fa-exclamation-triangle"})," This scaling policy is configured with multiple alarms. You are only editing the first alarm."),Rt.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&&Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-12"},Rt.createElement("div",{className:"alert alert-warning"},Rt.createElement("p",null,Rt.createElement("i",{className:"fa fa-exclamation-triangle"})," This alarm is used in multiple scaling policies. Any changes here will affect those other scaling policies.")))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"Whenever"),Rt.createElement("div",{className:"col-md-10 horizontal"},Rt.createElement(c,{value:e.statistic,onChange:e=>g("statistic",e.target.value),stringOptions:zl,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}),Rt.createElement("span",{className:"input-label sp-margin-xs-right sp-margin-s-top"}," of "),Rt.createElement(Tl,{alarm:e,serverGroup:a,updateAlarm:e=>{i(e)}}))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"is"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement(c,{value:e.comparisonOperator,onChange:e=>g("comparisonOperator",e.target.value),options:Bl,clearable:!1,inputClassName:"sp-margin-s-right configurer-field-small"}),Rt.createElement("div",{className:"sp-margin-xl-left"},Rt.createElement(p,{value:e.threshold,onChange:e=>g("threshold",Number.parseInt(e.target.value)),inputClassName:"sp-margin-xs-right configurer-field-lg"})),Rt.createElement("span",{className:"input-label"},d))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-2 sm-label-right"},"for at least"),Rt.createElement("div",{className:"col-md-10 horizontal middle"},Rt.createElement(p,{value:e.evaluationPeriods,onChange:e=>g("evaluationPeriods",Number.parseInt(e.target.value)),inputClassName:"configurer-field-med number-input-field"}),Rt.createElement("span",{className:"input-label sp-margin-s-xaxis"}," consecutive period(s) of "),Rt.createElement(c,{value:e.period,onChange:e=>g("period",e.target.value),options:Fl,clearable:!1,inputClassName:"sp-margin-xs-right configurer-field-lg"}))),Rt.createElement("div",{className:"row sp-margin-s-yaxis"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},e&&Rt.createElement("div",null,Rt.createElement(El,{alarm:e,serverGroup:a,onChartLoaded:e=>u(e.unit)})))))};yr(".SimplePolicyAction .action-input {\n width: 65px;\n}\n.SimplePolicyAction .adjustment-type-input {\n width: 110px;\n}\n");const $l=({adjustmentType:e,adjustmentTypeChanged:t,operator:a,scalingAdjustment:n,updateScalingAdjustment:r})=>{const i="Set to"===a?["instances"]:["instances","percent of group"],[s,l]=Rt.useState(e),[o,d]=Rt.useState(n);return Rt.createElement("div",{className:"SimplePolicyAction row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1 horizontal middle"},Rt.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"}),Rt.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"}),Rt.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"})))};yr(".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 Ll=({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 Rt.createElement("div",{className:"StepPolicyAction row"},null==m?void 0:m.map(((i,s)=>Rt.createElement("div",{key:`step-adjustment-${s}`,className:"step-policy-row col-md-10 col-md-offset-1 horizontal middle"},Boolean(s)?Rt.createElement("span",{className:"action-input sp-margin-xs-left"},r):Rt.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"}),Rt.createElement(p,{value:i.scalingAdjustment,min:1,onChange:e=>g({...i,scalingAdjustment:Number.parseInt(e.target.value)},s),inputClassName:"action-input"}),Boolean(s)?Rt.createElement("span",{className:"sp-margin-xs-left"},e):Rt.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"}),Rt.createElement("span",{className:"sp-margin-xs-xaxis"}," ","when ",Rt.createElement("b",null,null==a?void 0:a.metricName)," is"," "),s===m.length-1&&Rt.createElement("span",null,` ${n?"less":"greater"} than${!Boolean(s)||o?" or equal to":""} ${n?i.metricIntervalUpperBound||"":i.metricIntervalLowerBound||""} `),s<m.length-1&&Rt.createElement(Rt.Fragment,null,Rt.createElement("span",{className:"sp-margin-xs-xaxis"},"between"),n?Rt.createElement(p,{value:i.metricIntervalLowerBound,max:i.metricIntervalUpperBound,step:.1,onChange:e=>g({...i,metricIntervalLowerBound:Number.parseFloat(e.target.value)},s),inputClassName:"action-input"}):Rt.createElement("span",null,i.metricIntervalLowerBound),Rt.createElement("span",{className:"sp-margin-xs-xaxis"},"and"),n?Rt.createElement("span",null,i.metricIntervalUpperBound):Rt.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)&&Rt.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)})))),Rt.createElement("div",{className:"row sp-margin-s"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement("button",{type:"button",className:"btn btn-block btn-sm add-new",onClick:()=>{const e=[...m,{scalingAdjustment:1}];l(e)}},Rt.createElement("span",{className:"glyphicon glyphicon-plus-sign"}),"Add step"))),Rt.createElement("div",{className:"row sp-margin-s-xaxis"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement("a",{href:"http://docs.aws.amazon.com/autoscaling/latest/userguide/as-scale-based-on-demand.html#as-scaling-steps",target:"_blank"},Rt.createElement("i",{className:"far fa-file-alt sp-margin-xs-right"}),"Documentation"))))},Rl=({app:e,closeModal:t,dismissModal:a,policy:n,serverGroup:r})=>{var i,s,l;const o={closeModal:t,dismissModal:a},[c,d]=Rt.useState({});Rt.useEffect((()=>{const e=Al.buildNewCommand("Step",r,n);d(e)}),[]);const u=(null==(i=n.stepAdjustments)?void 0:i.length)?n.stepAdjustments[0].scalingAdjustment:n.scalingAdjustment,[p,m]=Rt.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=Zt(c);t.simplescalingAdjustment=e,d(t)},E=e=>{const t=Zt(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=Zt(c),t=c.step?c.step.estimatedInstanceWarmup:c.simple.cooldown;if(c.step)delete e.step,e.simple=Al.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=Al.buildStepPolicy(n,e.alarm.threshold,t),y(e.step)}d(e)};return Rt.createElement(It,{...o,title:`${f} scaling policy`,application:e,description:`${f} scaling policy for ${r.name}`,initialValues:c,mapValuesToTask:()=>{const t=Al.prepareCommandForUpsert(c,"Remove"===p);return{application:e,job:[{type:t.type||"upsertScalingPolicy",...t}]}},render:()=>{var e,t,a,i,s;return Rt.createElement("div",null,Rt.createElement("h4",{className:"section-heading"},"Conditions"),Rt.createElement("div",{className:"section-body"},Rt.createElement(Ml,{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})})),Rt.createElement("h4",{className:"section-heading"},"Actions"),Rt.createElement("div",{className:"section-body"},!(null==(t=c.alarm)?void 0:t.metricName)&&Rt.createElement("h4",{className:"text-center"},"Select a metric"),(null==(a=c.alarm)?void 0:a.metricName)&&!h&&Rt.createElement("div",null,Rt.createElement("div",{className:"row"},Rt.createElement("div",{className:"col-md-10 col-md-offset-1"},Rt.createElement("p",null,"This is a simple scaling policy. To declare different actions based on the magnitude of the alarm,",Rt.createElement("b",null,"switch to a",Rt.createElement("a",{className:"clickable sp-margin-xs-l",onClick:C},"step policy"),".")))),Rt.createElement($l,{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&&Rt.createElement(Ll,{adjustmentType:g,adjustmentTypeChanged:w,alarm:c.alarm,isMin:"min"===v,operator:p,step:c.step,stepsChanged:E})),Rt.createElement(Dl,{command:c,isInstanceType:"instances"===g,isNew:Boolean(!n.policyARN),operator:p,updateCommand:d}))}})};class Ol extends Ot.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:_n.awsServerGroupTransformer.constructNewStepScalingPolicyTemplate(e),serverGroup:e};b.show(Rl,a,{dialogClassName:"wizard-modal modal-lg"})}createTargetTrackingPolicy(){const{serverGroup:e,application:t}=this.props,a={app:t,policy:_n.awsServerGroupTransformer.constructNewTargetTrackingPolicyTemplate(),serverGroup:e};b.show(xl,a,{dialogClassName:"wizard-modal modal-lg"})}render(){const{min:e,max:t}=this.props.serverGroup.capacity;return Ot.createElement("div",null,Ot.createElement("a",{className:"clickable",onClick:this.handleClick},"Create new scaling policy"),this.state.showSelection&&Ot.createElement(Pl,{warnOnMinMaxCapacity:e===t,typeSelectedCallback:this.typeSelected,showCallback:this.showModalCallback}))}}class Vl{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 Ul={GreaterThanOrEqualToThreshold:">=",GreaterThanThreshold:">",LessThanOrEqualToThreshold:"<=",LessThanThreshold:"<"},ql=({alarm:e})=>Rt.createElement("div",null,Rt.createElement("div",null,Rt.createElement("b",null,"Whenever"),` ${e.statistic} of ${e.metricName}`),Rt.createElement("div",null,Rt.createElement("b",null,"for at least"),` ${e.evaluationPeriods} consecutive periods of ${e.period} seconds`)),Hl=({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 Rt.createElement("div",null,Rt.createElement(W,{className:"dl-horizontal dl-narrow"},Rt.createElement(z,{label:"Whenever",value:`${d.statistic} of ${d.metricName} is ${Ul[d.comparisonOperator]} ${d.threshold}`}),Rt.createElement(z,{label:"for at least",value:`${d.evaluationPeriods} consecutive periods of ${d.period} seconds`}),Boolean(null==o?void 0:o.length)&&Rt.createElement(z,{label:"then",value:o.map(((e,t)=>Rt.createElement("div",{key:`step-adjustment-boundary-${t}`},o.length>1&&Rt.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)),Rt.createElement("span",null,p(e)))))}),!Boolean(null==o?void 0:o.length)&&Rt.createElement(z,{label:"then",value:p(e)}),Boolean(l)&&Rt.createElement(z,{label:"in",value:`increments of at least ${l} instance${l>1?"s":""}`}),Boolean(c)&&Rt.createElement(z,{label:"wait",value:`${i} seconds before allowing another scaling activity.`}),Boolean(s)&&Rt.createElement(z,{label:"wait",value:`${s} seconds to warm up after each step.`})),Rt.createElement(El,{alarm:d,serverGroup:t}))};yr(".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 Wl=({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 Rt.createElement("div",{className:"StepPolicySummary"},Rt.createElement("div",null,!Boolean(null==(n=t.alarms)?void 0:n.length)&&Rt.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=>Rt.createElement("div",{key:`step-summary-${t.policyName}`},Rt.createElement(ne,{Component:()=>Rt.createElement(Hl,{policy:t,serverGroup:a}),placement:"left",title:t.policyName},Rt.createElement("div",null,Rt.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Rt.createElement(ql,{alarm:e}))),Rt.createElement("div",{className:"actions"},Rt.createElement("button",{className:"btn btn-xs btn-link",onClick:c},Rt.createElement("span",{className:"glyphicon glyphicon-cog"}),Rt.createElement("span",{className:"sr-only"},"Edit policy")),Rt.createElement("button",{className:"btn btn-xs btn-link",onClick:d},Rt.createElement("span",{className:"glyphicon glyphicon-trash"}),Rt.createElement("span",{className:"sr-only"},"Delete policy"))))))))};yr(".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 jl=({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 Rt.createElement("div",{className:"TargetTrackingSummary"},Rt.createElement(ne,{Component:()=>Rt.createElement(d,{config:t.targetTrackingConfiguration,serverGroup:a}),placement:"left",title:o},Rt.createElement("div",null,Rt.createElement("div",{className:"label label-default"},Z(t.policyType).toUpperCase()),Rt.createElement("div",null,Rt.createElement("b",null,"Target"),Rt.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)&&Rt.createElement("span",null,` @ ${u.targetValue}`)))),Rt.createElement("div",{className:"actions"},Rt.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"})}},Rt.createElement("span",{className:"glyphicon glyphicon-cog"}),Rt.createElement("span",{className:"sr-only"},"Edit policy")),Rt.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]})})}},Rt.createElement("span",{className:"glyphicon glyphicon-trash"}),Rt.createElement("span",{className:"sr-only"},"Delete policy"))))},Zl=({application:e,policy:t,serverGroup:a})=>"TargetTrackingScaling"===(t.policyType?t.policyType:t.targetTrackingConfiguration?"TargetTrackingScaling":"StepScaling")?Rt.createElement(jl,{application:e,policy:t,serverGroup:a}):Rt.createElement(Wl,{application:e,policy:t,serverGroup:a});class _l extends Ot.Component{constructor(){super(...arguments),this.editAdvancedSettings=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&kt.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 Ot.createElement(x,{heading:"Advanced Settings"},Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},Ot.createElement("dt",null,"Cooldown"),Ot.createElement("dd",null,t.defaultCooldown," seconds"),t.enabledMetrics.length>0&&[Ot.createElement("dt",{key:"t-metrics"},"Enabled Metrics"),Ot.createElement("dd",{key:"d-metrics"},t.enabledMetrics.map((e=>e.metric)).join(", "))],Ot.createElement("dt",null,"Health Check Type"),Ot.createElement("dd",null,t.healthCheckType),Ot.createElement("dt",null,"Grace Period"),Ot.createElement("dd",null,t.healthCheckGracePeriod," seconds"),Ot.createElement("dt",null,"Termination Policies"),Ot.createElement("dd",null,t.terminationPolicies.join(", ")),t.capacityRebalance&&[Ot.createElement("dt",null,"Capacity Rebalance ",Ot.createElement(n,{id:"aws.serverGroup.capacityRebalance"})),Ot.createElement("dd",null,`${t.capacityRebalance}`)]),Sn.adHocInfraWritesEnabled&&Ot.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 &nbsp;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 &nbsp;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 Kl extends Ot.Component{constructor(e){super(e),this.state={changeConfig:this.getChangeConfig(e.serverGroup)}}getChangeConfig(e){const t={metadata:ra(e.entityTags,"creationMetadata")};return Ea(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 Ot.createElement(x,{heading:"Server Group Information",defaultExpanded:!0},Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Created"),Ot.createElement("dd",null,B(e.createdTime)),n&&Ot.createElement(At,{metadata:r.creationMetadata}),n&&Ot.createElement(xt,{changeConfig:t,linkText:"view changes",nameItem:e,viewType:"description"}),Ot.createElement("dt",null,"In"),Ot.createElement("dd",null,Ot.createElement(I,{account:e.account}),e.region),Ot.createElement("dt",null,"VPC"),Ot.createElement("dd",null,Ot.createElement(pr,{vpcId:e.vpcId})),e.vpcId&&e.subnetType&&Ot.createElement("dt",null,"Subnet"),e.vpcId&&e.subnetType&&Ot.createElement("dd",null,e.subnetType),e.asg&&Ot.createElement("dt",null,"Zones"),e.asg&&Ot.createElement("dd",null,Ot.createElement("ul",null,e.asg.availabilityZones.map((e=>Ot.createElement("li",{key:e},e)))))))}}var Yl=Object.defineProperty,Xl=Object.getOwnPropertyDescriptor;let Jl=class extends Ot.Component{render(){const{serverGroup:e,app:t}=this.props,a={min:e.asg.minSize,max:e.asg.maxSize,desired:e.asg.desiredCapacity};return Ot.createElement(x,{heading:"Capacity",defaultExpanded:!0},Ot.createElement(Pt,{current:e.instances.length,capacity:a}),Ot.createElement("div",null,Sn.adHocInfraWritesEnabled&&Ot.createElement("a",{className:"clickable",onClick:()=>pl.show({application:t,serverGroup:e})},"Resize Server Group")),Ot.createElement("div",null,Ot.createElement(Dt,{serverGroup:e})))}};Jl=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?Xl(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&&Yl(t,a,i),i})([ie("amazon.serverGroup.CapacityDetailsSection")],Jl);class Ql extends Ot.Component{render(){const{serverGroup:e}=this.props;return e.instanceCounts.total>0?Ot.createElement(x,{heading:"Health",defaultExpanded:!0},Ot.createElement("dl",{className:"dl-horizontal dl-narrow"},Ot.createElement("dt",null,"Instances"),Ot.createElement("dd",null,Ot.createElement(X,{container:e.instanceCounts,className:"pull-left"})))):null}}const eo=({serverGroup:e})=>{if(!e.mixedInstancesPolicy)return null;const t=e.mixedInstancesPolicy.instancesDistribution;return Ot.createElement(x,{heading:"Instances Distribution"},Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},Ot.createElement(z,{label:"On-Demand Allocation Strategy",helpFieldId:"aws.serverGroup.odAllocationStrategy",value:t.onDemandAllocationStrategy}),Ot.createElement(z,{label:"On-Demand Base Capacity",helpFieldId:"aws.serverGroup.odBase",value:t.onDemandBaseCapacity}),Ot.createElement(z,{label:"On-Demand Percentage Above Base Capacity",helpFieldId:"aws.serverGroup.odPercentAboveBase",value:t.onDemandPercentageAboveBaseCapacity}),Ot.createElement(z,{label:"Spot Allocation Strategy",helpFieldId:"aws.serverGroup.spotAllocationStrategy",value:t.spotAllocationStrategy}),t.spotInstancePools&&Ot.createElement(z,{label:"Spot Instance Pools",helpFieldId:"aws.serverGroup.spotInstancePoolCount",value:t.spotInstancePools}),Ot.createElement(z,{label:"Max Spot Price",helpFieldId:"aws.serverGroup.spotMaxPrice",value:t.spotMaxPrice||"on-demand price, default"})))},to=e=>{let t;return(e||"").split(", ").forEach((e=>{const a=e.split("=");2===a.length&&"ancestor_name"===a[0]&&(t=a[1])})),t};class ao extends Ot.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=to(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?Ot.createElement(x,{heading:"Launch Configuration"},Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},Ot.createElement("dt",null,"Name"),Ot.createElement("dd",null,t.launchConfigurationName),Ot.createElement("dt",null,"Image ID"),Ot.createElement("dd",null,t.imageId),a&&a.imageLocation&&Ot.createElement("dt",null,"Image Name"),a&&a.imageLocation&&Ot.createElement("dd",null,a.imageLocation),a&&a.baseImage&&Ot.createElement("dt",null,"Base Image Name"),a&&a.baseImage&&Ot.createElement("dd",null,a.baseImage),Ot.createElement("dt",null,"Instance Type"),Ot.createElement("dd",null,t.instanceType),Ot.createElement("dt",null,"IAM Profile"),Ot.createElement("dd",null,t.iamInstanceProfile),t.instanceMonitoring&&Ot.createElement(Ot.Fragment,null,Ot.createElement("dt",null,"Instance Monitoring"),Ot.createElement("dd",null,t.instanceMonitoring.enabled?"enabled":"disabled")),t.spotPrice&&Ot.createElement("dt",null,"Spot Price"),t.spotPrice&&Ot.createElement("dd",null,t.spotPrice),t.keyName&&Ot.createElement("dt",null,"Key Name"),t.keyName&&Ot.createElement("dd",null,t.keyName),t.kernelId&&Ot.createElement("dt",null,"Kernel ID"),t.kernelId&&Ot.createElement("dd",null,t.kernelId),t.ramdiskId&&Ot.createElement("dt",null,"Ramdisk ID"),t.ramdiskId&&Ot.createElement("dd",null,t.ramdiskId),Ot.createElement("dt",null,"User Data"),t.userData&&Ot.createElement("dd",null,Ot.createElement(zt,{serverGroupName:e,userData:t.userData})),!t.userData&&Ot.createElement("dd",null,"[none]"))):null}}function no(e){return e.instanceTypeOverrides?Ot.createElement(x,{heading:"Instance Types",defaultExpanded:!0,outerDivClassName:"multiple-instance-types-subsection",toggleClassName:"clickable subsection-heading",headingClassName:"collapsible-subheading"},Ot.createElement("table",{className:"table table-condensed packed",id:"MultipleInstanceTypes"},Ot.createElement("thead",null,Ot.createElement("tr",null,Ot.createElement("th",{id:"instanceType"},"Type ",Ot.createElement(n,{id:"aws.serverGroup.multipleInstanceTypes"})),Ot.createElement("th",{id:"weight"},"Weighted Capacity ",Ot.createElement(n,{id:"aws.serverGroup.instanceTypeWeight"})))),Ot.createElement("tbody",null,e.instanceTypeOverrides.map((e=>[Ot.createElement("tr",{key:e.instanceType},Ot.createElement("td",{headers:"instanceType"},e.instanceType),Ot.createElement("td",{headers:"weight"},e.weightedCapacity))]))))):null}yr('.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 -webkit-animation: 0.15 ease-in 0 fadeIn;\n animation: 0.15 ease-in 0 fadeIn;\n -webkit-animation-iteration-count: 1;\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 ro=({serverGroup:e})=>{var t,a,n;const{image:r}=e,i=to(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 Ot.createElement(x,{heading:"Launch Template"},Ot.createElement(W,{className:"horizontal-when-filters-collapsed"},Ot.createElement(z,{label:"Name",value:l.launchTemplateName}),Ot.createElement(z,{label:"Image ID",value:o.imageId}),(null==r?void 0:r.imageLocation)&&Ot.createElement(z,{label:"Image Name",value:null==r?void 0:r.imageLocation}),i&&Ot.createElement(z,{label:"Base Image Name",value:i}),u&&u.length>0?Ot.createElement(no,{instanceTypeOverrides:u}):Ot.createElement(z,{label:"Instance Type",value:o.instanceType}),d&&Ot.createElement(z,{label:"CPU Credit Specification",value:d}),Ot.createElement(z,{label:"IAM Profile",value:o.iamInstanceProfile.name}),o.monitoring&&Ot.createElement(z,{label:"Instance Monitoring",value:o.monitoring.enabled?"enabled":"disabled"}),c&&Ot.createElement(z,{label:"Max Spot Price",value:c}),o.keyName&&Ot.createElement(z,{label:"Key Name",value:o.keyName}),o.kernelId&&Ot.createElement(z,{label:"Kernel ID",value:o.kernelId}),o.ramDiskId&&Ot.createElement(z,{label:"Ramdisk ID",value:o.ramDiskId}),o.userData&&Ot.createElement(z,{label:"User Data",value:Ot.createElement(zt,{serverGroupName:e.name,userData:o.userData})})))};class io extends Ot.Component{render(){return Ot.createElement(x,{heading:"Logs"},Ot.createElement("ul",null,Ot.createElement("li",null,Ot.createElement(Dt,{serverGroup:this.props.serverGroup}))))}}class so extends Ot.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?Ot.createElement(x,{heading:"Package"},Ot.createElement("dl",{className:"horizontal-when-filters-collapsed"},Ot.createElement("dt",null,"Job"),Ot.createElement("dd",null,e.buildInfo.jenkins.name),Ot.createElement("dt",null,"Package"),Ot.createElement("dd",null,e.buildInfo.package_name),Ot.createElement("dt",null,"Build"),Ot.createElement("dd",null,e.buildInfo.jenkins.number),Ot.createElement("dt",null,"Commit"),Ot.createElement("dd",null,t),Ot.createElement("dt",null,"Version"),Ot.createElement("dd",null,e.buildInfo.version),Ot.createElement("dt",null,"Build Link"),Ot.createElement("dd",null,Ot.createElement("a",{target:"_blank",href:a},a)))):null}}var lo=Object.defineProperty,oo=Object.getOwnPropertyDescriptor;let co=class extends Ot.Component{constructor(e){super(e)}static arePoliciesDisabled(e){const t=vl.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=co.arePoliciesDisabled(t);return Ot.createElement(x,{cacheKey:"Scaling Policies",heading:({chevron:e})=>Ot.createElement("h4",{className:"collapsible-heading"},e,Ot.createElement("span",null,a&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Policies"))},a&&Ot.createElement("div",{className:"band band-warning"},"Some scaling processes are disabled that may prevent scaling policies from working."),t.scalingPolicies.map((a=>Ot.createElement(Zl,{key:a.policyARN,policy:a,serverGroup:t,application:e}))),Sn.adHocInfraWritesEnabled?Ot.createElement(Ol,{serverGroup:t,application:e}):Ot.createElement("p",null,"Can not create scaling policy, because ad-hoc operations are disabled for AWS providers."))}};co=((e,t,a,n)=>{for(var r,i=n>1?void 0:n?oo(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&&lo(t,a,i),i})([ie("aws.serverGroup.ScalingPoliciesDetailsSection")],co);class uo extends Ot.Component{constructor(e){super(e),this.toggleScalingProcesses=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&kt.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=vl.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 Ot.createElement(x,{cacheKey:"Scaling Processes",heading:({chevron:e})=>Ot.createElement("h4",{className:"collapsible-heading"},e,Ot.createElement("span",null,t&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scaling policies from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),a&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scaling Processes"))},Ot.createElement("ul",{className:"scaling-processes"},e.map((e=>Ot.createElement("li",{key:e.name},Ot.createElement("span",{style:{visibility:e.enabled?"visible":"hidden"},className:"fa fa-check small"}),Ot.createElement("span",{className:e.enabled?"":"text-disabled"},e.name," "),Ot.createElement(n,{content:e.description,placement:"bottom"}),e.suspensionDate&&Ot.createElement("div",{className:"text-disabled small",style:{marginLeft:"35px"}},"Suspended ",B(e.suspensionDate)))))),Sn.adHocInfraWritesEnabled&&Ot.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 po extends Ot.Component{render(){const{action:e}=this.props;return Ot.createElement("dl",{className:"horizontal-when-filters-collapsed",style:{marginBottom:"20px"}},Ot.createElement("dt",null,"Schedule"),Ot.createElement("dd",null,e.recurrence),void 0!==e.minSize&&Ot.createElement("dt",null,"Min Size"),void 0!==e.minSize&&Ot.createElement("dd",null,e.minSize),void 0!==e.maxSize&&Ot.createElement("dt",null,"Max Size"),void 0!==e.maxSize&&Ot.createElement("dd",null,e.maxSize),void 0!==e.desiredCapacity&&Ot.createElement("dt",null,"Desired Size"),void 0!==e.desiredCapacity&&Ot.createElement("dd",null,e.desiredCapacity))}}class mo extends Ot.Component{constructor(e){super(e),this.editScheduledActions=()=>{kt.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=vl.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 Ot.createElement(x,{cacheKey:"Scheduled Actions",heading:({chevron:e})=>Ot.createElement("h4",{className:"collapsible-heading"},e,Ot.createElement("span",null,t&&Ot.createElement(_,{value:"Some scaling processes are disabled that may prevent scheduled actions from working"},Ot.createElement("span",{className:"fa fa-exclamation-circle warning-text"})),"Scheduled Actions"))},e.scheduledActions.map(((e,t)=>Ot.createElement(po,{key:t,action:e}))),e.scheduledActions.length>0&&Ot.createElement("p",null,Ot.createElement("strong",null,"Note:")," Schedules are evaluated in UTC."),0===e.scheduledActions.length&&Ot.createElement("p",null,"No Scheduled Actions are configured for this server group."),Sn.adHocInfraWritesEnabled&&Ot.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 go extends Ot.Component{constructor(e){super(e),this.updateSecurityGroups=()=>{const{app:e,serverGroup:t}=this.props;lt(t,e).then((a=>a&&kt.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 Cs.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=ea(n.securityGroups).map((e=>ya(a.securityGroups.data,{accountName:n.account,region:n.region,id:e})||ya(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 Ot.createElement(x,{heading:U.get("Firewalls")},Ot.createElement("ul",null,Jt(t,"name").map((t=>Ot.createElement("li",{key:t.name},Ot.createElement(Ja,{to:"^.firewallDetails",params:{name:t.name,accountId:t.accountName,region:e.region,vpcId:e.vpcId,provider:e.type}},Ot.createElement("a",null,t.name," (",t.id,")")))))),Sn.adHocInfraWritesEnabled&&e.vpcId&&Ot.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 ho extends Ot.Component{render(){const{serverGroup:e}=this.props;return Ot.createElement(x,{heading:"Tags"},0===e.asg.tags.length&&Ot.createElement("div",null,"No tags associated with this server group"),e.asg.tags.length>0&&Ot.createElement("dl",null,Jt(e.asg.tags,"key").map((e=>[Ot.createElement("dt",{key:e.key},e.key),Ot.createElement("dd",{key:e.value},e.value)]))))}}class fo{static listKeyPairs(){return D("/keyPairs").useCache().get().then((e=>e.sort(((e,t)=>e.keyName.localeCompare(t.keyName)))))}}class vo{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:wa(this.enabledMetrics),healthCheckTypes:wa(this.healthCheckTypes),terminationPolicies:wa(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=Sn.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=>Ea(e,"backingData.filtered.regions")&&e.backingData.filtered.regions.some((t=>t.name===e.region&&t.deprecated)),Ya.all([o.getCredentialsKeyedByAccount("aws"),this.securityGroupReader.getAllSecurityGroups(),g.listSubnets(),o.getPreferredZonesByAccount("aws"),fo.listKeyPairs(),this.awsInstanceTypeService.getAllTypesByRegion(),Ya.when(wa(this.enabledMetrics)),Ya.when(wa(this.healthCheckTypes)),Ya.when(wa(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=Ya.when();if(m.accounts=Ca(m.credentialsKeyedByAccount),m.filtered={},m.scalingProcesses=vl.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=ta(this.getRegionalSecurityGroups(t),"id");fa(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=la(e.backingData.credentialsKeyedByAccount,(t=>t.defaultKeyPair&&e.keyPair&&0===e.keyPair.indexOf(t.defaultKeyPair.replace("{{region}}","")))),n=ea(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=ta(a,"name");e.instanceType&&!n.includes(e.instanceType)&&(t.dirty.instanceType=e.instanceType,e.instanceType=null);const r=ta(e.launchTemplateOverridesForInstanceType,"instanceType"),i=fa(r,n),s=sa(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 ga(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=ya(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=ea(e.backingData.subnets).filter({account:e.credentials,region:e.region}).reject({target:"elb"}).reject({purpose:null}).uniqBy("purpose").value(),ea(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 ea(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=ya(a,{id:e});return t?t.name:e})),i=e.securityGroups.map((e=>{const t=ya(a,{id:e})||ya(a,{name:e});return t?t.name:null})).map((e=>ya(n,{name:e}))).filter((e=>e)),s=ta(i,"name"),l=Sa(r,s);e.securityGroups=ta(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 ea(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 _t(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=fa(e,t),[r,i]=da(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=fa(r.concat(o),s),e.vpcId?delete e.vpcLoadBalancers:e.vpcLoadBalancers=fa(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=ya(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 ga(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=Zt(n[e.region].sort());else{e.availabilityZones=fa(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 ga(t.dirty,this.configureSecurityGroupOptions(e).dirty),ga(t.dirty,this.configureLoadBalancerOptions(e).dirty),e.viewState.dirty=e.viewState.dirty||{},ga(e.viewState.dirty,t.dirty),t},e.regionChanged=e=>{const t={dirty:{}},a=e.backingData.filtered;return ga(t.dirty,this.configureSubnetPurposes(e).dirty),e.region?(ga(t.dirty,e.subnetChanged(e).dirty),ga(t.dirty,this.configureInstanceTypes(e).dirty),this.configureAvailabilityZones(e),ga(t.dirty,e.usePreferredZonesChanged(e).dirty),ga(t.dirty,this.configureImages(e).dirty),ga(t.dirty,this.configureKeyPairs(e).dirty)):a.regionalAvailabilityZones=null,Ft(e),t},e.clusterChanged=e=>{e.moniker=re.getMoniker(e.application,e.stack,e.freeFormDetails),Ft(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,la(a.filtered.regions,{name:e.region})?ga(t.dirty,e.regionChanged(e).dirty):(e.region=null,t.dirty.region=!0)}else e.region=null;return Ft(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)}}vo.$inject=["securityGroupReader","awsInstanceTypeService","cacheInitializer","loadBalancerReader","serverGroupCommandRegistry"];const yo="spinnaker.amazon.serverGroup.configure.service";t("spinnaker.amazon.serverGroup.configure.service",[Ie,"spinnaker.amazon.instanceType.service",Ae,st,Bt]).service("awsServerGroupConfigurationService",vo);e.module("spinnaker.amazon.serverGroupCommandBuilder.service",[Mt,"spinnaker.amazon.serverGroup.configure.service"]).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||Sn.defaults.account,i=a.region||e.defaultRegions.aws||Sn.defaults.region,l=a.subnet||Sn.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=Sn.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=Sn.serverGroups)?void 0:m.enableIPv6)&&(w.associateIPv6Address=!0),null==(g=Sn.serverGroups)?void 0:g.enableIMDSv2){const t=Sn.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=[qt.get(i,"launchTemplate.launchTemplateData.instanceType")]:i.launchConfig&&(y=[qt.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;const k=i.asg.availabilityZones.sort();let N=!1;const T=t[i.account];if(T){const e=T[i.region].sort();N=k.join(",")===e.join(",")}const G=["Launch","Terminate","AddToLoadBalancer"],I=(null!=(p=null==(u=null==(d=n.attributes)?void 0:d.providerSettings)?void 0:u.aws)?p:{}).useAmiBlockDeviceMappings||!1,A={},x=["spinnaker:application","spinnaker:stack","spinnaker:details"];i.asg.tags&&i.asg.tags.filter((e=>!x.includes(e.key))).forEach((e=>{A[e.key]=e.value}));const P={application:n.name,strategy:"",stack:v.stack,freeFormDetails:v.freeFormDetails,credentials:i.account,cooldown:i.asg.defaultCooldown,enabledMetrics:qt.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:k,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,A),targetGroups:i.targetGroups,useAmiBlockDeviceMappings:I,copySourceCustomBlockDeviceMappings:"clone"===c,viewState:{instanceProfile:o,useAllImageSelection:!1,useSimpleCapacity:i.asg.minSize===i.asg.maxSize,usePreferredZones:N,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)&&(P.interestingHealthProviderNames=["Amazon"]),"editPipeline"===c){P.useSourceCapacity=!0,P.viewState.useSimpleCapacity=!1,P.strategy="redblack";const e=r.getStrategy("redblack");e.initializationMethod&&e.initializationMethod(P),P.suspendedProcesses=[]}const D=i.asg.vpczoneIdentifier;if(""!==D){const e=D.split(",")[0],t=a.find((t=>t.id===e));P.subnetType=t.purpose,P.vpcId=t.vpcId}else P.subnetType="",P.vpcId=null;if(i.launchConfig&&(e.extend(P,{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&&(P.base64UserData=i.launchConfig.userData),P.viewState.imageId=i.launchConfig.imageId,P.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,P.instanceType=t.instanceType,P.viewState.useSimpleInstanceTypeSelector=!0),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,P.securityGroups=t.networkInterfaces?(null!=(w=t.networkInterfaces.find((e=>0===e.deviceIndex)))?w:{}).groups:t.securityGroups,P.onDemandAllocationStrategy=e.instancesDistribution.onDemandAllocationStrategy,P.onDemandBaseCapacity=e.instancesDistribution.onDemandBaseCapacity,P.onDemandPercentageAboveBaseCapacity=e.instancesDistribution.onDemandPercentageAboveBaseCapacity,P.spotAllocationStrategy=e.instancesDistribution.spotAllocationStrategy,P.spotInstancePools=e.instancesDistribution.spotInstancePools,e.launchTemplateOverridesForInstanceType?P.launchTemplateOverridesForInstanceType=function(e){let t=1;return qt.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):P.instanceType=t.instanceType,P.viewState.useSimpleInstanceTypeSelector=l(P)}const n=qt.get(t,"networkInterfaces[0]"),r=Sn.serverGroups,s=i.accountDetails&&"test"===i.accountDetails.environment,o=r&&r.enableIPv6&&r.setIPv6InTest&&s;e.extend(P,{iamRole:t.iamInstanceProfile.name,keyPair:t.keyName,associateIPv6Address:o||Boolean(n),ramdiskId:t.ramdiskId,instanceMonitoring:t.monitoring&&t.monitoring.enabled,ebsOptimized:t.ebsOptimized,spotPrice:a||void 0,requireIMDSv2:Boolean("required"===(null==(C=t.metadataOptions)?void 0:C.httpTokens)),unlimitedCpuCredits:t.creditSpecification?"unlimited"===t.creditSpecification.cpuCredits:void 0}),P.viewState.imageId=t.imageId}if("clone"===c&&i.image&&i.image.name&&(P.amiName=i.image.name),i.launchConfig&&i.launchConfig.securityGroups.length&&(P.securityGroups=i.launchConfig.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.securityGroups.length&&(P.securityGroups=i.launchTemplate.launchTemplateData.securityGroups),i.launchTemplate&&i.launchTemplate.launchTemplateData.networkInterfaces){const e=null!=(S=i.launchTemplate.launchTemplateData.networkInterfaces.find((e=>0===e.deviceIndex)))?S:{};P.securityGroups=e.groups}return P}))},buildNewServerGroupCommandForPipeline:function(){return t.when({viewState:{requiresTemplateSelection:!0}})},buildServerGroupCommandFromPipeline:function(n,r){const s=qt.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}}}]);t("spinnaker.amazon.serverGroup.editAsgAdvancedSettings.modal.controller",["spinnaker.amazon.serverGroupCommandBuilder.service"]).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}]);t("spinnaker.amazon.serverGroup.details.rollback.controller",[$t]).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=ra(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=ra(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"}}]);t("spinnaker.amazon.scalingPolicy.scalingPolicySummary.component",[]).component("scalingPolicySummary",Xa(L(Zl,"scalingPolicySummary"),["application","policy","serverGroup"]));t("spinnaker.amazon.scalingPolicy.module",["spinnaker.amazon.scalingPolicy.scalingPolicySummary.component"]);e.module("spinnaker.amazon.serverGroup.details.autoscaling.process.controller",[]).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=qt.chain(t.command).filter({enabled:!0}).map("name").value(),l=qt.chain(t.command).filter({enabled:!1}).map("name").value();this.isDirty=function(){const e=qt.chain(t.command).filter({enabled:!0}).map("name").value(),a=qt.chain(t.command).filter({enabled:!1}).map("name").value(),n=qt.intersection(l,e),r=qt.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=qt.chain(t.command).filter({enabled:!0}).map("name").value(),a=qt.chain(t.command).filter({enabled:!1}).map("name").value(),i=qt.intersection(l,e),o=qt.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}]);t("spinnaker.amazon.serverGroup.details.scheduledActions.editScheduledActions.modal.controller",[]).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}]);t("spinnaker.amazon.serverGroup.details.securityGroup.editSecurityGroups.modal.controller",[$t,Ie]).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=qt.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}]);t("spinnaker.amazon.serverGroup.details",["spinnaker.amazon.scalingPolicy.module","spinnaker.amazon.serverGroup.details.securityGroup.editSecurityGroups.modal.controller","spinnaker.amazon.serverGroup.details.autoscaling.process.controller","spinnaker.amazon.serverGroup.details.scheduledActions.editScheduledActions.modal.controller","spinnaker.amazon.serverGroup.editAsgAdvancedSettings.modal.controller","spinnaker.amazon.serverGroup.details.rollback.controller"]);t("spinnaker.amazon.serverGroup.transformer",[]).service("awsServerGroupTransformer",class{addComparator(e){if(e.comparisonOperator)switch(e.comparisonOperator){case"LessThanThreshold":e.comparator="&lt;";break;case"GreaterThanThreshold":e.comparator="&gt;";break;case"LessThanOrEqualToThreshold":e.comparator="&le;";break;case"GreaterThanOrEqualToThreshold":e.comparator="&ge;"}}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})),Un.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"}}}}});t("spinnaker.amazon.subnet.renderer",[]).service("awsSubnetRenderer",class{render(e){return e.subnetType}});Lt.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=Sn.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}}});t("spinnaker.amazon.vpc",[]).component("vpcTag",Xa(L(pr,"vpcTag"),["vpcId"]));yr('.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 bo="spinnaker.amazon";t("spinnaker.amazon",["spinnaker.amazon.react","spinnaker.amazon.pipeline.stage.bakeStage","spinnaker.amazon.pipeline.stage.cloneServerGroupStage","spinnaker.amazon.pipeline.stage.aws.destroyAsgStage","spinnaker.amazon.pipeline.stage.disableAsgStage","spinnaker.amazon.pipeline.stage.disableClusterStage","spinnaker.amazon.pipeline.stage.rollbackClusterStage","spinnaker.amazon.pipeline.stage.enableAsgStage","spinnaker.amazon.pipeline.stage.findAmiStage","spinnaker.amazon.pipeline.stage.findImageFromTagsStage","spinnaker.amazon.pipeline.stage.modifyScalingProcessStage","spinnaker.amazon.pipeline.stage.aws.resizeAsgStage","spinnaker.amazon.pipeline.stage.scaleDownClusterStage","spinnaker.amazon.pipeline.stage.aws.shrinkClusterStage","spinnaker.amazon.pipeline.stage.tagImageStage","spinnaker.amazon.serverGroup.details","spinnaker.amazon.common","spinnaker.amazon.serverGroup.transformer","spinnaker.amazon.instanceType.service","spinnaker.amazon.loadBalancer","spinnaker.amazon.function","spinnaker.amazon.instance.details.controller","spinnaker.amazon.securityGroup","spinnaker.amazon.subnet.renderer","spinnaker.amazon.vpc","spinnaker.amazon.search.searchResultFormatter","spinnaker.amazon.pipeline.stages.deployCloudFormationStage","spinnaker.amazon.cloudformation.entry.component","spinnaker.amazon.cloudformation.changetset.info.component","spinnaker.amazon.deployCloudFormation.service","spinnaker.application.instanceStatus.component","spinnaker.application.instanceTags.component","spinnaker.application.instanceSecurityGroups.component","spinnaker.application.instanceDns.component","spinnaker.application.amazonInstanceInformation.component","spinnaker.amazon.pipeline.stage.Aws.LambdaDeleteStage","spinnaker.amazon.pipeline.stage.Aws.LambdaDeploymentStage","spinnaker.amazon.pipeline.stage.Aws.LambdaInvokeStage","spinnaker.amazon.pipeline.stage.Aws.LambdaUpdateCodeStage","spinnaker.amazon.pipeline.stage.Aws.LambdaTrafficRoutingStage"]).config((()=>{V.registerProvider("aws",{name:"Amazon",adHocInfrastructureWritesEnabled:Sn.adHocInfraWritesEnabled,logo:{path:"amazon.logo352d4e042476837f.svg"},image:{reader:Qn},serverGroup:{transformer:"awsServerGroupTransformer",detailsActions:fl,detailsGetter:yl,detailsSections:[Kl,Jl,Ql,eo,ao,ro,go,uo,co,mo,ho,so,_l,io],CloneServerGroupModal:cl,commandBuilder:"awsServerGroupCommandBuilder",configurationService:"awsServerGroupConfigurationService",scalingActivitiesEnabled:!0,TargetTrackingChart:Sl,UpsertStepPolicyModal:Rl,UpsertTargetTrackingModal:xl},instance:{instanceTypeService:"awsInstanceTypeService",detailsTemplateUrl:"amazon/src/instance/details/instanceDetails.html",detailsController:"awsInstanceDetailsCtrl"},loadBalancer:{transformer:Nr,detailsTemplateUrl:"amazon/src/loadBalancer/details/loadBalancerDetails.html",detailsController:"awsLoadBalancerDetailsCtrl",CreateLoadBalancerModal:gi,targetGroupDetailsTemplateUrl:"amazon/src/loadBalancer/details/targetGroupDetails.html",targetGroupDetailsController:"awsTargetGroupDetailsCtrl",ClusterContainer:Er,LoadBalancersTag:kr},function:{details:Xn,CreateFunctionModal:Wn,transformer:Gn},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 &rarr; Instance</dt>\n <dd ng-repeat="listener in ctrl.loadBalancer.elb.listenerDescriptions">\n {{listener.listener.protocol}}:{{listener.listener.loadBalancerPort}} &rarr;\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}} &rarr;</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}} &rarr; {{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{bo as AMAZON_MODULE,Sn as AWSProviderSettings,yo as AWS_SERVER_GROUP_CONFIGURATION_SERVICE,_l as AdvancedSettingsDetailsSection,Ml as AlarmConfigurer,Jl as AmazonCapacityDetailsSection,$r as AmazonCertificateReader,Pr as AmazonCertificateSelectField,Xn as AmazonFunctionDetails,ks as AmazonImageSelectInput,Kl as AmazonInfoDetailsSection,mr as AmazonInstanceWriter,gi as AmazonLoadBalancerChoiceModal,Er as AmazonLoadBalancerClusterContainer,wr as AmazonLoadBalancerDataUtils,kr as AmazonLoadBalancersTag,pl as AmazonResizeServerGroupModal,Rl as AmazonUpsertScalingPolicyModal,xl as AmazonUpsertTargetTrackingModal,Gn as AwsFunctionTransformer,Nr as AwsLoadBalancerTransformer,dl as AwsModalFooter,Zn as AwsReactInject,_n as AwsReactInjector,vo as AwsServerGroupConfigurationService,Bl as COMPARATORS,Wn as CreateLambdaFunction,Ol as CreateScalingPolicyButton,bl as DateLineChart,kl as DimensionsEditor,jn as FunctionActions,$n as FunctionBasicInformation,Ql as HealthDetailsSection,ws as IPRangeRules,fr as InstanceDns,ur as InstanceInformation,vr as InstanceStatus,eo as InstancesDistributionDetailsSection,fo as KeyPairsReader,ao as LaunchConfigDetailsSection,ro as LaunchTemplateDetailsSection,pi as LoadBalancerTypes,io as LogsDetailsSection,El as MetricAlarmChart,Tl as MetricSelector,so as PackageDetailsSection,Pl as PolicyTypeSelectionModal,co as ScalingPoliciesDetailsSection,Dl as ScalingPolicyAdditionalSettings,Zl as ScalingPolicySummary,Vl as ScalingPolicyWriter,uo as ScalingProcessesDetailsSection,mo as ScheduledActionsDetailsSection,el as SecurityGroupSelector,go as SecurityGroupsDetailsSection,ll as ServerGroupAdvancedSettings,nl as ServerGroupAdvancedSettingsCommon,Ts as ServerGroupBasicSettings,As as ServerGroupCapacity,Ys as ServerGroupInstanceType,Qs as ServerGroupLoadBalancers,al as ServerGroupSecurityGroups,tl as ServerGroupSecurityGroupsRemoved,Xs as ServerGroupZones,Ll as StepPolicyAction,Wl as StepPolicySummary,Yr as SubnetSelectField,Kr as SubnetSelectInput,ho as TagsDetailsSection,br as TargetGroup,Ir as TargetGroupDetails,Gl as TargetMetricFields,Il as TargetTrackingAdditionalSettings,Sl as TargetTrackingChart,jl as TargetTrackingSummary,Un as VpcReader,hr as applyHealthCheckInfoToTargetGroups,gr as getAllTargetGroups,to as getBaseImageName};
2
2
  //# sourceMappingURL=index.js.map