| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206142071420814209142101421114212142131421414215142161421714218142191422014221142221422314224142251422614227142281422914230142311423214233142341423514236142371423814239142401424114242142431424414245142461424714248142491425014251142521425314254142551425614257142581425914260142611426214263142641426514266142671426814269142701427114272142731427414275142761427714278142791428014281142821428314284142851428614287142881428914290142911429214293142941429514296142971429814299143001430114302143031430414305143061430714308143091431014311143121431314314143151431614317143181431914320143211432214323143241432514326143271432814329143301433114332143331433414335143361433714338143391434014341143421434314344143451434614347143481434914350143511435214353143541435514356143571435814359143601436114362143631436414365143661436714368143691437014371143721437314374143751437614377143781437914380143811438214383143841438514386143871438814389143901439114392143931439414395143961439714398143991440014401144021440314404144051440614407144081440914410144111441214413144141441514416144171441814419144201442114422144231442414425144261442714428144291443014431144321443314434144351443614437144381443914440144411444214443144441444514446144471444814449144501445114452144531445414455144561445714458144591446014461144621446314464144651446614467144681446914470144711447214473144741447514476144771447814479144801448114482144831448414485144861448714488144891449014491144921449314494144951449614497144981449914500145011450214503145041450514506145071450814509145101451114512145131451414515145161451714518145191452014521145221452314524145251452614527145281452914530145311453214533145341453514536145371453814539145401454114542145431454414545145461454714548145491455014551145521455314554145551455614557145581455914560145611456214563145641456514566145671456814569145701457114572145731457414575145761457714578145791458014581145821458314584145851458614587145881458914590145911459214593145941459514596145971459814599146001460114602146031460414605146061460714608146091461014611146121461314614146151461614617146181461914620146211462214623146241462514626146271462814629146301463114632146331463414635146361463714638146391464014641146421464314644146451464614647146481464914650146511465214653146541465514656146571465814659146601466114662146631466414665146661466714668146691467014671146721467314674146751467614677146781467914680146811468214683146841468514686146871468814689146901469114692146931469414695146961469714698146991470014701147021470314704147051470614707147081470914710147111471214713147141471514716147171471814719147201472114722147231472414725147261472714728147291473014731147321473314734147351473614737147381473914740147411474214743147441474514746147471474814749147501475114752147531475414755147561475714758147591476014761147621476314764147651476614767147681476914770147711477214773147741477514776147771477814779147801478114782147831478414785147861478714788147891479014791147921479314794147951479614797147981479914800148011480214803148041480514806148071480814809148101481114812148131481414815148161481714818148191482014821148221482314824148251482614827148281482914830148311483214833148341483514836148371483814839148401484114842148431484414845148461484714848148491485014851148521485314854148551485614857148581485914860148611486214863148641486514866148671486814869148701487114872148731487414875148761487714878148791488014881148821488314884148851488614887148881488914890148911489214893148941489514896148971489814899149001490114902149031490414905149061490714908149091491014911149121491314914149151491614917149181491914920149211492214923149241492514926149271492814929149301493114932149331493414935149361493714938149391494014941149421494314944149451494614947149481494914950149511495214953149541495514956149571495814959149601496114962149631496414965149661496714968149691497014971149721497314974149751497614977149781497914980149811498214983149841498514986149871498814989149901499114992149931499414995149961499714998149991500015001150021500315004150051500615007150081500915010150111501215013150141501515016150171501815019150201502115022150231502415025150261502715028150291503015031150321503315034150351503615037150381503915040150411504215043150441504515046150471504815049150501505115052150531505415055150561505715058150591506015061150621506315064150651506615067150681506915070150711507215073150741507515076150771507815079150801508115082150831508415085150861508715088150891509015091150921509315094150951509615097150981509915100151011510215103151041510515106151071510815109151101511115112151131511415115151161511715118151191512015121151221512315124151251512615127151281512915130151311513215133151341513515136151371513815139151401514115142151431514415145151461514715148151491515015151151521515315154151551515615157151581515915160151611516215163151641516515166151671516815169151701517115172151731517415175151761517715178151791518015181151821518315184151851518615187151881518915190151911519215193151941519515196151971519815199152001520115202152031520415205152061520715208152091521015211152121521315214152151521615217152181521915220152211522215223152241522515226152271522815229152301523115232152331523415235152361523715238152391524015241152421524315244152451524615247152481524915250152511525215253152541525515256152571525815259152601526115262152631526415265152661526715268152691527015271152721527315274152751527615277152781527915280152811528215283152841528515286152871528815289152901529115292152931529415295152961529715298152991530015301153021530315304153051530615307153081530915310153111531215313153141531515316153171531815319153201532115322153231532415325153261532715328153291533015331153321533315334153351533615337153381533915340153411534215343153441534515346153471534815349153501535115352153531535415355153561535715358153591536015361153621536315364153651536615367153681536915370153711537215373153741537515376153771537815379153801538115382153831538415385153861538715388153891539015391153921539315394153951539615397153981539915400154011540215403154041540515406154071540815409154101541115412154131541415415154161541715418154191542015421154221542315424154251542615427154281542915430154311543215433154341543515436154371543815439154401544115442154431544415445154461544715448154491545015451154521545315454154551545615457154581545915460154611546215463154641546515466154671546815469154701547115472154731547415475154761547715478154791548015481154821548315484154851548615487154881548915490154911549215493154941549515496154971549815499155001550115502155031550415505155061550715508155091551015511155121551315514155151551615517155181551915520155211552215523155241552515526155271552815529155301553115532155331553415535155361553715538155391554015541155421554315544155451554615547155481554915550155511555215553155541555515556155571555815559155601556115562155631556415565155661556715568155691557015571155721557315574155751557615577155781557915580155811558215583155841558515586155871558815589155901559115592155931559415595155961559715598155991560015601156021560315604156051560615607156081560915610156111561215613156141561515616156171561815619156201562115622156231562415625156261562715628156291563015631156321563315634156351563615637156381563915640156411564215643156441564515646156471564815649156501565115652156531565415655156561565715658156591566015661156621566315664156651566615667156681566915670156711567215673156741567515676156771567815679156801568115682156831568415685156861568715688156891569015691156921569315694156951569615697156981569915700157011570215703157041570515706157071570815709157101571115712157131571415715157161571715718157191572015721157221572315724157251572615727157281572915730157311573215733157341573515736157371573815739157401574115742157431574415745157461574715748157491575015751157521575315754157551575615757157581575915760157611576215763157641576515766157671576815769157701577115772157731577415775157761577715778157791578015781157821578315784157851578615787157881578915790157911579215793157941579515796157971579815799158001580115802158031580415805158061580715808158091581015811158121581315814158151581615817158181581915820158211582215823158241582515826158271582815829158301583115832158331583415835158361583715838158391584015841158421584315844158451584615847158481584915850158511585215853158541585515856158571585815859158601586115862158631586415865158661586715868158691587015871158721587315874158751587615877158781587915880158811588215883158841588515886158871588815889158901589115892158931589415895158961589715898158991590015901159021590315904159051590615907159081590915910159111591215913159141591515916159171591815919159201592115922159231592415925159261592715928159291593015931159321593315934159351593615937159381593915940159411594215943159441594515946159471594815949159501595115952159531595415955159561595715958159591596015961159621596315964159651596615967159681596915970159711597215973159741597515976159771597815979159801598115982159831598415985159861598715988159891599015991159921599315994159951599615997159981599916000160011600216003160041600516006160071600816009160101601116012160131601416015160161601716018160191602016021160221602316024160251602616027160281602916030160311603216033160341603516036160371603816039160401604116042160431604416045160461604716048160491605016051160521605316054160551605616057160581605916060160611606216063160641606516066160671606816069160701607116072160731607416075160761607716078160791608016081160821608316084160851608616087160881608916090160911609216093160941609516096160971609816099161001610116102161031610416105161061610716108161091611016111161121611316114161151611616117161181611916120161211612216123161241612516126161271612816129161301613116132161331613416135161361613716138161391614016141161421614316144161451614616147161481614916150161511615216153161541615516156161571615816159161601616116162161631616416165161661616716168161691617016171161721617316174161751617616177161781617916180161811618216183161841618516186161871618816189161901619116192161931619416195161961619716198161991620016201162021620316204162051620616207162081620916210162111621216213162141621516216162171621816219162201622116222162231622416225162261622716228162291623016231162321623316234162351623616237162381623916240162411624216243162441624516246162471624816249162501625116252162531625416255162561625716258162591626016261162621626316264162651626616267162681626916270162711627216273162741627516276162771627816279162801628116282162831628416285162861628716288162891629016291162921629316294162951629616297162981629916300163011630216303163041630516306163071630816309163101631116312163131631416315163161631716318163191632016321163221632316324163251632616327163281632916330163311633216333163341633516336163371633816339163401634116342163431634416345163461634716348163491635016351163521635316354163551635616357163581635916360163611636216363163641636516366163671636816369163701637116372163731637416375163761637716378163791638016381163821638316384163851638616387163881638916390163911639216393163941639516396163971639816399164001640116402164031640416405164061640716408164091641016411164121641316414164151641616417164181641916420164211642216423164241642516426164271642816429164301643116432164331643416435164361643716438164391644016441164421644316444164451644616447164481644916450164511645216453164541645516456164571645816459164601646116462164631646416465164661646716468164691647016471164721647316474164751647616477164781647916480164811648216483164841648516486164871648816489164901649116492164931649416495164961649716498164991650016501165021650316504165051650616507165081650916510165111651216513165141651516516165171651816519165201652116522165231652416525165261652716528165291653016531165321653316534165351653616537165381653916540165411654216543165441654516546165471654816549165501655116552165531655416555165561655716558165591656016561165621656316564165651656616567165681656916570165711657216573165741657516576165771657816579165801658116582165831658416585165861658716588165891659016591165921659316594165951659616597165981659916600166011660216603166041660516606166071660816609166101661116612166131661416615166161661716618166191662016621166221662316624166251662616627166281662916630166311663216633166341663516636166371663816639166401664116642166431664416645166461664716648166491665016651166521665316654166551665616657166581665916660166611666216663166641666516666166671666816669166701667116672166731667416675166761667716678166791668016681166821668316684166851668616687166881668916690166911669216693166941669516696166971669816699167001670116702167031670416705167061670716708167091671016711167121671316714167151671616717167181671916720167211672216723167241672516726167271672816729167301673116732167331673416735167361673716738167391674016741167421674316744167451674616747167481674916750167511675216753167541675516756167571675816759167601676116762167631676416765167661676716768167691677016771167721677316774167751677616777167781677916780167811678216783167841678516786167871678816789167901679116792167931679416795167961679716798167991680016801168021680316804168051680616807168081680916810168111681216813168141681516816168171681816819168201682116822168231682416825168261682716828168291683016831168321683316834168351683616837168381683916840168411684216843168441684516846168471684816849168501685116852168531685416855168561685716858168591686016861168621686316864168651686616867168681686916870168711687216873168741687516876168771687816879168801688116882168831688416885168861688716888168891689016891168921689316894168951689616897168981689916900169011690216903169041690516906169071690816909169101691116912169131691416915169161691716918169191692016921169221692316924169251692616927169281692916930169311693216933169341693516936169371693816939169401694116942169431694416945169461694716948169491695016951169521695316954169551695616957169581695916960169611696216963169641696516966169671696816969169701697116972169731697416975169761697716978169791698016981169821698316984169851698616987169881698916990169911699216993169941699516996169971699816999170001700117002170031700417005170061700717008170091701017011170121701317014170151701617017170181701917020170211702217023170241702517026170271702817029170301703117032170331703417035170361703717038170391704017041170421704317044170451704617047170481704917050170511705217053170541705517056170571705817059170601706117062170631706417065170661706717068170691707017071170721707317074170751707617077170781707917080170811708217083170841708517086170871708817089170901709117092170931709417095170961709717098170991710017101171021710317104171051710617107171081710917110171111711217113171141711517116171171711817119171201712117122171231712417125171261712717128171291713017131171321713317134171351713617137171381713917140171411714217143171441714517146171471714817149171501715117152171531715417155171561715717158171591716017161171621716317164171651716617167171681716917170171711717217173171741717517176171771717817179171801718117182171831718417185171861718717188171891719017191171921719317194171951719617197171981719917200172011720217203172041720517206172071720817209172101721117212172131721417215172161721717218172191722017221172221722317224172251722617227172281722917230172311723217233172341723517236172371723817239172401724117242172431724417245172461724717248172491725017251172521725317254172551725617257172581725917260172611726217263172641726517266172671726817269172701727117272172731727417275172761727717278172791728017281172821728317284172851728617287172881728917290172911729217293172941729517296172971729817299173001730117302173031730417305173061730717308173091731017311173121731317314173151731617317173181731917320173211732217323173241732517326173271732817329173301733117332173331733417335173361733717338173391734017341173421734317344173451734617347173481734917350173511735217353173541735517356173571735817359173601736117362173631736417365173661736717368173691737017371173721737317374173751737617377173781737917380173811738217383173841738517386173871738817389173901739117392173931739417395173961739717398173991740017401174021740317404174051740617407174081740917410174111741217413174141741517416174171741817419174201742117422174231742417425174261742717428174291743017431174321743317434174351743617437174381743917440174411744217443174441744517446174471744817449174501745117452174531745417455174561745717458174591746017461174621746317464174651746617467174681746917470174711747217473174741747517476174771747817479174801748117482174831748417485174861748717488174891749017491174921749317494174951749617497174981749917500175011750217503175041750517506175071750817509175101751117512175131751417515175161751717518175191752017521175221752317524175251752617527175281752917530175311753217533175341753517536175371753817539175401754117542175431754417545175461754717548175491755017551175521755317554175551755617557175581755917560175611756217563175641756517566175671756817569175701757117572175731757417575175761757717578175791758017581175821758317584175851758617587175881758917590175911759217593175941759517596175971759817599176001760117602176031760417605176061760717608176091761017611176121761317614176151761617617176181761917620176211762217623176241762517626176271762817629176301763117632176331763417635176361763717638176391764017641176421764317644176451764617647176481764917650176511765217653176541765517656176571765817659176601766117662176631766417665176661766717668176691767017671176721767317674176751767617677176781767917680176811768217683176841768517686176871768817689176901769117692176931769417695176961769717698176991770017701177021770317704177051770617707177081770917710177111771217713177141771517716177171771817719177201772117722177231772417725177261772717728177291773017731177321773317734177351773617737177381773917740177411774217743177441774517746177471774817749177501775117752177531775417755177561775717758177591776017761177621776317764177651776617767177681776917770177711777217773177741777517776177771777817779177801778117782177831778417785177861778717788177891779017791177921779317794177951779617797177981779917800178011780217803178041780517806178071780817809178101781117812178131781417815178161781717818178191782017821178221782317824178251782617827178281782917830178311783217833178341783517836178371783817839178401784117842178431784417845178461784717848178491785017851178521785317854178551785617857178581785917860178611786217863178641786517866178671786817869178701787117872178731787417875178761787717878178791788017881178821788317884178851788617887178881788917890178911789217893178941789517896178971789817899179001790117902179031790417905179061790717908179091791017911179121791317914179151791617917179181791917920179211792217923179241792517926179271792817929179301793117932179331793417935179361793717938179391794017941179421794317944179451794617947179481794917950179511795217953179541795517956179571795817959179601796117962179631796417965179661796717968179691797017971179721797317974179751797617977179781797917980179811798217983179841798517986179871798817989179901799117992179931799417995179961799717998179991800018001180021800318004180051800618007180081800918010180111801218013180141801518016180171801818019180201802118022180231802418025180261802718028180291803018031180321803318034180351803618037180381803918040180411804218043180441804518046180471804818049180501805118052180531805418055180561805718058180591806018061180621806318064180651806618067180681806918070180711807218073180741807518076180771807818079180801808118082180831808418085180861808718088180891809018091180921809318094180951809618097180981809918100181011810218103181041810518106181071810818109181101811118112181131811418115181161811718118181191812018121181221812318124181251812618127181281812918130181311813218133181341813518136181371813818139181401814118142181431814418145181461814718148181491815018151181521815318154181551815618157181581815918160181611816218163181641816518166181671816818169181701817118172181731817418175181761817718178181791818018181181821818318184181851818618187181881818918190181911819218193181941819518196181971819818199182001820118202182031820418205182061820718208182091821018211182121821318214182151821618217182181821918220182211822218223182241822518226182271822818229182301823118232182331823418235182361823718238182391824018241182421824318244182451824618247182481824918250182511825218253182541825518256182571825818259182601826118262182631826418265182661826718268182691827018271182721827318274182751827618277182781827918280182811828218283182841828518286182871828818289182901829118292182931829418295182961829718298182991830018301183021830318304183051830618307183081830918310183111831218313183141831518316183171831818319183201832118322183231832418325183261832718328183291833018331183321833318334183351833618337183381833918340183411834218343183441834518346183471834818349183501835118352183531835418355183561835718358183591836018361183621836318364183651836618367183681836918370183711837218373183741837518376183771837818379183801838118382183831838418385183861838718388183891839018391183921839318394183951839618397183981839918400184011840218403184041840518406184071840818409184101841118412184131841418415184161841718418184191842018421184221842318424184251842618427184281842918430184311843218433184341843518436184371843818439184401844118442184431844418445184461844718448184491845018451184521845318454184551845618457184581845918460184611846218463184641846518466184671846818469184701847118472184731847418475184761847718478184791848018481184821848318484184851848618487184881848918490184911849218493184941849518496184971849818499185001850118502185031850418505185061850718508185091851018511185121851318514185151851618517185181851918520185211852218523185241852518526185271852818529185301853118532185331853418535185361853718538185391854018541185421854318544185451854618547185481854918550185511855218553185541855518556185571855818559185601856118562185631856418565185661856718568185691857018571185721857318574185751857618577185781857918580185811858218583185841858518586185871858818589185901859118592185931859418595185961859718598185991860018601186021860318604186051860618607186081860918610186111861218613186141861518616186171861818619186201862118622186231862418625186261862718628186291863018631186321863318634186351863618637186381863918640186411864218643186441864518646186471864818649186501865118652186531865418655186561865718658186591866018661186621866318664186651866618667186681866918670186711867218673186741867518676186771867818679186801868118682186831868418685186861868718688186891869018691186921869318694186951869618697186981869918700187011870218703187041870518706187071870818709187101871118712187131871418715187161871718718187191872018721187221872318724187251872618727187281872918730187311873218733187341873518736187371873818739187401874118742187431874418745187461874718748187491875018751187521875318754187551875618757187581875918760187611876218763187641876518766187671876818769187701877118772187731877418775187761877718778187791878018781187821878318784187851878618787187881878918790187911879218793187941879518796187971879818799188001880118802188031880418805188061880718808188091881018811188121881318814188151881618817188181881918820188211882218823188241882518826188271882818829188301883118832188331883418835188361883718838188391884018841188421884318844188451884618847188481884918850188511885218853188541885518856188571885818859188601886118862188631886418865188661886718868188691887018871188721887318874188751887618877188781887918880188811888218883188841888518886188871888818889188901889118892188931889418895188961889718898188991890018901189021890318904189051890618907189081890918910189111891218913189141891518916189171891818919189201892118922189231892418925189261892718928189291893018931189321893318934189351893618937189381893918940189411894218943189441894518946189471894818949189501895118952189531895418955189561895718958189591896018961189621896318964189651896618967189681896918970189711897218973189741897518976189771897818979189801898118982189831898418985189861898718988189891899018991189921899318994189951899618997189981899919000190011900219003190041900519006190071900819009190101901119012190131901419015190161901719018190191902019021190221902319024190251902619027190281902919030190311903219033190341903519036190371903819039190401904119042190431904419045190461904719048190491905019051190521905319054190551905619057190581905919060190611906219063190641906519066190671906819069190701907119072190731907419075190761907719078190791908019081190821908319084190851908619087190881908919090190911909219093190941909519096190971909819099191001910119102191031910419105191061910719108191091911019111191121911319114191151911619117191181911919120191211912219123191241912519126191271912819129191301913119132191331913419135191361913719138191391914019141191421914319144191451914619147191481914919150191511915219153191541915519156191571915819159191601916119162191631916419165191661916719168191691917019171191721917319174191751917619177191781917919180191811918219183191841918519186191871918819189191901919119192191931919419195191961919719198191991920019201192021920319204192051920619207192081920919210192111921219213192141921519216192171921819219192201922119222192231922419225192261922719228192291923019231192321923319234192351923619237192381923919240192411924219243192441924519246192471924819249192501925119252192531925419255192561925719258192591926019261192621926319264192651926619267192681926919270192711927219273192741927519276192771927819279192801928119282192831928419285192861928719288192891929019291192921929319294192951929619297192981929919300193011930219303193041930519306193071930819309193101931119312193131931419315193161931719318193191932019321193221932319324193251932619327193281932919330193311933219333193341933519336193371933819339193401934119342193431934419345193461934719348193491935019351193521935319354193551935619357193581935919360193611936219363193641936519366193671936819369193701937119372193731937419375193761937719378193791938019381193821938319384193851938619387193881938919390193911939219393193941939519396193971939819399194001940119402194031940419405194061940719408194091941019411194121941319414194151941619417194181941919420194211942219423194241942519426194271942819429194301943119432194331943419435194361943719438194391944019441194421944319444194451944619447194481944919450194511945219453194541945519456194571945819459194601946119462194631946419465194661946719468194691947019471194721947319474194751947619477194781947919480194811948219483194841948519486194871948819489194901949119492194931949419495194961949719498194991950019501195021950319504195051950619507195081950919510195111951219513195141951519516195171951819519195201952119522195231952419525195261952719528195291953019531195321953319534195351953619537195381953919540195411954219543195441954519546195471954819549195501955119552195531955419555195561955719558195591956019561195621956319564195651956619567195681956919570195711957219573195741957519576195771957819579195801958119582195831958419585195861958719588195891959019591195921959319594195951959619597195981959919600196011960219603196041960519606196071960819609196101961119612196131961419615196161961719618196191962019621196221962319624196251962619627196281962919630196311963219633196341963519636196371963819639196401964119642196431964419645196461964719648196491965019651196521965319654196551965619657196581965919660196611966219663196641966519666196671966819669196701967119672196731967419675196761967719678196791968019681196821968319684196851968619687196881968919690196911969219693196941969519696196971969819699197001970119702197031970419705197061970719708197091971019711197121971319714197151971619717197181971919720197211972219723197241972519726197271972819729197301973119732197331973419735197361973719738197391974019741197421974319744197451974619747197481974919750197511975219753197541975519756197571975819759197601976119762197631976419765197661976719768197691977019771197721977319774197751977619777197781977919780197811978219783197841978519786197871978819789197901979119792197931979419795197961979719798197991980019801198021980319804198051980619807198081980919810198111981219813198141981519816198171981819819198201982119822198231982419825198261982719828198291983019831198321983319834198351983619837198381983919840198411984219843198441984519846198471984819849198501985119852198531985419855198561985719858198591986019861198621986319864198651986619867198681986919870198711987219873198741987519876198771987819879198801988119882198831988419885198861988719888198891989019891198921989319894198951989619897198981989919900199011990219903199041990519906199071990819909199101991119912199131991419915199161991719918199191992019921199221992319924199251992619927199281992919930199311993219933199341993519936199371993819939199401994119942199431994419945199461994719948199491995019951199521995319954199551995619957199581995919960199611996219963199641996519966199671996819969199701997119972199731997419975199761997719978199791998019981199821998319984199851998619987199881998919990199911999219993199941999519996199971999819999200002000120002200032000420005200062000720008200092001020011200122001320014200152001620017200182001920020200212002220023200242002520026200272002820029200302003120032200332003420035200362003720038200392004020041200422004320044200452004620047200482004920050200512005220053200542005520056200572005820059200602006120062200632006420065200662006720068200692007020071200722007320074200752007620077200782007920080200812008220083200842008520086200872008820089200902009120092200932009420095200962009720098200992010020101201022010320104201052010620107201082010920110201112011220113201142011520116201172011820119201202012120122201232012420125201262012720128201292013020131201322013320134201352013620137201382013920140201412014220143201442014520146201472014820149201502015120152201532015420155201562015720158201592016020161201622016320164201652016620167201682016920170201712017220173201742017520176201772017820179201802018120182201832018420185201862018720188201892019020191201922019320194201952019620197201982019920200202012020220203202042020520206202072020820209202102021120212202132021420215202162021720218202192022020221202222022320224202252022620227202282022920230202312023220233202342023520236202372023820239202402024120242202432024420245202462024720248202492025020251202522025320254202552025620257202582025920260202612026220263202642026520266202672026820269202702027120272202732027420275202762027720278202792028020281202822028320284202852028620287202882028920290202912029220293202942029520296202972029820299203002030120302203032030420305203062030720308203092031020311203122031320314203152031620317203182031920320203212032220323203242032520326203272032820329203302033120332203332033420335203362033720338203392034020341203422034320344203452034620347203482034920350203512035220353203542035520356203572035820359203602036120362203632036420365203662036720368203692037020371203722037320374203752037620377203782037920380203812038220383203842038520386203872038820389203902039120392203932039420395203962039720398203992040020401204022040320404204052040620407204082040920410204112041220413204142041520416204172041820419204202042120422204232042420425204262042720428204292043020431204322043320434204352043620437204382043920440204412044220443204442044520446204472044820449204502045120452204532045420455204562045720458204592046020461204622046320464204652046620467204682046920470204712047220473204742047520476204772047820479204802048120482204832048420485204862048720488204892049020491204922049320494204952049620497204982049920500205012050220503205042050520506205072050820509205102051120512205132051420515205162051720518205192052020521205222052320524205252052620527205282052920530205312053220533205342053520536205372053820539205402054120542205432054420545205462054720548205492055020551205522055320554205552055620557205582055920560205612056220563205642056520566205672056820569205702057120572205732057420575205762057720578205792058020581205822058320584205852058620587205882058920590205912059220593205942059520596205972059820599206002060120602206032060420605206062060720608206092061020611206122061320614206152061620617206182061920620206212062220623206242062520626206272062820629206302063120632206332063420635206362063720638206392064020641206422064320644206452064620647206482064920650206512065220653206542065520656206572065820659206602066120662206632066420665206662066720668206692067020671206722067320674206752067620677206782067920680206812068220683206842068520686206872068820689206902069120692206932069420695206962069720698206992070020701207022070320704207052070620707207082070920710207112071220713207142071520716207172071820719207202072120722207232072420725207262072720728207292073020731207322073320734207352073620737207382073920740207412074220743207442074520746207472074820749207502075120752207532075420755207562075720758207592076020761207622076320764207652076620767207682076920770207712077220773207742077520776207772077820779207802078120782207832078420785207862078720788207892079020791207922079320794207952079620797207982079920800208012080220803208042080520806208072080820809208102081120812208132081420815208162081720818208192082020821208222082320824208252082620827208282082920830208312083220833208342083520836208372083820839208402084120842208432084420845208462084720848208492085020851208522085320854208552085620857208582085920860208612086220863208642086520866208672086820869208702087120872208732087420875208762087720878208792088020881208822088320884208852088620887208882088920890208912089220893208942089520896208972089820899209002090120902209032090420905209062090720908209092091020911209122091320914209152091620917209182091920920209212092220923209242092520926209272092820929209302093120932209332093420935209362093720938209392094020941209422094320944209452094620947209482094920950209512095220953209542095520956209572095820959209602096120962209632096420965209662096720968209692097020971209722097320974209752097620977209782097920980209812098220983209842098520986209872098820989209902099120992209932099420995209962099720998209992100021001210022100321004210052100621007210082100921010210112101221013210142101521016210172101821019210202102121022210232102421025210262102721028210292103021031210322103321034210352103621037210382103921040210412104221043210442104521046210472104821049210502105121052210532105421055210562105721058210592106021061210622106321064210652106621067210682106921070210712107221073210742107521076210772107821079210802108121082210832108421085210862108721088210892109021091210922109321094210952109621097210982109921100211012110221103211042110521106211072110821109211102111121112211132111421115211162111721118211192112021121211222112321124211252112621127211282112921130211312113221133211342113521136211372113821139211402114121142211432114421145211462114721148211492115021151211522115321154211552115621157211582115921160211612116221163211642116521166211672116821169211702117121172211732117421175211762117721178211792118021181211822118321184211852118621187211882118921190211912119221193211942119521196211972119821199212002120121202212032120421205212062120721208212092121021211212122121321214212152121621217212182121921220212212122221223212242122521226212272122821229212302123121232212332123421235212362123721238212392124021241212422124321244212452124621247212482124921250212512125221253212542125521256212572125821259212602126121262212632126421265212662126721268212692127021271212722127321274212752127621277212782127921280212812128221283212842128521286212872128821289212902129121292212932129421295212962129721298212992130021301213022130321304213052130621307213082130921310213112131221313213142131521316213172131821319213202132121322213232132421325213262132721328213292133021331213322133321334213352133621337213382133921340213412134221343213442134521346213472134821349213502135121352213532135421355213562135721358213592136021361213622136321364213652136621367213682136921370213712137221373213742137521376213772137821379213802138121382213832138421385213862138721388213892139021391213922139321394213952139621397213982139921400214012140221403214042140521406214072140821409214102141121412214132141421415214162141721418214192142021421214222142321424214252142621427214282142921430214312143221433214342143521436214372143821439214402144121442214432144421445214462144721448214492145021451214522145321454214552145621457214582145921460214612146221463214642146521466214672146821469214702147121472214732147421475214762147721478214792148021481214822148321484214852148621487214882148921490214912149221493214942149521496214972149821499215002150121502215032150421505215062150721508215092151021511215122151321514215152151621517215182151921520215212152221523215242152521526215272152821529215302153121532215332153421535215362153721538215392154021541215422154321544215452154621547215482154921550215512155221553215542155521556215572155821559215602156121562215632156421565215662156721568215692157021571215722157321574215752157621577215782157921580215812158221583215842158521586215872158821589215902159121592215932159421595215962159721598215992160021601216022160321604216052160621607216082160921610216112161221613216142161521616216172161821619216202162121622216232162421625216262162721628216292163021631216322163321634216352163621637216382163921640216412164221643216442164521646216472164821649216502165121652216532165421655216562165721658216592166021661216622166321664216652166621667216682166921670216712167221673216742167521676216772167821679216802168121682216832168421685216862168721688216892169021691216922169321694216952169621697216982169921700217012170221703217042170521706217072170821709217102171121712217132171421715217162171721718217192172021721217222172321724217252172621727217282172921730217312173221733217342173521736217372173821739217402174121742217432174421745217462174721748217492175021751217522175321754217552175621757217582175921760217612176221763217642176521766217672176821769217702177121772217732177421775217762177721778217792178021781217822178321784217852178621787217882178921790217912179221793217942179521796217972179821799218002180121802218032180421805218062180721808218092181021811218122181321814218152181621817218182181921820218212182221823218242182521826218272182821829218302183121832218332183421835218362183721838218392184021841218422184321844218452184621847218482184921850218512185221853218542185521856218572185821859218602186121862218632186421865218662186721868218692187021871218722187321874218752187621877218782187921880218812188221883218842188521886218872188821889218902189121892218932189421895218962189721898218992190021901219022190321904219052190621907219082190921910219112191221913219142191521916219172191821919219202192121922219232192421925219262192721928219292193021931219322193321934219352193621937219382193921940219412194221943219442194521946219472194821949219502195121952219532195421955219562195721958219592196021961219622196321964219652196621967219682196921970219712197221973219742197521976219772197821979219802198121982219832198421985219862198721988219892199021991219922199321994219952199621997219982199922000220012200222003220042200522006220072200822009220102201122012220132201422015220162201722018220192202022021220222202322024220252202622027220282202922030220312203222033220342203522036220372203822039220402204122042220432204422045220462204722048220492205022051220522205322054220552205622057220582205922060220612206222063220642206522066220672206822069220702207122072220732207422075220762207722078220792208022081220822208322084220852208622087220882208922090220912209222093220942209522096220972209822099221002210122102221032210422105221062210722108221092211022111221122211322114221152211622117221182211922120221212212222123221242212522126221272212822129221302213122132221332213422135221362213722138221392214022141221422214322144221452214622147221482214922150221512215222153221542215522156221572215822159221602216122162221632216422165221662216722168221692217022171221722217322174221752217622177221782217922180221812218222183221842218522186221872218822189221902219122192221932219422195221962219722198221992220022201222022220322204222052220622207222082220922210222112221222213222142221522216222172221822219222202222122222222232222422225222262222722228222292223022231222322223322234222352223622237222382223922240222412224222243222442224522246222472224822249222502225122252222532225422255222562225722258222592226022261222622226322264222652226622267222682226922270222712227222273222742227522276222772227822279222802228122282222832228422285222862228722288222892229022291222922229322294222952229622297222982229922300223012230222303223042230522306223072230822309223102231122312223132231422315223162231722318223192232022321223222232322324223252232622327223282232922330223312233222333223342233522336223372233822339223402234122342223432234422345223462234722348223492235022351223522235322354223552235622357223582235922360223612236222363223642236522366223672236822369223702237122372223732237422375223762237722378223792238022381223822238322384223852238622387223882238922390223912239222393223942239522396223972239822399224002240122402224032240422405224062240722408224092241022411224122241322414224152241622417224182241922420224212242222423224242242522426224272242822429224302243122432224332243422435224362243722438224392244022441224422244322444224452244622447224482244922450224512245222453224542245522456224572245822459224602246122462224632246422465224662246722468224692247022471224722247322474224752247622477224782247922480224812248222483224842248522486224872248822489224902249122492224932249422495224962249722498224992250022501225022250322504225052250622507225082250922510225112251222513225142251522516225172251822519225202252122522225232252422525225262252722528225292253022531225322253322534225352253622537225382253922540225412254222543225442254522546225472254822549225502255122552225532255422555225562255722558225592256022561225622256322564225652256622567225682256922570225712257222573225742257522576225772257822579225802258122582225832258422585225862258722588225892259022591225922259322594225952259622597225982259922600226012260222603226042260522606226072260822609226102261122612226132261422615226162261722618226192262022621226222262322624226252262622627226282262922630226312263222633226342263522636226372263822639226402264122642226432264422645226462264722648226492265022651226522265322654226552265622657226582265922660226612266222663226642266522666226672266822669226702267122672226732267422675226762267722678226792268022681226822268322684226852268622687226882268922690226912269222693226942269522696226972269822699227002270122702227032270422705227062270722708227092271022711227122271322714227152271622717227182271922720227212272222723227242272522726227272272822729227302273122732227332273422735227362273722738227392274022741227422274322744227452274622747227482274922750227512275222753227542275522756227572275822759227602276122762227632276422765227662276722768227692277022771227722277322774227752277622777227782277922780227812278222783227842278522786227872278822789227902279122792227932279422795227962279722798227992280022801228022280322804228052280622807228082280922810228112281222813228142281522816228172281822819228202282122822228232282422825228262282722828228292283022831228322283322834228352283622837228382283922840228412284222843228442284522846228472284822849228502285122852228532285422855228562285722858228592286022861228622286322864228652286622867228682286922870228712287222873228742287522876228772287822879228802288122882228832288422885228862288722888228892289022891228922289322894228952289622897228982289922900229012290222903229042290522906229072290822909229102291122912229132291422915229162291722918229192292022921229222292322924229252292622927229282292922930229312293222933229342293522936229372293822939229402294122942229432294422945229462294722948229492295022951229522295322954229552295622957229582295922960229612296222963229642296522966229672296822969229702297122972229732297422975229762297722978229792298022981229822298322984229852298622987229882298922990229912299222993229942299522996229972299822999230002300123002230032300423005230062300723008230092301023011230122301323014230152301623017230182301923020230212302223023230242302523026230272302823029230302303123032230332303423035230362303723038230392304023041230422304323044230452304623047230482304923050230512305223053230542305523056230572305823059230602306123062230632306423065230662306723068230692307023071230722307323074230752307623077230782307923080230812308223083230842308523086230872308823089230902309123092230932309423095230962309723098230992310023101231022310323104231052310623107231082310923110231112311223113231142311523116231172311823119231202312123122231232312423125231262312723128231292313023131231322313323134231352313623137231382313923140231412314223143231442314523146231472314823149231502315123152231532315423155231562315723158231592316023161231622316323164231652316623167231682316923170231712317223173231742317523176231772317823179231802318123182231832318423185231862318723188231892319023191231922319323194231952319623197231982319923200232012320223203232042320523206232072320823209232102321123212232132321423215232162321723218232192322023221232222322323224232252322623227232282322923230232312323223233232342323523236232372323823239232402324123242232432324423245232462324723248232492325023251232522325323254232552325623257232582325923260232612326223263232642326523266232672326823269232702327123272232732327423275232762327723278232792328023281232822328323284232852328623287232882328923290232912329223293232942329523296232972329823299233002330123302233032330423305233062330723308233092331023311233122331323314233152331623317233182331923320233212332223323233242332523326233272332823329233302333123332233332333423335233362333723338233392334023341233422334323344233452334623347233482334923350233512335223353233542335523356233572335823359233602336123362233632336423365233662336723368233692337023371233722337323374233752337623377233782337923380233812338223383233842338523386233872338823389233902339123392233932339423395233962339723398233992340023401234022340323404234052340623407234082340923410234112341223413234142341523416234172341823419234202342123422234232342423425234262342723428234292343023431234322343323434234352343623437234382343923440234412344223443234442344523446234472344823449234502345123452234532345423455234562345723458234592346023461234622346323464234652346623467234682346923470234712347223473234742347523476234772347823479234802348123482234832348423485234862348723488234892349023491234922349323494234952349623497234982349923500235012350223503235042350523506235072350823509235102351123512235132351423515235162351723518235192352023521235222352323524235252352623527235282352923530235312353223533235342353523536235372353823539235402354123542235432354423545235462354723548235492355023551235522355323554235552355623557235582355923560235612356223563235642356523566235672356823569235702357123572235732357423575235762357723578235792358023581235822358323584235852358623587235882358923590235912359223593235942359523596235972359823599236002360123602236032360423605236062360723608236092361023611236122361323614236152361623617236182361923620236212362223623236242362523626236272362823629236302363123632236332363423635236362363723638236392364023641236422364323644236452364623647236482364923650236512365223653236542365523656236572365823659236602366123662236632366423665236662366723668236692367023671236722367323674236752367623677236782367923680236812368223683236842368523686236872368823689236902369123692236932369423695236962369723698236992370023701237022370323704237052370623707237082370923710237112371223713237142371523716237172371823719237202372123722237232372423725237262372723728237292373023731237322373323734237352373623737237382373923740237412374223743237442374523746237472374823749237502375123752237532375423755237562375723758237592376023761237622376323764237652376623767237682376923770237712377223773237742377523776237772377823779237802378123782237832378423785237862378723788237892379023791237922379323794237952379623797237982379923800238012380223803238042380523806238072380823809238102381123812238132381423815238162381723818238192382023821238222382323824238252382623827238282382923830238312383223833238342383523836238372383823839238402384123842238432384423845238462384723848238492385023851238522385323854238552385623857238582385923860238612386223863238642386523866238672386823869238702387123872238732387423875238762387723878238792388023881238822388323884238852388623887238882388923890238912389223893238942389523896238972389823899239002390123902239032390423905239062390723908239092391023911239122391323914239152391623917239182391923920239212392223923239242392523926239272392823929239302393123932239332393423935239362393723938239392394023941239422394323944239452394623947239482394923950239512395223953239542395523956239572395823959239602396123962239632396423965239662396723968239692397023971239722397323974239752397623977239782397923980239812398223983239842398523986239872398823989239902399123992239932399423995239962399723998239992400024001240022400324004240052400624007240082400924010240112401224013240142401524016240172401824019240202402124022240232402424025240262402724028240292403024031240322403324034240352403624037240382403924040240412404224043240442404524046240472404824049240502405124052240532405424055240562405724058240592406024061240622406324064240652406624067240682406924070240712407224073240742407524076240772407824079240802408124082240832408424085240862408724088240892409024091240922409324094240952409624097240982409924100241012410224103241042410524106241072410824109241102411124112241132411424115241162411724118241192412024121241222412324124241252412624127241282412924130241312413224133241342413524136241372413824139241402414124142241432414424145241462414724148241492415024151241522415324154241552415624157241582415924160241612416224163241642416524166241672416824169241702417124172241732417424175241762417724178241792418024181241822418324184241852418624187241882418924190241912419224193241942419524196241972419824199242002420124202242032420424205242062420724208242092421024211242122421324214242152421624217242182421924220242212422224223242242422524226242272422824229242302423124232242332423424235242362423724238242392424024241242422424324244242452424624247242482424924250242512425224253242542425524256242572425824259242602426124262242632426424265242662426724268242692427024271242722427324274242752427624277242782427924280242812428224283242842428524286242872428824289242902429124292242932429424295242962429724298242992430024301243022430324304243052430624307243082430924310243112431224313243142431524316243172431824319243202432124322243232432424325243262432724328243292433024331243322433324334243352433624337243382433924340243412434224343243442434524346243472434824349243502435124352243532435424355243562435724358243592436024361243622436324364243652436624367243682436924370243712437224373243742437524376243772437824379243802438124382243832438424385243862438724388243892439024391243922439324394243952439624397243982439924400244012440224403244042440524406244072440824409244102441124412244132441424415244162441724418244192442024421244222442324424244252442624427244282442924430244312443224433244342443524436244372443824439244402444124442244432444424445244462444724448244492445024451244522445324454244552445624457244582445924460244612446224463244642446524466244672446824469244702447124472244732447424475244762447724478244792448024481244822448324484244852448624487244882448924490244912449224493244942449524496244972449824499245002450124502245032450424505245062450724508245092451024511245122451324514245152451624517245182451924520245212452224523245242452524526245272452824529245302453124532245332453424535245362453724538245392454024541245422454324544245452454624547245482454924550245512455224553245542455524556245572455824559245602456124562245632456424565245662456724568245692457024571245722457324574245752457624577245782457924580245812458224583245842458524586245872458824589245902459124592245932459424595245962459724598245992460024601246022460324604246052460624607246082460924610246112461224613246142461524616246172461824619246202462124622246232462424625246262462724628246292463024631246322463324634246352463624637246382463924640246412464224643246442464524646246472464824649246502465124652246532465424655246562465724658246592466024661246622466324664246652466624667246682466924670246712467224673246742467524676246772467824679246802468124682246832468424685246862468724688246892469024691246922469324694246952469624697246982469924700247012470224703247042470524706247072470824709247102471124712247132471424715247162471724718247192472024721247222472324724247252472624727247282472924730247312473224733247342473524736247372473824739247402474124742247432474424745247462474724748247492475024751247522475324754247552475624757247582475924760247612476224763247642476524766247672476824769247702477124772247732477424775247762477724778247792478024781247822478324784247852478624787247882478924790247912479224793247942479524796247972479824799248002480124802248032480424805248062480724808248092481024811248122481324814248152481624817248182481924820248212482224823248242482524826248272482824829248302483124832248332483424835248362483724838248392484024841248422484324844248452484624847248482484924850248512485224853248542485524856248572485824859248602486124862248632486424865248662486724868248692487024871248722487324874248752487624877248782487924880248812488224883248842488524886248872488824889248902489124892248932489424895248962489724898248992490024901249022490324904249052490624907249082490924910249112491224913249142491524916249172491824919249202492124922249232492424925249262492724928249292493024931249322493324934249352493624937249382493924940249412494224943249442494524946249472494824949249502495124952249532495424955249562495724958249592496024961249622496324964249652496624967249682496924970249712497224973249742497524976249772497824979249802498124982249832498424985249862498724988249892499024991249922499324994249952499624997249982499925000250012500225003250042500525006250072500825009250102501125012250132501425015250162501725018250192502025021250222502325024250252502625027250282502925030250312503225033250342503525036250372503825039250402504125042250432504425045250462504725048250492505025051250522505325054250552505625057250582505925060250612506225063250642506525066250672506825069250702507125072250732507425075250762507725078250792508025081250822508325084250852508625087250882508925090250912509225093250942509525096250972509825099251002510125102251032510425105251062510725108251092511025111251122511325114251152511625117251182511925120251212512225123251242512525126251272512825129251302513125132251332513425135251362513725138251392514025141251422514325144251452514625147251482514925150251512515225153251542515525156251572515825159251602516125162251632516425165251662516725168251692517025171251722517325174251752517625177251782517925180251812518225183251842518525186251872518825189251902519125192251932519425195251962519725198251992520025201252022520325204252052520625207252082520925210252112521225213252142521525216252172521825219252202522125222252232522425225252262522725228252292523025231252322523325234252352523625237252382523925240252412524225243252442524525246252472524825249252502525125252252532525425255252562525725258252592526025261252622526325264252652526625267252682526925270252712527225273252742527525276252772527825279252802528125282252832528425285252862528725288252892529025291252922529325294252952529625297252982529925300253012530225303253042530525306253072530825309253102531125312253132531425315253162531725318253192532025321253222532325324253252532625327253282532925330253312533225333253342533525336253372533825339253402534125342253432534425345253462534725348253492535025351253522535325354253552535625357253582535925360253612536225363253642536525366253672536825369253702537125372253732537425375253762537725378253792538025381253822538325384253852538625387253882538925390253912539225393253942539525396253972539825399254002540125402254032540425405254062540725408254092541025411254122541325414254152541625417254182541925420254212542225423254242542525426254272542825429254302543125432254332543425435254362543725438254392544025441254422544325444254452544625447254482544925450254512545225453254542545525456254572545825459254602546125462254632546425465254662546725468254692547025471254722547325474254752547625477254782547925480254812548225483254842548525486254872548825489254902549125492254932549425495254962549725498254992550025501255022550325504255052550625507255082550925510255112551225513255142551525516255172551825519255202552125522255232552425525255262552725528255292553025531255322553325534255352553625537255382553925540255412554225543255442554525546255472554825549255502555125552255532555425555255562555725558255592556025561255622556325564255652556625567255682556925570255712557225573255742557525576255772557825579255802558125582255832558425585255862558725588255892559025591255922559325594255952559625597255982559925600256012560225603256042560525606256072560825609256102561125612256132561425615256162561725618256192562025621256222562325624256252562625627256282562925630256312563225633256342563525636256372563825639256402564125642256432564425645256462564725648256492565025651256522565325654256552565625657256582565925660256612566225663256642566525666256672566825669256702567125672256732567425675256762567725678256792568025681256822568325684256852568625687256882568925690256912569225693256942569525696256972569825699257002570125702257032570425705257062570725708257092571025711257122571325714257152571625717257182571925720257212572225723257242572525726257272572825729257302573125732257332573425735257362573725738257392574025741257422574325744257452574625747257482574925750257512575225753257542575525756257572575825759257602576125762257632576425765257662576725768257692577025771257722577325774257752577625777257782577925780257812578225783257842578525786257872578825789257902579125792257932579425795257962579725798257992580025801258022580325804258052580625807258082580925810258112581225813258142581525816258172581825819258202582125822258232582425825258262582725828258292583025831258322583325834258352583625837258382583925840258412584225843258442584525846258472584825849258502585125852258532585425855258562585725858258592586025861258622586325864258652586625867258682586925870258712587225873258742587525876258772587825879258802588125882258832588425885258862588725888258892589025891258922589325894258952589625897258982589925900259012590225903259042590525906259072590825909259102591125912259132591425915259162591725918259192592025921259222592325924259252592625927259282592925930259312593225933259342593525936259372593825939259402594125942259432594425945259462594725948259492595025951259522595325954259552595625957259582595925960259612596225963259642596525966259672596825969259702597125972259732597425975259762597725978259792598025981259822598325984259852598625987259882598925990259912599225993259942599525996259972599825999260002600126002260032600426005260062600726008260092601026011260122601326014260152601626017260182601926020260212602226023260242602526026260272602826029260302603126032260332603426035260362603726038260392604026041260422604326044260452604626047260482604926050260512605226053260542605526056260572605826059260602606126062260632606426065260662606726068260692607026071260722607326074260752607626077260782607926080260812608226083260842608526086260872608826089260902609126092260932609426095260962609726098260992610026101261022610326104261052610626107261082610926110261112611226113261142611526116261172611826119261202612126122261232612426125261262612726128261292613026131261322613326134261352613626137261382613926140261412614226143261442614526146261472614826149261502615126152261532615426155261562615726158261592616026161261622616326164261652616626167261682616926170261712617226173261742617526176261772617826179261802618126182261832618426185261862618726188261892619026191261922619326194261952619626197261982619926200262012620226203262042620526206262072620826209262102621126212262132621426215262162621726218262192622026221262222622326224262252622626227262282622926230262312623226233262342623526236262372623826239262402624126242262432624426245262462624726248262492625026251262522625326254262552625626257262582625926260262612626226263262642626526266262672626826269262702627126272262732627426275262762627726278262792628026281262822628326284262852628626287262882628926290262912629226293262942629526296262972629826299263002630126302263032630426305263062630726308263092631026311263122631326314263152631626317263182631926320263212632226323263242632526326263272632826329263302633126332263332633426335263362633726338263392634026341263422634326344263452634626347263482634926350263512635226353263542635526356263572635826359263602636126362263632636426365263662636726368263692637026371263722637326374263752637626377263782637926380263812638226383263842638526386263872638826389263902639126392263932639426395263962639726398263992640026401264022640326404264052640626407264082640926410264112641226413264142641526416264172641826419264202642126422264232642426425264262642726428264292643026431264322643326434264352643626437264382643926440264412644226443264442644526446264472644826449264502645126452264532645426455264562645726458264592646026461264622646326464264652646626467264682646926470264712647226473264742647526476264772647826479264802648126482264832648426485264862648726488264892649026491264922649326494264952649626497264982649926500265012650226503265042650526506265072650826509265102651126512265132651426515265162651726518265192652026521265222652326524265252652626527265282652926530265312653226533265342653526536265372653826539265402654126542265432654426545265462654726548265492655026551265522655326554265552655626557265582655926560265612656226563265642656526566265672656826569265702657126572265732657426575265762657726578265792658026581265822658326584265852658626587265882658926590265912659226593265942659526596265972659826599266002660126602266032660426605266062660726608266092661026611266122661326614266152661626617266182661926620266212662226623266242662526626266272662826629266302663126632266332663426635266362663726638266392664026641266422664326644266452664626647266482664926650266512665226653266542665526656266572665826659266602666126662266632666426665266662666726668266692667026671266722667326674266752667626677266782667926680266812668226683266842668526686266872668826689266902669126692266932669426695266962669726698266992670026701267022670326704267052670626707267082670926710267112671226713267142671526716267172671826719267202672126722267232672426725267262672726728267292673026731267322673326734267352673626737267382673926740267412674226743267442674526746267472674826749267502675126752267532675426755267562675726758267592676026761267622676326764267652676626767267682676926770267712677226773267742677526776267772677826779267802678126782267832678426785267862678726788267892679026791267922679326794267952679626797267982679926800268012680226803268042680526806268072680826809268102681126812268132681426815268162681726818268192682026821268222682326824268252682626827268282682926830268312683226833268342683526836268372683826839268402684126842268432684426845268462684726848268492685026851268522685326854268552685626857268582685926860268612686226863268642686526866268672686826869268702687126872268732687426875268762687726878268792688026881268822688326884268852688626887268882688926890268912689226893268942689526896268972689826899269002690126902269032690426905269062690726908269092691026911269122691326914269152691626917269182691926920269212692226923269242692526926269272692826929269302693126932269332693426935269362693726938269392694026941269422694326944269452694626947269482694926950269512695226953269542695526956269572695826959269602696126962269632696426965269662696726968269692697026971269722697326974269752697626977269782697926980269812698226983269842698526986269872698826989269902699126992269932699426995269962699726998269992700027001270022700327004270052700627007270082700927010270112701227013270142701527016270172701827019270202702127022270232702427025270262702727028270292703027031270322703327034270352703627037270382703927040270412704227043270442704527046270472704827049270502705127052270532705427055270562705727058270592706027061270622706327064270652706627067270682706927070270712707227073270742707527076270772707827079270802708127082270832708427085270862708727088270892709027091270922709327094270952709627097270982709927100271012710227103271042710527106271072710827109271102711127112271132711427115271162711727118271192712027121271222712327124271252712627127271282712927130271312713227133271342713527136271372713827139271402714127142271432714427145271462714727148271492715027151271522715327154271552715627157271582715927160271612716227163271642716527166271672716827169271702717127172271732717427175271762717727178271792718027181271822718327184271852718627187271882718927190271912719227193271942719527196271972719827199272002720127202272032720427205272062720727208272092721027211272122721327214272152721627217272182721927220272212722227223272242722527226272272722827229272302723127232272332723427235272362723727238272392724027241272422724327244272452724627247272482724927250272512725227253272542725527256272572725827259272602726127262272632726427265272662726727268272692727027271272722727327274272752727627277272782727927280272812728227283272842728527286272872728827289272902729127292272932729427295272962729727298272992730027301273022730327304273052730627307273082730927310273112731227313273142731527316273172731827319273202732127322273232732427325273262732727328273292733027331273322733327334273352733627337273382733927340273412734227343273442734527346273472734827349273502735127352273532735427355273562735727358273592736027361273622736327364273652736627367273682736927370273712737227373273742737527376273772737827379273802738127382273832738427385273862738727388273892739027391273922739327394273952739627397273982739927400274012740227403274042740527406274072740827409274102741127412274132741427415274162741727418274192742027421274222742327424274252742627427274282742927430274312743227433274342743527436274372743827439274402744127442274432744427445274462744727448274492745027451274522745327454274552745627457274582745927460274612746227463274642746527466274672746827469274702747127472274732747427475274762747727478274792748027481274822748327484274852748627487274882748927490274912749227493274942749527496274972749827499275002750127502275032750427505275062750727508275092751027511275122751327514275152751627517275182751927520275212752227523275242752527526275272752827529275302753127532275332753427535275362753727538275392754027541275422754327544275452754627547275482754927550275512755227553275542755527556275572755827559275602756127562275632756427565275662756727568275692757027571275722757327574275752757627577275782757927580275812758227583275842758527586275872758827589275902759127592275932759427595275962759727598275992760027601276022760327604276052760627607276082760927610276112761227613276142761527616276172761827619276202762127622276232762427625276262762727628276292763027631276322763327634276352763627637276382763927640276412764227643276442764527646276472764827649276502765127652276532765427655276562765727658276592766027661276622766327664276652766627667276682766927670276712767227673276742767527676276772767827679276802768127682276832768427685276862768727688276892769027691276922769327694276952769627697276982769927700277012770227703277042770527706277072770827709277102771127712277132771427715277162771727718277192772027721277222772327724277252772627727277282772927730277312773227733277342773527736277372773827739277402774127742277432774427745277462774727748277492775027751277522775327754277552775627757277582775927760277612776227763277642776527766277672776827769277702777127772277732777427775277762777727778277792778027781277822778327784277852778627787277882778927790277912779227793277942779527796277972779827799278002780127802278032780427805278062780727808278092781027811278122781327814278152781627817278182781927820278212782227823278242782527826278272782827829278302783127832278332783427835278362783727838278392784027841278422784327844278452784627847278482784927850278512785227853278542785527856278572785827859278602786127862278632786427865278662786727868278692787027871278722787327874278752787627877278782787927880278812788227883278842788527886278872788827889278902789127892278932789427895278962789727898278992790027901279022790327904279052790627907279082790927910279112791227913279142791527916279172791827919279202792127922279232792427925279262792727928279292793027931279322793327934279352793627937279382793927940279412794227943279442794527946279472794827949279502795127952279532795427955279562795727958279592796027961279622796327964279652796627967279682796927970279712797227973279742797527976279772797827979279802798127982279832798427985279862798727988279892799027991279922799327994279952799627997279982799928000280012800228003280042800528006280072800828009280102801128012280132801428015280162801728018280192802028021280222802328024280252802628027280282802928030280312803228033280342803528036280372803828039280402804128042280432804428045280462804728048280492805028051280522805328054280552805628057280582805928060280612806228063280642806528066280672806828069280702807128072280732807428075280762807728078280792808028081280822808328084280852808628087280882808928090280912809228093280942809528096280972809828099281002810128102281032810428105281062810728108281092811028111281122811328114281152811628117281182811928120281212812228123281242812528126281272812828129281302813128132281332813428135281362813728138281392814028141281422814328144281452814628147281482814928150281512815228153281542815528156281572815828159281602816128162281632816428165281662816728168281692817028171281722817328174281752817628177281782817928180281812818228183281842818528186281872818828189281902819128192281932819428195281962819728198281992820028201282022820328204282052820628207282082820928210282112821228213282142821528216282172821828219282202822128222282232822428225282262822728228282292823028231282322823328234282352823628237282382823928240282412824228243282442824528246282472824828249282502825128252282532825428255282562825728258282592826028261282622826328264282652826628267282682826928270282712827228273282742827528276282772827828279282802828128282282832828428285282862828728288282892829028291282922829328294282952829628297282982829928300283012830228303283042830528306283072830828309283102831128312283132831428315283162831728318283192832028321283222832328324283252832628327283282832928330283312833228333283342833528336283372833828339283402834128342283432834428345283462834728348283492835028351283522835328354283552835628357283582835928360283612836228363283642836528366283672836828369283702837128372283732837428375283762837728378283792838028381283822838328384283852838628387283882838928390283912839228393283942839528396283972839828399284002840128402284032840428405284062840728408284092841028411284122841328414284152841628417284182841928420284212842228423284242842528426284272842828429284302843128432284332843428435284362843728438284392844028441284422844328444284452844628447284482844928450284512845228453284542845528456284572845828459284602846128462284632846428465284662846728468284692847028471284722847328474284752847628477284782847928480284812848228483284842848528486284872848828489284902849128492284932849428495284962849728498284992850028501285022850328504285052850628507285082850928510285112851228513285142851528516285172851828519285202852128522285232852428525285262852728528285292853028531285322853328534285352853628537285382853928540285412854228543285442854528546285472854828549285502855128552285532855428555285562855728558285592856028561285622856328564285652856628567285682856928570285712857228573285742857528576285772857828579285802858128582285832858428585285862858728588285892859028591285922859328594285952859628597285982859928600286012860228603286042860528606286072860828609286102861128612286132861428615286162861728618286192862028621286222862328624286252862628627286282862928630286312863228633286342863528636286372863828639286402864128642286432864428645286462864728648286492865028651286522865328654286552865628657286582865928660286612866228663286642866528666286672866828669286702867128672286732867428675286762867728678286792868028681286822868328684286852868628687286882868928690286912869228693286942869528696286972869828699287002870128702287032870428705287062870728708287092871028711287122871328714287152871628717287182871928720287212872228723287242872528726287272872828729287302873128732287332873428735287362873728738287392874028741287422874328744287452874628747287482874928750287512875228753287542875528756287572875828759287602876128762287632876428765287662876728768287692877028771287722877328774287752877628777287782877928780287812878228783287842878528786287872878828789287902879128792287932879428795287962879728798287992880028801288022880328804288052880628807288082880928810288112881228813288142881528816288172881828819288202882128822288232882428825288262882728828288292883028831288322883328834288352883628837288382883928840288412884228843288442884528846288472884828849288502885128852288532885428855288562885728858288592886028861288622886328864288652886628867288682886928870288712887228873288742887528876288772887828879288802888128882288832888428885288862888728888288892889028891288922889328894288952889628897288982889928900289012890228903289042890528906289072890828909289102891128912289132891428915289162891728918289192892028921289222892328924289252892628927289282892928930289312893228933289342893528936289372893828939289402894128942289432894428945289462894728948289492895028951289522895328954289552895628957289582895928960289612896228963289642896528966289672896828969289702897128972289732897428975289762897728978289792898028981289822898328984289852898628987289882898928990289912899228993289942899528996289972899828999290002900129002290032900429005290062900729008290092901029011290122901329014290152901629017290182901929020290212902229023290242902529026290272902829029290302903129032290332903429035290362903729038290392904029041290422904329044290452904629047290482904929050290512905229053290542905529056290572905829059290602906129062290632906429065290662906729068290692907029071290722907329074290752907629077290782907929080290812908229083290842908529086290872908829089290902909129092290932909429095290962909729098290992910029101291022910329104291052910629107291082910929110291112911229113291142911529116291172911829119291202912129122291232912429125291262912729128291292913029131291322913329134291352913629137291382913929140291412914229143291442914529146291472914829149291502915129152291532915429155291562915729158291592916029161291622916329164291652916629167291682916929170291712917229173291742917529176291772917829179291802918129182291832918429185291862918729188291892919029191291922919329194291952919629197291982919929200292012920229203292042920529206292072920829209292102921129212292132921429215292162921729218292192922029221292222922329224292252922629227292282922929230292312923229233292342923529236292372923829239292402924129242292432924429245292462924729248292492925029251292522925329254292552925629257292582925929260292612926229263292642926529266292672926829269292702927129272292732927429275292762927729278292792928029281292822928329284292852928629287292882928929290292912929229293292942929529296292972929829299293002930129302293032930429305293062930729308293092931029311293122931329314293152931629317293182931929320293212932229323293242932529326293272932829329293302933129332293332933429335293362933729338293392934029341293422934329344293452934629347293482934929350293512935229353293542935529356293572935829359293602936129362293632936429365293662936729368293692937029371293722937329374293752937629377293782937929380293812938229383293842938529386293872938829389293902939129392293932939429395293962939729398293992940029401294022940329404294052940629407294082940929410294112941229413294142941529416294172941829419294202942129422294232942429425294262942729428294292943029431294322943329434294352943629437294382943929440294412944229443294442944529446294472944829449294502945129452294532945429455294562945729458294592946029461294622946329464294652946629467294682946929470294712947229473294742947529476294772947829479294802948129482294832948429485294862948729488294892949029491294922949329494294952949629497294982949929500295012950229503295042950529506295072950829509295102951129512295132951429515295162951729518295192952029521295222952329524295252952629527295282952929530295312953229533295342953529536295372953829539295402954129542295432954429545295462954729548295492955029551295522955329554295552955629557295582955929560295612956229563295642956529566295672956829569295702957129572295732957429575295762957729578295792958029581295822958329584295852958629587295882958929590295912959229593295942959529596295972959829599296002960129602296032960429605296062960729608296092961029611296122961329614296152961629617296182961929620296212962229623296242962529626296272962829629296302963129632296332963429635296362963729638296392964029641296422964329644296452964629647296482964929650296512965229653296542965529656296572965829659296602966129662296632966429665296662966729668296692967029671296722967329674296752967629677296782967929680296812968229683296842968529686296872968829689296902969129692296932969429695296962969729698296992970029701297022970329704297052970629707297082970929710297112971229713297142971529716297172971829719297202972129722297232972429725297262972729728297292973029731297322973329734297352973629737297382973929740297412974229743297442974529746297472974829749297502975129752297532975429755297562975729758297592976029761297622976329764297652976629767297682976929770297712977229773297742977529776297772977829779297802978129782297832978429785297862978729788297892979029791297922979329794297952979629797297982979929800298012980229803298042980529806298072980829809298102981129812298132981429815298162981729818298192982029821298222982329824298252982629827298282982929830298312983229833298342983529836298372983829839298402984129842298432984429845298462984729848298492985029851298522985329854298552985629857298582985929860298612986229863298642986529866298672986829869298702987129872298732987429875298762987729878298792988029881298822988329884298852988629887298882988929890298912989229893298942989529896298972989829899299002990129902299032990429905299062990729908299092991029911299122991329914299152991629917299182991929920299212992229923299242992529926299272992829929299302993129932299332993429935299362993729938299392994029941299422994329944299452994629947299482994929950299512995229953299542995529956299572995829959299602996129962299632996429965299662996729968299692997029971299722997329974299752997629977299782997929980299812998229983299842998529986299872998829989299902999129992299932999429995299962999729998299993000030001300023000330004300053000630007300083000930010300113001230013300143001530016300173001830019300203002130022300233002430025300263002730028300293003030031300323003330034300353003630037300383003930040300413004230043300443004530046300473004830049300503005130052300533005430055300563005730058300593006030061300623006330064300653006630067300683006930070300713007230073300743007530076300773007830079300803008130082300833008430085300863008730088300893009030091300923009330094300953009630097300983009930100301013010230103301043010530106301073010830109301103011130112301133011430115301163011730118301193012030121301223012330124301253012630127301283012930130301313013230133301343013530136301373013830139301403014130142301433014430145301463014730148301493015030151301523015330154301553015630157301583015930160301613016230163301643016530166301673016830169301703017130172301733017430175301763017730178301793018030181301823018330184301853018630187301883018930190301913019230193301943019530196301973019830199302003020130202302033020430205302063020730208302093021030211302123021330214302153021630217302183021930220302213022230223302243022530226302273022830229302303023130232302333023430235302363023730238302393024030241302423024330244302453024630247302483024930250302513025230253302543025530256302573025830259302603026130262302633026430265302663026730268302693027030271302723027330274302753027630277302783027930280302813028230283302843028530286302873028830289302903029130292302933029430295302963029730298302993030030301303023030330304303053030630307303083030930310303113031230313303143031530316303173031830319303203032130322303233032430325303263032730328303293033030331303323033330334303353033630337303383033930340303413034230343303443034530346303473034830349303503035130352303533035430355303563035730358303593036030361303623036330364303653036630367303683036930370303713037230373303743037530376303773037830379303803038130382303833038430385303863038730388303893039030391303923039330394303953039630397303983039930400304013040230403304043040530406304073040830409304103041130412304133041430415304163041730418304193042030421304223042330424304253042630427304283042930430304313043230433304343043530436304373043830439304403044130442304433044430445304463044730448304493045030451304523045330454304553045630457304583045930460304613046230463304643046530466304673046830469304703047130472304733047430475304763047730478304793048030481304823048330484304853048630487304883048930490304913049230493304943049530496304973049830499305003050130502305033050430505305063050730508305093051030511305123051330514305153051630517305183051930520305213052230523305243052530526305273052830529305303053130532305333053430535305363053730538305393054030541305423054330544305453054630547305483054930550305513055230553305543055530556305573055830559305603056130562305633056430565305663056730568305693057030571305723057330574305753057630577305783057930580305813058230583305843058530586305873058830589305903059130592305933059430595305963059730598305993060030601306023060330604306053060630607306083060930610306113061230613306143061530616306173061830619306203062130622306233062430625306263062730628306293063030631306323063330634306353063630637306383063930640306413064230643306443064530646306473064830649306503065130652306533065430655306563065730658306593066030661306623066330664306653066630667306683066930670306713067230673306743067530676306773067830679306803068130682306833068430685306863068730688306893069030691306923069330694306953069630697306983069930700307013070230703307043070530706307073070830709307103071130712307133071430715307163071730718307193072030721307223072330724307253072630727307283072930730307313073230733307343073530736307373073830739307403074130742307433074430745307463074730748307493075030751307523075330754307553075630757307583075930760307613076230763307643076530766307673076830769307703077130772307733077430775307763077730778307793078030781307823078330784307853078630787307883078930790307913079230793307943079530796307973079830799308003080130802308033080430805308063080730808308093081030811308123081330814308153081630817308183081930820308213082230823308243082530826308273082830829308303083130832308333083430835308363083730838308393084030841308423084330844308453084630847308483084930850308513085230853308543085530856308573085830859308603086130862308633086430865308663086730868308693087030871308723087330874308753087630877308783087930880308813088230883308843088530886308873088830889308903089130892308933089430895308963089730898308993090030901309023090330904309053090630907309083090930910309113091230913309143091530916309173091830919309203092130922309233092430925309263092730928309293093030931309323093330934309353093630937309383093930940309413094230943309443094530946309473094830949309503095130952309533095430955309563095730958309593096030961309623096330964309653096630967309683096930970309713097230973309743097530976309773097830979309803098130982309833098430985309863098730988309893099030991309923099330994309953099630997309983099931000310013100231003310043100531006310073100831009310103101131012310133101431015310163101731018310193102031021310223102331024310253102631027310283102931030310313103231033310343103531036310373103831039310403104131042310433104431045310463104731048310493105031051310523105331054310553105631057310583105931060310613106231063310643106531066310673106831069310703107131072310733107431075310763107731078310793108031081310823108331084310853108631087310883108931090310913109231093310943109531096310973109831099311003110131102311033110431105311063110731108311093111031111311123111331114311153111631117311183111931120311213112231123311243112531126311273112831129311303113131132311333113431135311363113731138311393114031141311423114331144311453114631147311483114931150311513115231153311543115531156311573115831159311603116131162311633116431165311663116731168311693117031171311723117331174311753117631177311783117931180311813118231183311843118531186311873118831189311903119131192311933119431195311963119731198311993120031201312023120331204312053120631207312083120931210312113121231213312143121531216312173121831219312203122131222312233122431225312263122731228312293123031231312323123331234312353123631237312383123931240312413124231243312443124531246312473124831249312503125131252312533125431255312563125731258312593126031261312623126331264312653126631267312683126931270312713127231273312743127531276312773127831279312803128131282312833128431285312863128731288312893129031291312923129331294312953129631297312983129931300313013130231303313043130531306313073130831309313103131131312313133131431315313163131731318313193132031321313223132331324313253132631327313283132931330313313133231333313343133531336313373133831339313403134131342313433134431345313463134731348313493135031351313523135331354313553135631357313583135931360313613136231363313643136531366313673136831369313703137131372313733137431375313763137731378313793138031381313823138331384313853138631387313883138931390313913139231393313943139531396313973139831399314003140131402314033140431405314063140731408314093141031411314123141331414314153141631417314183141931420314213142231423314243142531426314273142831429314303143131432314333143431435314363143731438314393144031441314423144331444314453144631447314483144931450314513145231453314543145531456314573145831459314603146131462314633146431465314663146731468314693147031471314723147331474314753147631477314783147931480314813148231483314843148531486314873148831489314903149131492314933149431495314963149731498314993150031501315023150331504315053150631507315083150931510315113151231513315143151531516315173151831519315203152131522315233152431525315263152731528315293153031531315323153331534315353153631537315383153931540315413154231543315443154531546315473154831549315503155131552315533155431555315563155731558315593156031561315623156331564315653156631567315683156931570315713157231573315743157531576315773157831579315803158131582315833158431585315863158731588315893159031591315923159331594315953159631597315983159931600316013160231603316043160531606316073160831609316103161131612316133161431615316163161731618316193162031621316223162331624316253162631627316283162931630316313163231633316343163531636316373163831639316403164131642316433164431645316463164731648316493165031651316523165331654316553165631657316583165931660316613166231663316643166531666316673166831669316703167131672316733167431675316763167731678316793168031681316823168331684316853168631687316883168931690316913169231693316943169531696316973169831699317003170131702317033170431705317063170731708317093171031711317123171331714317153171631717317183171931720317213172231723317243172531726317273172831729317303173131732317333173431735317363173731738317393174031741317423174331744317453174631747317483174931750317513175231753317543175531756317573175831759317603176131762317633176431765317663176731768317693177031771317723177331774317753177631777317783177931780317813178231783317843178531786317873178831789317903179131792317933179431795317963179731798317993180031801318023180331804318053180631807318083180931810318113181231813318143181531816318173181831819318203182131822318233182431825318263182731828318293183031831318323183331834318353183631837318383183931840318413184231843318443184531846318473184831849318503185131852318533185431855318563185731858318593186031861318623186331864318653186631867318683186931870318713187231873318743187531876318773187831879318803188131882318833188431885318863188731888318893189031891318923189331894318953189631897318983189931900319013190231903319043190531906319073190831909319103191131912319133191431915319163191731918319193192031921319223192331924319253192631927319283192931930319313193231933319343193531936319373193831939319403194131942319433194431945319463194731948319493195031951319523195331954319553195631957319583195931960319613196231963319643196531966319673196831969319703197131972319733197431975319763197731978319793198031981319823198331984319853198631987319883198931990319913199231993319943199531996319973199831999320003200132002320033200432005320063200732008320093201032011320123201332014320153201632017320183201932020320213202232023320243202532026320273202832029320303203132032320333203432035320363203732038320393204032041320423204332044320453204632047320483204932050320513205232053320543205532056320573205832059320603206132062320633206432065320663206732068320693207032071320723207332074320753207632077320783207932080320813208232083320843208532086320873208832089320903209132092320933209432095320963209732098320993210032101321023210332104321053210632107321083210932110321113211232113321143211532116321173211832119321203212132122321233212432125321263212732128321293213032131321323213332134321353213632137321383213932140321413214232143321443214532146321473214832149321503215132152321533215432155321563215732158321593216032161321623216332164321653216632167321683216932170321713217232173321743217532176321773217832179321803218132182321833218432185321863218732188321893219032191321923219332194321953219632197321983219932200322013220232203322043220532206322073220832209322103221132212322133221432215322163221732218322193222032221322223222332224322253222632227322283222932230322313223232233322343223532236322373223832239322403224132242322433224432245322463224732248322493225032251322523225332254322553225632257322583225932260322613226232263322643226532266322673226832269322703227132272322733227432275322763227732278322793228032281322823228332284322853228632287322883228932290322913229232293322943229532296322973229832299323003230132302323033230432305323063230732308323093231032311323123231332314323153231632317323183231932320323213232232323323243232532326323273232832329323303233132332323333233432335323363233732338323393234032341323423234332344323453234632347323483234932350323513235232353323543235532356323573235832359323603236132362323633236432365323663236732368323693237032371323723237332374323753237632377323783237932380323813238232383323843238532386323873238832389323903239132392323933239432395323963239732398323993240032401324023240332404324053240632407324083240932410324113241232413324143241532416324173241832419324203242132422324233242432425324263242732428324293243032431324323243332434324353243632437324383243932440324413244232443324443244532446324473244832449324503245132452324533245432455324563245732458324593246032461324623246332464324653246632467324683246932470324713247232473324743247532476324773247832479324803248132482324833248432485324863248732488324893249032491324923249332494324953249632497324983249932500325013250232503325043250532506325073250832509325103251132512325133251432515325163251732518325193252032521325223252332524325253252632527325283252932530325313253232533325343253532536325373253832539325403254132542325433254432545325463254732548325493255032551325523255332554325553255632557325583255932560325613256232563325643256532566325673256832569325703257132572325733257432575325763257732578325793258032581325823258332584325853258632587325883258932590325913259232593325943259532596325973259832599326003260132602326033260432605326063260732608326093261032611326123261332614326153261632617326183261932620326213262232623326243262532626326273262832629326303263132632326333263432635326363263732638326393264032641326423264332644326453264632647326483264932650326513265232653326543265532656326573265832659326603266132662326633266432665326663266732668326693267032671326723267332674326753267632677326783267932680326813268232683326843268532686326873268832689326903269132692326933269432695326963269732698326993270032701327023270332704327053270632707327083270932710327113271232713327143271532716327173271832719327203272132722327233272432725327263272732728327293273032731327323273332734327353273632737327383273932740327413274232743327443274532746327473274832749327503275132752327533275432755327563275732758327593276032761327623276332764327653276632767327683276932770327713277232773327743277532776327773277832779327803278132782327833278432785327863278732788327893279032791327923279332794327953279632797327983279932800328013280232803328043280532806328073280832809328103281132812328133281432815328163281732818328193282032821328223282332824328253282632827328283282932830328313283232833328343283532836328373283832839328403284132842328433284432845328463284732848328493285032851328523285332854328553285632857328583285932860328613286232863328643286532866328673286832869328703287132872328733287432875328763287732878328793288032881328823288332884328853288632887328883288932890328913289232893328943289532896328973289832899329003290132902329033290432905329063290732908329093291032911329123291332914329153291632917329183291932920329213292232923329243292532926329273292832929329303293132932329333293432935329363293732938329393294032941329423294332944329453294632947329483294932950329513295232953329543295532956329573295832959329603296132962329633296432965329663296732968329693297032971329723297332974329753297632977329783297932980329813298232983329843298532986329873298832989329903299132992329933299432995329963299732998329993300033001330023300333004330053300633007330083300933010330113301233013330143301533016330173301833019330203302133022330233302433025330263302733028330293303033031330323303333034330353303633037330383303933040330413304233043330443304533046330473304833049330503305133052330533305433055330563305733058330593306033061330623306333064330653306633067330683306933070330713307233073330743307533076330773307833079330803308133082330833308433085330863308733088330893309033091330923309333094330953309633097330983309933100331013310233103331043310533106331073310833109331103311133112331133311433115331163311733118331193312033121331223312333124331253312633127331283312933130331313313233133331343313533136331373313833139331403314133142331433314433145331463314733148331493315033151331523315333154331553315633157331583315933160331613316233163331643316533166331673316833169331703317133172331733317433175331763317733178331793318033181331823318333184331853318633187331883318933190331913319233193331943319533196331973319833199332003320133202332033320433205332063320733208332093321033211332123321333214332153321633217332183321933220332213322233223332243322533226332273322833229332303323133232332333323433235332363323733238332393324033241332423324333244332453324633247332483324933250332513325233253332543325533256332573325833259332603326133262 |
- // THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
- // Package ec2 provides a client for Amazon Elastic Compute Cloud.
- package ec2
- import (
- "fmt"
- "time"
- "github.com/aws/aws-sdk-go/aws/awsutil"
- "github.com/aws/aws-sdk-go/aws/request"
- "github.com/aws/aws-sdk-go/private/protocol"
- "github.com/aws/aws-sdk-go/private/protocol/ec2query"
- )
- const opAcceptVpcPeeringConnection = "AcceptVpcPeeringConnection"
- // AcceptVpcPeeringConnectionRequest generates a "aws/request.Request" representing the
- // client's request for the AcceptVpcPeeringConnection operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AcceptVpcPeeringConnection method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AcceptVpcPeeringConnectionRequest method.
- // req, resp := client.AcceptVpcPeeringConnectionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AcceptVpcPeeringConnectionRequest(input *AcceptVpcPeeringConnectionInput) (req *request.Request, output *AcceptVpcPeeringConnectionOutput) {
- op := &request.Operation{
- Name: opAcceptVpcPeeringConnection,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AcceptVpcPeeringConnectionInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AcceptVpcPeeringConnectionOutput{}
- req.Data = output
- return
- }
- // Accept a VPC peering connection request. To accept a request, the VPC peering
- // connection must be in the pending-acceptance state, and you must be the owner
- // of the peer VPC. Use the DescribeVpcPeeringConnections request to view your
- // outstanding VPC peering connection requests.
- func (c *EC2) AcceptVpcPeeringConnection(input *AcceptVpcPeeringConnectionInput) (*AcceptVpcPeeringConnectionOutput, error) {
- req, out := c.AcceptVpcPeeringConnectionRequest(input)
- err := req.Send()
- return out, err
- }
- const opAllocateAddress = "AllocateAddress"
- // AllocateAddressRequest generates a "aws/request.Request" representing the
- // client's request for the AllocateAddress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AllocateAddress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AllocateAddressRequest method.
- // req, resp := client.AllocateAddressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AllocateAddressRequest(input *AllocateAddressInput) (req *request.Request, output *AllocateAddressOutput) {
- op := &request.Operation{
- Name: opAllocateAddress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AllocateAddressInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AllocateAddressOutput{}
- req.Data = output
- return
- }
- // Acquires an Elastic IP address.
- //
- // An Elastic IP address is for use either in the EC2-Classic platform or in
- // a VPC. For more information, see Elastic IP Addresses (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/elastic-ip-addresses-eip.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) AllocateAddress(input *AllocateAddressInput) (*AllocateAddressOutput, error) {
- req, out := c.AllocateAddressRequest(input)
- err := req.Send()
- return out, err
- }
- const opAllocateHosts = "AllocateHosts"
- // AllocateHostsRequest generates a "aws/request.Request" representing the
- // client's request for the AllocateHosts operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AllocateHosts method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AllocateHostsRequest method.
- // req, resp := client.AllocateHostsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AllocateHostsRequest(input *AllocateHostsInput) (req *request.Request, output *AllocateHostsOutput) {
- op := &request.Operation{
- Name: opAllocateHosts,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AllocateHostsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AllocateHostsOutput{}
- req.Data = output
- return
- }
- // Allocates a Dedicated host to your account. At minimum you need to specify
- // the instance size type, Availability Zone, and quantity of hosts you want
- // to allocate.
- func (c *EC2) AllocateHosts(input *AllocateHostsInput) (*AllocateHostsOutput, error) {
- req, out := c.AllocateHostsRequest(input)
- err := req.Send()
- return out, err
- }
- const opAssignPrivateIpAddresses = "AssignPrivateIpAddresses"
- // AssignPrivateIpAddressesRequest generates a "aws/request.Request" representing the
- // client's request for the AssignPrivateIpAddresses operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AssignPrivateIpAddresses method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AssignPrivateIpAddressesRequest method.
- // req, resp := client.AssignPrivateIpAddressesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AssignPrivateIpAddressesRequest(input *AssignPrivateIpAddressesInput) (req *request.Request, output *AssignPrivateIpAddressesOutput) {
- op := &request.Operation{
- Name: opAssignPrivateIpAddresses,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AssignPrivateIpAddressesInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &AssignPrivateIpAddressesOutput{}
- req.Data = output
- return
- }
- // Assigns one or more secondary private IP addresses to the specified network
- // interface. You can specify one or more specific secondary IP addresses, or
- // you can specify the number of secondary IP addresses to be automatically
- // assigned within the subnet's CIDR block range. The number of secondary IP
- // addresses that you can assign to an instance varies by instance type. For
- // information about instance types, see Instance Types (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instance-types.html)
- // in the Amazon Elastic Compute Cloud User Guide. For more information about
- // Elastic IP addresses, see Elastic IP Addresses (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/elastic-ip-addresses-eip.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // AssignPrivateIpAddresses is available only in EC2-VPC.
- func (c *EC2) AssignPrivateIpAddresses(input *AssignPrivateIpAddressesInput) (*AssignPrivateIpAddressesOutput, error) {
- req, out := c.AssignPrivateIpAddressesRequest(input)
- err := req.Send()
- return out, err
- }
- const opAssociateAddress = "AssociateAddress"
- // AssociateAddressRequest generates a "aws/request.Request" representing the
- // client's request for the AssociateAddress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AssociateAddress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AssociateAddressRequest method.
- // req, resp := client.AssociateAddressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AssociateAddressRequest(input *AssociateAddressInput) (req *request.Request, output *AssociateAddressOutput) {
- op := &request.Operation{
- Name: opAssociateAddress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AssociateAddressInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AssociateAddressOutput{}
- req.Data = output
- return
- }
- // Associates an Elastic IP address with an instance or a network interface.
- //
- // An Elastic IP address is for use in either the EC2-Classic platform or in
- // a VPC. For more information, see Elastic IP Addresses (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/elastic-ip-addresses-eip.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // [EC2-Classic, VPC in an EC2-VPC-only account] If the Elastic IP address
- // is already associated with a different instance, it is disassociated from
- // that instance and associated with the specified instance.
- //
- // [VPC in an EC2-Classic account] If you don't specify a private IP address,
- // the Elastic IP address is associated with the primary IP address. If the
- // Elastic IP address is already associated with a different instance or a network
- // interface, you get an error unless you allow reassociation.
- //
- // This is an idempotent operation. If you perform the operation more than
- // once, Amazon EC2 doesn't return an error.
- func (c *EC2) AssociateAddress(input *AssociateAddressInput) (*AssociateAddressOutput, error) {
- req, out := c.AssociateAddressRequest(input)
- err := req.Send()
- return out, err
- }
- const opAssociateDhcpOptions = "AssociateDhcpOptions"
- // AssociateDhcpOptionsRequest generates a "aws/request.Request" representing the
- // client's request for the AssociateDhcpOptions operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AssociateDhcpOptions method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AssociateDhcpOptionsRequest method.
- // req, resp := client.AssociateDhcpOptionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AssociateDhcpOptionsRequest(input *AssociateDhcpOptionsInput) (req *request.Request, output *AssociateDhcpOptionsOutput) {
- op := &request.Operation{
- Name: opAssociateDhcpOptions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AssociateDhcpOptionsInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &AssociateDhcpOptionsOutput{}
- req.Data = output
- return
- }
- // Associates a set of DHCP options (that you've previously created) with the
- // specified VPC, or associates no DHCP options with the VPC.
- //
- // After you associate the options with the VPC, any existing instances and
- // all new instances that you launch in that VPC use the options. You don't
- // need to restart or relaunch the instances. They automatically pick up the
- // changes within a few hours, depending on how frequently the instance renews
- // its DHCP lease. You can explicitly renew the lease using the operating system
- // on the instance.
- //
- // For more information, see DHCP Options Sets (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_DHCP_Options.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) AssociateDhcpOptions(input *AssociateDhcpOptionsInput) (*AssociateDhcpOptionsOutput, error) {
- req, out := c.AssociateDhcpOptionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opAssociateRouteTable = "AssociateRouteTable"
- // AssociateRouteTableRequest generates a "aws/request.Request" representing the
- // client's request for the AssociateRouteTable operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AssociateRouteTable method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AssociateRouteTableRequest method.
- // req, resp := client.AssociateRouteTableRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AssociateRouteTableRequest(input *AssociateRouteTableInput) (req *request.Request, output *AssociateRouteTableOutput) {
- op := &request.Operation{
- Name: opAssociateRouteTable,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AssociateRouteTableInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AssociateRouteTableOutput{}
- req.Data = output
- return
- }
- // Associates a subnet with a route table. The subnet and route table must be
- // in the same VPC. This association causes traffic originating from the subnet
- // to be routed according to the routes in the route table. The action returns
- // an association ID, which you need in order to disassociate the route table
- // from the subnet later. A route table can be associated with multiple subnets.
- //
- // For more information about route tables, see Route Tables (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Route_Tables.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) AssociateRouteTable(input *AssociateRouteTableInput) (*AssociateRouteTableOutput, error) {
- req, out := c.AssociateRouteTableRequest(input)
- err := req.Send()
- return out, err
- }
- const opAttachClassicLinkVpc = "AttachClassicLinkVpc"
- // AttachClassicLinkVpcRequest generates a "aws/request.Request" representing the
- // client's request for the AttachClassicLinkVpc operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AttachClassicLinkVpc method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AttachClassicLinkVpcRequest method.
- // req, resp := client.AttachClassicLinkVpcRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AttachClassicLinkVpcRequest(input *AttachClassicLinkVpcInput) (req *request.Request, output *AttachClassicLinkVpcOutput) {
- op := &request.Operation{
- Name: opAttachClassicLinkVpc,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AttachClassicLinkVpcInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AttachClassicLinkVpcOutput{}
- req.Data = output
- return
- }
- // Links an EC2-Classic instance to a ClassicLink-enabled VPC through one or
- // more of the VPC's security groups. You cannot link an EC2-Classic instance
- // to more than one VPC at a time. You can only link an instance that's in the
- // running state. An instance is automatically unlinked from a VPC when it's
- // stopped - you can link it to the VPC again when you restart it.
- //
- // After you've linked an instance, you cannot change the VPC security groups
- // that are associated with it. To change the security groups, you must first
- // unlink the instance, and then link it again.
- //
- // Linking your instance to a VPC is sometimes referred to as attaching your
- // instance.
- func (c *EC2) AttachClassicLinkVpc(input *AttachClassicLinkVpcInput) (*AttachClassicLinkVpcOutput, error) {
- req, out := c.AttachClassicLinkVpcRequest(input)
- err := req.Send()
- return out, err
- }
- const opAttachInternetGateway = "AttachInternetGateway"
- // AttachInternetGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the AttachInternetGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AttachInternetGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AttachInternetGatewayRequest method.
- // req, resp := client.AttachInternetGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AttachInternetGatewayRequest(input *AttachInternetGatewayInput) (req *request.Request, output *AttachInternetGatewayOutput) {
- op := &request.Operation{
- Name: opAttachInternetGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AttachInternetGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &AttachInternetGatewayOutput{}
- req.Data = output
- return
- }
- // Attaches an Internet gateway to a VPC, enabling connectivity between the
- // Internet and the VPC. For more information about your VPC and Internet gateway,
- // see the Amazon Virtual Private Cloud User Guide (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/).
- func (c *EC2) AttachInternetGateway(input *AttachInternetGatewayInput) (*AttachInternetGatewayOutput, error) {
- req, out := c.AttachInternetGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opAttachNetworkInterface = "AttachNetworkInterface"
- // AttachNetworkInterfaceRequest generates a "aws/request.Request" representing the
- // client's request for the AttachNetworkInterface operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AttachNetworkInterface method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AttachNetworkInterfaceRequest method.
- // req, resp := client.AttachNetworkInterfaceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AttachNetworkInterfaceRequest(input *AttachNetworkInterfaceInput) (req *request.Request, output *AttachNetworkInterfaceOutput) {
- op := &request.Operation{
- Name: opAttachNetworkInterface,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AttachNetworkInterfaceInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AttachNetworkInterfaceOutput{}
- req.Data = output
- return
- }
- // Attaches a network interface to an instance.
- func (c *EC2) AttachNetworkInterface(input *AttachNetworkInterfaceInput) (*AttachNetworkInterfaceOutput, error) {
- req, out := c.AttachNetworkInterfaceRequest(input)
- err := req.Send()
- return out, err
- }
- const opAttachVolume = "AttachVolume"
- // AttachVolumeRequest generates a "aws/request.Request" representing the
- // client's request for the AttachVolume operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AttachVolume method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AttachVolumeRequest method.
- // req, resp := client.AttachVolumeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AttachVolumeRequest(input *AttachVolumeInput) (req *request.Request, output *VolumeAttachment) {
- op := &request.Operation{
- Name: opAttachVolume,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AttachVolumeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &VolumeAttachment{}
- req.Data = output
- return
- }
- // Attaches an EBS volume to a running or stopped instance and exposes it to
- // the instance with the specified device name.
- //
- // Encrypted EBS volumes may only be attached to instances that support Amazon
- // EBS encryption. For more information, see Amazon EBS Encryption (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // For a list of supported device names, see Attaching an EBS Volume to an
- // Instance (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-attaching-volume.html).
- // Any device names that aren't reserved for instance store volumes can be used
- // for EBS volumes. For more information, see Amazon EC2 Instance Store (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/InstanceStorage.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // If a volume has an AWS Marketplace product code:
- //
- // The volume can be attached only to a stopped instance.
- //
- // AWS Marketplace product codes are copied from the volume to the instance.
- //
- // You must be subscribed to the product.
- //
- // The instance type and operating system of the instance must support the
- // product. For example, you can't detach a volume from a Windows instance and
- // attach it to a Linux instance.
- //
- // For an overview of the AWS Marketplace, see Introducing AWS Marketplace
- // (https://aws.amazon.com/marketplace/help/200900000).
- //
- // For more information about EBS volumes, see Attaching Amazon EBS Volumes
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-attaching-volume.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) AttachVolume(input *AttachVolumeInput) (*VolumeAttachment, error) {
- req, out := c.AttachVolumeRequest(input)
- err := req.Send()
- return out, err
- }
- const opAttachVpnGateway = "AttachVpnGateway"
- // AttachVpnGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the AttachVpnGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AttachVpnGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AttachVpnGatewayRequest method.
- // req, resp := client.AttachVpnGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AttachVpnGatewayRequest(input *AttachVpnGatewayInput) (req *request.Request, output *AttachVpnGatewayOutput) {
- op := &request.Operation{
- Name: opAttachVpnGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AttachVpnGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- output = &AttachVpnGatewayOutput{}
- req.Data = output
- return
- }
- // Attaches a virtual private gateway to a VPC. For more information, see Adding
- // a Hardware Virtual Private Gateway to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) AttachVpnGateway(input *AttachVpnGatewayInput) (*AttachVpnGatewayOutput, error) {
- req, out := c.AttachVpnGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opAuthorizeSecurityGroupEgress = "AuthorizeSecurityGroupEgress"
- // AuthorizeSecurityGroupEgressRequest generates a "aws/request.Request" representing the
- // client's request for the AuthorizeSecurityGroupEgress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AuthorizeSecurityGroupEgress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AuthorizeSecurityGroupEgressRequest method.
- // req, resp := client.AuthorizeSecurityGroupEgressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AuthorizeSecurityGroupEgressRequest(input *AuthorizeSecurityGroupEgressInput) (req *request.Request, output *AuthorizeSecurityGroupEgressOutput) {
- op := &request.Operation{
- Name: opAuthorizeSecurityGroupEgress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AuthorizeSecurityGroupEgressInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &AuthorizeSecurityGroupEgressOutput{}
- req.Data = output
- return
- }
- // [EC2-VPC only] Adds one or more egress rules to a security group for use
- // with a VPC. Specifically, this action permits instances to send traffic to
- // one or more destination CIDR IP address ranges, or to one or more destination
- // security groups for the same VPC. This action doesn't apply to security groups
- // for use in EC2-Classic. For more information, see Security Groups for Your
- // VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_SecurityGroups.html)
- // in the Amazon Virtual Private Cloud User Guide.
- //
- // You can have up to 50 rules per security group (covering both ingress and
- // egress rules).
- //
- // Each rule consists of the protocol (for example, TCP), plus either a CIDR
- // range or a source group. For the TCP and UDP protocols, you must also specify
- // the destination port or port range. For the ICMP protocol, you must also
- // specify the ICMP type and code. You can use -1 for the type or code to mean
- // all types or all codes.
- //
- // Rule changes are propagated to affected instances as quickly as possible.
- // However, a small delay might occur.
- func (c *EC2) AuthorizeSecurityGroupEgress(input *AuthorizeSecurityGroupEgressInput) (*AuthorizeSecurityGroupEgressOutput, error) {
- req, out := c.AuthorizeSecurityGroupEgressRequest(input)
- err := req.Send()
- return out, err
- }
- const opAuthorizeSecurityGroupIngress = "AuthorizeSecurityGroupIngress"
- // AuthorizeSecurityGroupIngressRequest generates a "aws/request.Request" representing the
- // client's request for the AuthorizeSecurityGroupIngress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the AuthorizeSecurityGroupIngress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the AuthorizeSecurityGroupIngressRequest method.
- // req, resp := client.AuthorizeSecurityGroupIngressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) AuthorizeSecurityGroupIngressRequest(input *AuthorizeSecurityGroupIngressInput) (req *request.Request, output *AuthorizeSecurityGroupIngressOutput) {
- op := &request.Operation{
- Name: opAuthorizeSecurityGroupIngress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AuthorizeSecurityGroupIngressInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &AuthorizeSecurityGroupIngressOutput{}
- req.Data = output
- return
- }
- // Adds one or more ingress rules to a security group.
- //
- // EC2-Classic: You can have up to 100 rules per group.
- //
- // EC2-VPC: You can have up to 50 rules per group (covering both ingress and
- // egress rules).
- //
- // Rule changes are propagated to instances within the security group as quickly
- // as possible. However, a small delay might occur.
- //
- // [EC2-Classic] This action gives one or more CIDR IP address ranges permission
- // to access a security group in your account, or gives one or more security
- // groups (called the source groups) permission to access a security group for
- // your account. A source group can be for your own AWS account, or another.
- //
- // [EC2-VPC] This action gives one or more CIDR IP address ranges permission
- // to access a security group in your VPC, or gives one or more other security
- // groups (called the source groups) permission to access a security group for
- // your VPC. The security groups must all be for the same VPC.
- func (c *EC2) AuthorizeSecurityGroupIngress(input *AuthorizeSecurityGroupIngressInput) (*AuthorizeSecurityGroupIngressOutput, error) {
- req, out := c.AuthorizeSecurityGroupIngressRequest(input)
- err := req.Send()
- return out, err
- }
- const opBundleInstance = "BundleInstance"
- // BundleInstanceRequest generates a "aws/request.Request" representing the
- // client's request for the BundleInstance operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the BundleInstance method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the BundleInstanceRequest method.
- // req, resp := client.BundleInstanceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) BundleInstanceRequest(input *BundleInstanceInput) (req *request.Request, output *BundleInstanceOutput) {
- op := &request.Operation{
- Name: opBundleInstance,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &BundleInstanceInput{}
- }
- req = c.newRequest(op, input, output)
- output = &BundleInstanceOutput{}
- req.Data = output
- return
- }
- // Bundles an Amazon instance store-backed Windows instance.
- //
- // During bundling, only the root device volume (C:\) is bundled. Data on other
- // instance store volumes is not preserved.
- //
- // This action is not applicable for Linux/Unix instances or Windows instances
- // that are backed by Amazon EBS.
- //
- // For more information, see Creating an Instance Store-Backed Windows AMI
- // (http://docs.aws.amazon.com/AWSEC2/latest/WindowsGuide/Creating_InstanceStoreBacked_WinAMI.html).
- func (c *EC2) BundleInstance(input *BundleInstanceInput) (*BundleInstanceOutput, error) {
- req, out := c.BundleInstanceRequest(input)
- err := req.Send()
- return out, err
- }
- const opCancelBundleTask = "CancelBundleTask"
- // CancelBundleTaskRequest generates a "aws/request.Request" representing the
- // client's request for the CancelBundleTask operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CancelBundleTask method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CancelBundleTaskRequest method.
- // req, resp := client.CancelBundleTaskRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CancelBundleTaskRequest(input *CancelBundleTaskInput) (req *request.Request, output *CancelBundleTaskOutput) {
- op := &request.Operation{
- Name: opCancelBundleTask,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CancelBundleTaskInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CancelBundleTaskOutput{}
- req.Data = output
- return
- }
- // Cancels a bundling operation for an instance store-backed Windows instance.
- func (c *EC2) CancelBundleTask(input *CancelBundleTaskInput) (*CancelBundleTaskOutput, error) {
- req, out := c.CancelBundleTaskRequest(input)
- err := req.Send()
- return out, err
- }
- const opCancelConversionTask = "CancelConversionTask"
- // CancelConversionTaskRequest generates a "aws/request.Request" representing the
- // client's request for the CancelConversionTask operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CancelConversionTask method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CancelConversionTaskRequest method.
- // req, resp := client.CancelConversionTaskRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CancelConversionTaskRequest(input *CancelConversionTaskInput) (req *request.Request, output *CancelConversionTaskOutput) {
- op := &request.Operation{
- Name: opCancelConversionTask,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CancelConversionTaskInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &CancelConversionTaskOutput{}
- req.Data = output
- return
- }
- // Cancels an active conversion task. The task can be the import of an instance
- // or volume. The action removes all artifacts of the conversion, including
- // a partially uploaded volume or instance. If the conversion is complete or
- // is in the process of transferring the final disk image, the command fails
- // and returns an exception.
- //
- // For more information, see Using the Command Line Tools to Import Your Virtual
- // Machine to Amazon EC2 (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UploadingYourInstancesandVolumes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CancelConversionTask(input *CancelConversionTaskInput) (*CancelConversionTaskOutput, error) {
- req, out := c.CancelConversionTaskRequest(input)
- err := req.Send()
- return out, err
- }
- const opCancelExportTask = "CancelExportTask"
- // CancelExportTaskRequest generates a "aws/request.Request" representing the
- // client's request for the CancelExportTask operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CancelExportTask method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CancelExportTaskRequest method.
- // req, resp := client.CancelExportTaskRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CancelExportTaskRequest(input *CancelExportTaskInput) (req *request.Request, output *CancelExportTaskOutput) {
- op := &request.Operation{
- Name: opCancelExportTask,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CancelExportTaskInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &CancelExportTaskOutput{}
- req.Data = output
- return
- }
- // Cancels an active export task. The request removes all artifacts of the export,
- // including any partially-created Amazon S3 objects. If the export task is
- // complete or is in the process of transferring the final disk image, the command
- // fails and returns an error.
- func (c *EC2) CancelExportTask(input *CancelExportTaskInput) (*CancelExportTaskOutput, error) {
- req, out := c.CancelExportTaskRequest(input)
- err := req.Send()
- return out, err
- }
- const opCancelImportTask = "CancelImportTask"
- // CancelImportTaskRequest generates a "aws/request.Request" representing the
- // client's request for the CancelImportTask operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CancelImportTask method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CancelImportTaskRequest method.
- // req, resp := client.CancelImportTaskRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CancelImportTaskRequest(input *CancelImportTaskInput) (req *request.Request, output *CancelImportTaskOutput) {
- op := &request.Operation{
- Name: opCancelImportTask,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CancelImportTaskInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CancelImportTaskOutput{}
- req.Data = output
- return
- }
- // Cancels an in-process import virtual machine or import snapshot task.
- func (c *EC2) CancelImportTask(input *CancelImportTaskInput) (*CancelImportTaskOutput, error) {
- req, out := c.CancelImportTaskRequest(input)
- err := req.Send()
- return out, err
- }
- const opCancelReservedInstancesListing = "CancelReservedInstancesListing"
- // CancelReservedInstancesListingRequest generates a "aws/request.Request" representing the
- // client's request for the CancelReservedInstancesListing operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CancelReservedInstancesListing method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CancelReservedInstancesListingRequest method.
- // req, resp := client.CancelReservedInstancesListingRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CancelReservedInstancesListingRequest(input *CancelReservedInstancesListingInput) (req *request.Request, output *CancelReservedInstancesListingOutput) {
- op := &request.Operation{
- Name: opCancelReservedInstancesListing,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CancelReservedInstancesListingInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CancelReservedInstancesListingOutput{}
- req.Data = output
- return
- }
- // Cancels the specified Reserved Instance listing in the Reserved Instance
- // Marketplace.
- //
- // For more information, see Reserved Instance Marketplace (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ri-market-general.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CancelReservedInstancesListing(input *CancelReservedInstancesListingInput) (*CancelReservedInstancesListingOutput, error) {
- req, out := c.CancelReservedInstancesListingRequest(input)
- err := req.Send()
- return out, err
- }
- const opCancelSpotFleetRequests = "CancelSpotFleetRequests"
- // CancelSpotFleetRequestsRequest generates a "aws/request.Request" representing the
- // client's request for the CancelSpotFleetRequests operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CancelSpotFleetRequests method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CancelSpotFleetRequestsRequest method.
- // req, resp := client.CancelSpotFleetRequestsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CancelSpotFleetRequestsRequest(input *CancelSpotFleetRequestsInput) (req *request.Request, output *CancelSpotFleetRequestsOutput) {
- op := &request.Operation{
- Name: opCancelSpotFleetRequests,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CancelSpotFleetRequestsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CancelSpotFleetRequestsOutput{}
- req.Data = output
- return
- }
- // Cancels the specified Spot fleet requests.
- //
- // After you cancel a Spot fleet request, the Spot fleet launches no new Spot
- // instances. You must specify whether the Spot fleet should also terminate
- // its Spot instances. If you terminate the instances, the Spot fleet request
- // enters the cancelled_terminating state. Otherwise, the Spot fleet request
- // enters the cancelled_running state and the instances continue to run until
- // they are interrupted or you terminate them manually.
- func (c *EC2) CancelSpotFleetRequests(input *CancelSpotFleetRequestsInput) (*CancelSpotFleetRequestsOutput, error) {
- req, out := c.CancelSpotFleetRequestsRequest(input)
- err := req.Send()
- return out, err
- }
- const opCancelSpotInstanceRequests = "CancelSpotInstanceRequests"
- // CancelSpotInstanceRequestsRequest generates a "aws/request.Request" representing the
- // client's request for the CancelSpotInstanceRequests operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CancelSpotInstanceRequests method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CancelSpotInstanceRequestsRequest method.
- // req, resp := client.CancelSpotInstanceRequestsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CancelSpotInstanceRequestsRequest(input *CancelSpotInstanceRequestsInput) (req *request.Request, output *CancelSpotInstanceRequestsOutput) {
- op := &request.Operation{
- Name: opCancelSpotInstanceRequests,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CancelSpotInstanceRequestsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CancelSpotInstanceRequestsOutput{}
- req.Data = output
- return
- }
- // Cancels one or more Spot instance requests. Spot instances are instances
- // that Amazon EC2 starts on your behalf when the bid price that you specify
- // exceeds the current Spot price. Amazon EC2 periodically sets the Spot price
- // based on available Spot instance capacity and current Spot instance requests.
- // For more information, see Spot Instance Requests (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-requests.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Canceling a Spot instance request does not terminate running Spot instances
- // associated with the request.
- func (c *EC2) CancelSpotInstanceRequests(input *CancelSpotInstanceRequestsInput) (*CancelSpotInstanceRequestsOutput, error) {
- req, out := c.CancelSpotInstanceRequestsRequest(input)
- err := req.Send()
- return out, err
- }
- const opConfirmProductInstance = "ConfirmProductInstance"
- // ConfirmProductInstanceRequest generates a "aws/request.Request" representing the
- // client's request for the ConfirmProductInstance operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ConfirmProductInstance method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ConfirmProductInstanceRequest method.
- // req, resp := client.ConfirmProductInstanceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ConfirmProductInstanceRequest(input *ConfirmProductInstanceInput) (req *request.Request, output *ConfirmProductInstanceOutput) {
- op := &request.Operation{
- Name: opConfirmProductInstance,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ConfirmProductInstanceInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ConfirmProductInstanceOutput{}
- req.Data = output
- return
- }
- // Determines whether a product code is associated with an instance. This action
- // can only be used by the owner of the product code. It is useful when a product
- // code owner needs to verify whether another user's instance is eligible for
- // support.
- func (c *EC2) ConfirmProductInstance(input *ConfirmProductInstanceInput) (*ConfirmProductInstanceOutput, error) {
- req, out := c.ConfirmProductInstanceRequest(input)
- err := req.Send()
- return out, err
- }
- const opCopyImage = "CopyImage"
- // CopyImageRequest generates a "aws/request.Request" representing the
- // client's request for the CopyImage operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CopyImage method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CopyImageRequest method.
- // req, resp := client.CopyImageRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CopyImageRequest(input *CopyImageInput) (req *request.Request, output *CopyImageOutput) {
- op := &request.Operation{
- Name: opCopyImage,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CopyImageInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CopyImageOutput{}
- req.Data = output
- return
- }
- // Initiates the copy of an AMI from the specified source region to the current
- // region. You specify the destination region by using its endpoint when making
- // the request.
- //
- // For more information, see Copying AMIs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/CopyingAMIs.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CopyImage(input *CopyImageInput) (*CopyImageOutput, error) {
- req, out := c.CopyImageRequest(input)
- err := req.Send()
- return out, err
- }
- const opCopySnapshot = "CopySnapshot"
- // CopySnapshotRequest generates a "aws/request.Request" representing the
- // client's request for the CopySnapshot operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CopySnapshot method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CopySnapshotRequest method.
- // req, resp := client.CopySnapshotRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CopySnapshotRequest(input *CopySnapshotInput) (req *request.Request, output *CopySnapshotOutput) {
- op := &request.Operation{
- Name: opCopySnapshot,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CopySnapshotInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CopySnapshotOutput{}
- req.Data = output
- return
- }
- // Copies a point-in-time snapshot of an EBS volume and stores it in Amazon
- // S3. You can copy the snapshot within the same region or from one region to
- // another. You can use the snapshot to create EBS volumes or Amazon Machine
- // Images (AMIs). The snapshot is copied to the regional endpoint that you send
- // the HTTP request to.
- //
- // Copies of encrypted EBS snapshots remain encrypted. Copies of unencrypted
- // snapshots remain unencrypted, unless the Encrypted flag is specified during
- // the snapshot copy operation. By default, encrypted snapshot copies use the
- // default AWS Key Management Service (AWS KMS) customer master key (CMK); however,
- // you can specify a non-default CMK with the KmsKeyId parameter.
- //
- // To copy an encrypted snapshot that has been shared from another account,
- // you must have permissions for the CMK used to encrypt the snapshot.
- //
- // Snapshots created by the CopySnapshot action have an arbitrary volume
- // ID that should not be used for any purpose.
- //
- // For more information, see Copying an Amazon EBS Snapshot (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-copy-snapshot.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CopySnapshot(input *CopySnapshotInput) (*CopySnapshotOutput, error) {
- req, out := c.CopySnapshotRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateCustomerGateway = "CreateCustomerGateway"
- // CreateCustomerGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the CreateCustomerGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateCustomerGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateCustomerGatewayRequest method.
- // req, resp := client.CreateCustomerGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateCustomerGatewayRequest(input *CreateCustomerGatewayInput) (req *request.Request, output *CreateCustomerGatewayOutput) {
- op := &request.Operation{
- Name: opCreateCustomerGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateCustomerGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateCustomerGatewayOutput{}
- req.Data = output
- return
- }
- // Provides information to AWS about your VPN customer gateway device. The customer
- // gateway is the appliance at your end of the VPN connection. (The device on
- // the AWS side of the VPN connection is the virtual private gateway.) You must
- // provide the Internet-routable IP address of the customer gateway's external
- // interface. The IP address must be static and may be behind a device performing
- // network address translation (NAT).
- //
- // For devices that use Border Gateway Protocol (BGP), you can also provide
- // the device's BGP Autonomous System Number (ASN). You can use an existing
- // ASN assigned to your network. If you don't have an ASN already, you can use
- // a private ASN (in the 64512 - 65534 range).
- //
- // Amazon EC2 supports all 2-byte ASN numbers in the range of 1 - 65534, with
- // the exception of 7224, which is reserved in the us-east-1 region, and 9059,
- // which is reserved in the eu-west-1 region.
- //
- // For more information about VPN customer gateways, see Adding a Hardware
- // Virtual Private Gateway to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- //
- // You cannot create more than one customer gateway with the same VPN type,
- // IP address, and BGP ASN parameter values. If you run an identical request
- // more than one time, the first request creates the customer gateway, and subsequent
- // requests return information about the existing customer gateway. The subsequent
- // requests do not create new customer gateway resources.
- func (c *EC2) CreateCustomerGateway(input *CreateCustomerGatewayInput) (*CreateCustomerGatewayOutput, error) {
- req, out := c.CreateCustomerGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateDhcpOptions = "CreateDhcpOptions"
- // CreateDhcpOptionsRequest generates a "aws/request.Request" representing the
- // client's request for the CreateDhcpOptions operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateDhcpOptions method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateDhcpOptionsRequest method.
- // req, resp := client.CreateDhcpOptionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateDhcpOptionsRequest(input *CreateDhcpOptionsInput) (req *request.Request, output *CreateDhcpOptionsOutput) {
- op := &request.Operation{
- Name: opCreateDhcpOptions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateDhcpOptionsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateDhcpOptionsOutput{}
- req.Data = output
- return
- }
- // Creates a set of DHCP options for your VPC. After creating the set, you must
- // associate it with the VPC, causing all existing and new instances that you
- // launch in the VPC to use this set of DHCP options. The following are the
- // individual DHCP options you can specify. For more information about the options,
- // see RFC 2132 (http://www.ietf.org/rfc/rfc2132.txt).
- //
- // domain-name-servers - The IP addresses of up to four domain name servers,
- // or AmazonProvidedDNS. The default DHCP option set specifies AmazonProvidedDNS.
- // If specifying more than one domain name server, specify the IP addresses
- // in a single parameter, separated by commas. If you want your instance to
- // receive a custom DNS hostname as specified in domain-name, you must set domain-name-servers
- // to a custom DNS server.
- //
- // domain-name - If you're using AmazonProvidedDNS in "us-east-1", specify
- // "ec2.internal". If you're using AmazonProvidedDNS in another region, specify
- // "region.compute.internal" (for example, "ap-northeast-1.compute.internal").
- // Otherwise, specify a domain name (for example, "MyCompany.com"). This value
- // is used to complete unqualified DNS hostnames. Important: Some Linux operating
- // systems accept multiple domain names separated by spaces. However, Windows
- // and other Linux operating systems treat the value as a single domain, which
- // results in unexpected behavior. If your DHCP options set is associated with
- // a VPC that has instances with multiple operating systems, specify only one
- // domain name.
- //
- // ntp-servers - The IP addresses of up to four Network Time Protocol (NTP)
- // servers.
- //
- // netbios-name-servers - The IP addresses of up to four NetBIOS name servers.
- //
- // netbios-node-type - The NetBIOS node type (1, 2, 4, or 8). We recommend
- // that you specify 2 (broadcast and multicast are not currently supported).
- // For more information about these node types, see RFC 2132 (http://www.ietf.org/rfc/rfc2132.txt).
- //
- // Your VPC automatically starts out with a set of DHCP options that includes
- // only a DNS server that we provide (AmazonProvidedDNS). If you create a set
- // of options, and if your VPC has an Internet gateway, make sure to set the
- // domain-name-servers option either to AmazonProvidedDNS or to a domain name
- // server of your choice. For more information about DHCP options, see DHCP
- // Options Sets (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_DHCP_Options.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateDhcpOptions(input *CreateDhcpOptionsInput) (*CreateDhcpOptionsOutput, error) {
- req, out := c.CreateDhcpOptionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateFlowLogs = "CreateFlowLogs"
- // CreateFlowLogsRequest generates a "aws/request.Request" representing the
- // client's request for the CreateFlowLogs operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateFlowLogs method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateFlowLogsRequest method.
- // req, resp := client.CreateFlowLogsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateFlowLogsRequest(input *CreateFlowLogsInput) (req *request.Request, output *CreateFlowLogsOutput) {
- op := &request.Operation{
- Name: opCreateFlowLogs,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateFlowLogsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateFlowLogsOutput{}
- req.Data = output
- return
- }
- // Creates one or more flow logs to capture IP traffic for a specific network
- // interface, subnet, or VPC. Flow logs are delivered to a specified log group
- // in Amazon CloudWatch Logs. If you specify a VPC or subnet in the request,
- // a log stream is created in CloudWatch Logs for each network interface in
- // the subnet or VPC. Log streams can include information about accepted and
- // rejected traffic to a network interface. You can view the data in your log
- // streams using Amazon CloudWatch Logs.
- //
- // In your request, you must also specify an IAM role that has permission to
- // publish logs to CloudWatch Logs.
- func (c *EC2) CreateFlowLogs(input *CreateFlowLogsInput) (*CreateFlowLogsOutput, error) {
- req, out := c.CreateFlowLogsRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateImage = "CreateImage"
- // CreateImageRequest generates a "aws/request.Request" representing the
- // client's request for the CreateImage operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateImage method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateImageRequest method.
- // req, resp := client.CreateImageRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateImageRequest(input *CreateImageInput) (req *request.Request, output *CreateImageOutput) {
- op := &request.Operation{
- Name: opCreateImage,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateImageInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateImageOutput{}
- req.Data = output
- return
- }
- // Creates an Amazon EBS-backed AMI from an Amazon EBS-backed instance that
- // is either running or stopped.
- //
- // If you customized your instance with instance store volumes or EBS volumes
- // in addition to the root device volume, the new AMI contains block device
- // mapping information for those volumes. When you launch an instance from this
- // new AMI, the instance automatically launches with those additional volumes.
- //
- // For more information, see Creating Amazon EBS-Backed Linux AMIs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/creating-an-ami-ebs.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateImage(input *CreateImageInput) (*CreateImageOutput, error) {
- req, out := c.CreateImageRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateInstanceExportTask = "CreateInstanceExportTask"
- // CreateInstanceExportTaskRequest generates a "aws/request.Request" representing the
- // client's request for the CreateInstanceExportTask operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateInstanceExportTask method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateInstanceExportTaskRequest method.
- // req, resp := client.CreateInstanceExportTaskRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateInstanceExportTaskRequest(input *CreateInstanceExportTaskInput) (req *request.Request, output *CreateInstanceExportTaskOutput) {
- op := &request.Operation{
- Name: opCreateInstanceExportTask,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateInstanceExportTaskInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateInstanceExportTaskOutput{}
- req.Data = output
- return
- }
- // Exports a running or stopped instance to an S3 bucket.
- //
- // For information about the supported operating systems, image formats, and
- // known limitations for the types of instances you can export, see Exporting
- // EC2 Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ExportingEC2Instances.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateInstanceExportTask(input *CreateInstanceExportTaskInput) (*CreateInstanceExportTaskOutput, error) {
- req, out := c.CreateInstanceExportTaskRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateInternetGateway = "CreateInternetGateway"
- // CreateInternetGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the CreateInternetGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateInternetGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateInternetGatewayRequest method.
- // req, resp := client.CreateInternetGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateInternetGatewayRequest(input *CreateInternetGatewayInput) (req *request.Request, output *CreateInternetGatewayOutput) {
- op := &request.Operation{
- Name: opCreateInternetGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateInternetGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateInternetGatewayOutput{}
- req.Data = output
- return
- }
- // Creates an Internet gateway for use with a VPC. After creating the Internet
- // gateway, you attach it to a VPC using AttachInternetGateway.
- //
- // For more information about your VPC and Internet gateway, see the Amazon
- // Virtual Private Cloud User Guide (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/).
- func (c *EC2) CreateInternetGateway(input *CreateInternetGatewayInput) (*CreateInternetGatewayOutput, error) {
- req, out := c.CreateInternetGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateKeyPair = "CreateKeyPair"
- // CreateKeyPairRequest generates a "aws/request.Request" representing the
- // client's request for the CreateKeyPair operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateKeyPair method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateKeyPairRequest method.
- // req, resp := client.CreateKeyPairRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateKeyPairRequest(input *CreateKeyPairInput) (req *request.Request, output *CreateKeyPairOutput) {
- op := &request.Operation{
- Name: opCreateKeyPair,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateKeyPairInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateKeyPairOutput{}
- req.Data = output
- return
- }
- // Creates a 2048-bit RSA key pair with the specified name. Amazon EC2 stores
- // the public key and displays the private key for you to save to a file. The
- // private key is returned as an unencrypted PEM encoded PKCS#8 private key.
- // If a key with the specified name already exists, Amazon EC2 returns an error.
- //
- // You can have up to five thousand key pairs per region.
- //
- // The key pair returned to you is available only in the region in which you
- // create it. To create a key pair that is available in all regions, use ImportKeyPair.
- //
- // For more information about key pairs, see Key Pairs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-key-pairs.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateKeyPair(input *CreateKeyPairInput) (*CreateKeyPairOutput, error) {
- req, out := c.CreateKeyPairRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateNatGateway = "CreateNatGateway"
- // CreateNatGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the CreateNatGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateNatGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateNatGatewayRequest method.
- // req, resp := client.CreateNatGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateNatGatewayRequest(input *CreateNatGatewayInput) (req *request.Request, output *CreateNatGatewayOutput) {
- op := &request.Operation{
- Name: opCreateNatGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateNatGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateNatGatewayOutput{}
- req.Data = output
- return
- }
- // Creates a NAT gateway in the specified subnet. A NAT gateway can be used
- // to enable instances in a private subnet to connect to the Internet. This
- // action creates a network interface in the specified subnet with a private
- // IP address from the IP address range of the subnet. For more information,
- // see NAT Gateways (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateNatGateway(input *CreateNatGatewayInput) (*CreateNatGatewayOutput, error) {
- req, out := c.CreateNatGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateNetworkAcl = "CreateNetworkAcl"
- // CreateNetworkAclRequest generates a "aws/request.Request" representing the
- // client's request for the CreateNetworkAcl operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateNetworkAcl method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateNetworkAclRequest method.
- // req, resp := client.CreateNetworkAclRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateNetworkAclRequest(input *CreateNetworkAclInput) (req *request.Request, output *CreateNetworkAclOutput) {
- op := &request.Operation{
- Name: opCreateNetworkAcl,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateNetworkAclInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateNetworkAclOutput{}
- req.Data = output
- return
- }
- // Creates a network ACL in a VPC. Network ACLs provide an optional layer of
- // security (in addition to security groups) for the instances in your VPC.
- //
- // For more information about network ACLs, see Network ACLs (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_ACLs.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateNetworkAcl(input *CreateNetworkAclInput) (*CreateNetworkAclOutput, error) {
- req, out := c.CreateNetworkAclRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateNetworkAclEntry = "CreateNetworkAclEntry"
- // CreateNetworkAclEntryRequest generates a "aws/request.Request" representing the
- // client's request for the CreateNetworkAclEntry operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateNetworkAclEntry method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateNetworkAclEntryRequest method.
- // req, resp := client.CreateNetworkAclEntryRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateNetworkAclEntryRequest(input *CreateNetworkAclEntryInput) (req *request.Request, output *CreateNetworkAclEntryOutput) {
- op := &request.Operation{
- Name: opCreateNetworkAclEntry,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateNetworkAclEntryInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &CreateNetworkAclEntryOutput{}
- req.Data = output
- return
- }
- // Creates an entry (a rule) in a network ACL with the specified rule number.
- // Each network ACL has a set of numbered ingress rules and a separate set of
- // numbered egress rules. When determining whether a packet should be allowed
- // in or out of a subnet associated with the ACL, we process the entries in
- // the ACL according to the rule numbers, in ascending order. Each network ACL
- // has a set of ingress rules and a separate set of egress rules.
- //
- // We recommend that you leave room between the rule numbers (for example,
- // 100, 110, 120, ...), and not number them one right after the other (for example,
- // 101, 102, 103, ...). This makes it easier to add a rule between existing
- // ones without having to renumber the rules.
- //
- // After you add an entry, you can't modify it; you must either replace it,
- // or create an entry and delete the old one.
- //
- // For more information about network ACLs, see Network ACLs (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_ACLs.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateNetworkAclEntry(input *CreateNetworkAclEntryInput) (*CreateNetworkAclEntryOutput, error) {
- req, out := c.CreateNetworkAclEntryRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateNetworkInterface = "CreateNetworkInterface"
- // CreateNetworkInterfaceRequest generates a "aws/request.Request" representing the
- // client's request for the CreateNetworkInterface operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateNetworkInterface method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateNetworkInterfaceRequest method.
- // req, resp := client.CreateNetworkInterfaceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateNetworkInterfaceRequest(input *CreateNetworkInterfaceInput) (req *request.Request, output *CreateNetworkInterfaceOutput) {
- op := &request.Operation{
- Name: opCreateNetworkInterface,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateNetworkInterfaceInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateNetworkInterfaceOutput{}
- req.Data = output
- return
- }
- // Creates a network interface in the specified subnet.
- //
- // For more information about network interfaces, see Elastic Network Interfaces
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-eni.html) in the
- // Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateNetworkInterface(input *CreateNetworkInterfaceInput) (*CreateNetworkInterfaceOutput, error) {
- req, out := c.CreateNetworkInterfaceRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreatePlacementGroup = "CreatePlacementGroup"
- // CreatePlacementGroupRequest generates a "aws/request.Request" representing the
- // client's request for the CreatePlacementGroup operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreatePlacementGroup method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreatePlacementGroupRequest method.
- // req, resp := client.CreatePlacementGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreatePlacementGroupRequest(input *CreatePlacementGroupInput) (req *request.Request, output *CreatePlacementGroupOutput) {
- op := &request.Operation{
- Name: opCreatePlacementGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreatePlacementGroupInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &CreatePlacementGroupOutput{}
- req.Data = output
- return
- }
- // Creates a placement group that you launch cluster instances into. You must
- // give the group a name that's unique within the scope of your account.
- //
- // For more information about placement groups and cluster instances, see Cluster
- // Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using_cluster_computing.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreatePlacementGroup(input *CreatePlacementGroupInput) (*CreatePlacementGroupOutput, error) {
- req, out := c.CreatePlacementGroupRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateReservedInstancesListing = "CreateReservedInstancesListing"
- // CreateReservedInstancesListingRequest generates a "aws/request.Request" representing the
- // client's request for the CreateReservedInstancesListing operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateReservedInstancesListing method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateReservedInstancesListingRequest method.
- // req, resp := client.CreateReservedInstancesListingRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateReservedInstancesListingRequest(input *CreateReservedInstancesListingInput) (req *request.Request, output *CreateReservedInstancesListingOutput) {
- op := &request.Operation{
- Name: opCreateReservedInstancesListing,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateReservedInstancesListingInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateReservedInstancesListingOutput{}
- req.Data = output
- return
- }
- // Creates a listing for Amazon EC2 Reserved Instances to be sold in the Reserved
- // Instance Marketplace. You can submit one Reserved Instance listing at a time.
- // To get a list of your Reserved Instances, you can use the DescribeReservedInstances
- // operation.
- //
- // The Reserved Instance Marketplace matches sellers who want to resell Reserved
- // Instance capacity that they no longer need with buyers who want to purchase
- // additional capacity. Reserved Instances bought and sold through the Reserved
- // Instance Marketplace work like any other Reserved Instances.
- //
- // To sell your Reserved Instances, you must first register as a seller in
- // the Reserved Instance Marketplace. After completing the registration process,
- // you can create a Reserved Instance Marketplace listing of some or all of
- // your Reserved Instances, and specify the upfront price to receive for them.
- // Your Reserved Instance listings then become available for purchase. To view
- // the details of your Reserved Instance listing, you can use the DescribeReservedInstancesListings
- // operation.
- //
- // For more information, see Reserved Instance Marketplace (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ri-market-general.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateReservedInstancesListing(input *CreateReservedInstancesListingInput) (*CreateReservedInstancesListingOutput, error) {
- req, out := c.CreateReservedInstancesListingRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateRoute = "CreateRoute"
- // CreateRouteRequest generates a "aws/request.Request" representing the
- // client's request for the CreateRoute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateRoute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateRouteRequest method.
- // req, resp := client.CreateRouteRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateRouteRequest(input *CreateRouteInput) (req *request.Request, output *CreateRouteOutput) {
- op := &request.Operation{
- Name: opCreateRoute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateRouteInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateRouteOutput{}
- req.Data = output
- return
- }
- // Creates a route in a route table within a VPC.
- //
- // You must specify one of the following targets: Internet gateway or virtual
- // private gateway, NAT instance, NAT gateway, VPC peering connection, or network
- // interface.
- //
- // When determining how to route traffic, we use the route with the most specific
- // match. For example, let's say the traffic is destined for 192.0.2.3, and
- // the route table includes the following two routes:
- //
- // 192.0.2.0/24 (goes to some target A)
- //
- // 192.0.2.0/28 (goes to some target B)
- //
- // Both routes apply to the traffic destined for 192.0.2.3. However, the
- // second route in the list covers a smaller number of IP addresses and is therefore
- // more specific, so we use that route to determine where to target the traffic.
- //
- // For more information about route tables, see Route Tables (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Route_Tables.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateRoute(input *CreateRouteInput) (*CreateRouteOutput, error) {
- req, out := c.CreateRouteRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateRouteTable = "CreateRouteTable"
- // CreateRouteTableRequest generates a "aws/request.Request" representing the
- // client's request for the CreateRouteTable operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateRouteTable method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateRouteTableRequest method.
- // req, resp := client.CreateRouteTableRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateRouteTableRequest(input *CreateRouteTableInput) (req *request.Request, output *CreateRouteTableOutput) {
- op := &request.Operation{
- Name: opCreateRouteTable,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateRouteTableInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateRouteTableOutput{}
- req.Data = output
- return
- }
- // Creates a route table for the specified VPC. After you create a route table,
- // you can add routes and associate the table with a subnet.
- //
- // For more information about route tables, see Route Tables (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Route_Tables.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateRouteTable(input *CreateRouteTableInput) (*CreateRouteTableOutput, error) {
- req, out := c.CreateRouteTableRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateSecurityGroup = "CreateSecurityGroup"
- // CreateSecurityGroupRequest generates a "aws/request.Request" representing the
- // client's request for the CreateSecurityGroup operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateSecurityGroup method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateSecurityGroupRequest method.
- // req, resp := client.CreateSecurityGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateSecurityGroupRequest(input *CreateSecurityGroupInput) (req *request.Request, output *CreateSecurityGroupOutput) {
- op := &request.Operation{
- Name: opCreateSecurityGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateSecurityGroupInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateSecurityGroupOutput{}
- req.Data = output
- return
- }
- // Creates a security group.
- //
- // A security group is for use with instances either in the EC2-Classic platform
- // or in a specific VPC. For more information, see Amazon EC2 Security Groups
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-network-security.html)
- // in the Amazon Elastic Compute Cloud User Guide and Security Groups for Your
- // VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_SecurityGroups.html)
- // in the Amazon Virtual Private Cloud User Guide.
- //
- // EC2-Classic: You can have up to 500 security groups.
- //
- // EC2-VPC: You can create up to 500 security groups per VPC.
- //
- // When you create a security group, you specify a friendly name of your choice.
- // You can have a security group for use in EC2-Classic with the same name as
- // a security group for use in a VPC. However, you can't have two security groups
- // for use in EC2-Classic with the same name or two security groups for use
- // in a VPC with the same name.
- //
- // You have a default security group for use in EC2-Classic and a default security
- // group for use in your VPC. If you don't specify a security group when you
- // launch an instance, the instance is launched into the appropriate default
- // security group. A default security group includes a default rule that grants
- // instances unrestricted network access to each other.
- //
- // You can add or remove rules from your security groups using AuthorizeSecurityGroupIngress,
- // AuthorizeSecurityGroupEgress, RevokeSecurityGroupIngress, and RevokeSecurityGroupEgress.
- func (c *EC2) CreateSecurityGroup(input *CreateSecurityGroupInput) (*CreateSecurityGroupOutput, error) {
- req, out := c.CreateSecurityGroupRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateSnapshot = "CreateSnapshot"
- // CreateSnapshotRequest generates a "aws/request.Request" representing the
- // client's request for the CreateSnapshot operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateSnapshot method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateSnapshotRequest method.
- // req, resp := client.CreateSnapshotRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateSnapshotRequest(input *CreateSnapshotInput) (req *request.Request, output *Snapshot) {
- op := &request.Operation{
- Name: opCreateSnapshot,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateSnapshotInput{}
- }
- req = c.newRequest(op, input, output)
- output = &Snapshot{}
- req.Data = output
- return
- }
- // Creates a snapshot of an EBS volume and stores it in Amazon S3. You can use
- // snapshots for backups, to make copies of EBS volumes, and to save data before
- // shutting down an instance.
- //
- // When a snapshot is created, any AWS Marketplace product codes that are associated
- // with the source volume are propagated to the snapshot.
- //
- // You can take a snapshot of an attached volume that is in use. However, snapshots
- // only capture data that has been written to your EBS volume at the time the
- // snapshot command is issued; this may exclude any data that has been cached
- // by any applications or the operating system. If you can pause any file systems
- // on the volume long enough to take a snapshot, your snapshot should be complete.
- // However, if you cannot pause all file writes to the volume, you should unmount
- // the volume from within the instance, issue the snapshot command, and then
- // remount the volume to ensure a consistent and complete snapshot. You may
- // remount and use your volume while the snapshot status is pending.
- //
- // To create a snapshot for EBS volumes that serve as root devices, you should
- // stop the instance before taking the snapshot.
- //
- // Snapshots that are taken from encrypted volumes are automatically encrypted.
- // Volumes that are created from encrypted snapshots are also automatically
- // encrypted. Your encrypted volumes and any associated snapshots always remain
- // protected.
- //
- // For more information, see Amazon Elastic Block Store (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/AmazonEBS.html)
- // and Amazon EBS Encryption (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateSnapshot(input *CreateSnapshotInput) (*Snapshot, error) {
- req, out := c.CreateSnapshotRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateSpotDatafeedSubscription = "CreateSpotDatafeedSubscription"
- // CreateSpotDatafeedSubscriptionRequest generates a "aws/request.Request" representing the
- // client's request for the CreateSpotDatafeedSubscription operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateSpotDatafeedSubscription method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateSpotDatafeedSubscriptionRequest method.
- // req, resp := client.CreateSpotDatafeedSubscriptionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateSpotDatafeedSubscriptionRequest(input *CreateSpotDatafeedSubscriptionInput) (req *request.Request, output *CreateSpotDatafeedSubscriptionOutput) {
- op := &request.Operation{
- Name: opCreateSpotDatafeedSubscription,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateSpotDatafeedSubscriptionInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateSpotDatafeedSubscriptionOutput{}
- req.Data = output
- return
- }
- // Creates a data feed for Spot instances, enabling you to view Spot instance
- // usage logs. You can create one data feed per AWS account. For more information,
- // see Spot Instance Data Feed (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-data-feeds.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateSpotDatafeedSubscription(input *CreateSpotDatafeedSubscriptionInput) (*CreateSpotDatafeedSubscriptionOutput, error) {
- req, out := c.CreateSpotDatafeedSubscriptionRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateSubnet = "CreateSubnet"
- // CreateSubnetRequest generates a "aws/request.Request" representing the
- // client's request for the CreateSubnet operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateSubnet method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateSubnetRequest method.
- // req, resp := client.CreateSubnetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateSubnetRequest(input *CreateSubnetInput) (req *request.Request, output *CreateSubnetOutput) {
- op := &request.Operation{
- Name: opCreateSubnet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateSubnetInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateSubnetOutput{}
- req.Data = output
- return
- }
- // Creates a subnet in an existing VPC.
- //
- // When you create each subnet, you provide the VPC ID and the CIDR block you
- // want for the subnet. After you create a subnet, you can't change its CIDR
- // block. The subnet's CIDR block can be the same as the VPC's CIDR block (assuming
- // you want only a single subnet in the VPC), or a subset of the VPC's CIDR
- // block. If you create more than one subnet in a VPC, the subnets' CIDR blocks
- // must not overlap. The smallest subnet (and VPC) you can create uses a /28
- // netmask (16 IP addresses), and the largest uses a /16 netmask (65,536 IP
- // addresses).
- //
- // AWS reserves both the first four and the last IP address in each subnet's
- // CIDR block. They're not available for use.
- //
- // If you add more than one subnet to a VPC, they're set up in a star topology
- // with a logical router in the middle.
- //
- // If you launch an instance in a VPC using an Amazon EBS-backed AMI, the IP
- // address doesn't change if you stop and restart the instance (unlike a similar
- // instance launched outside a VPC, which gets a new IP address when restarted).
- // It's therefore possible to have a subnet with no running instances (they're
- // all stopped), but no remaining IP addresses available.
- //
- // For more information about subnets, see Your VPC and Subnets (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Subnets.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateSubnet(input *CreateSubnetInput) (*CreateSubnetOutput, error) {
- req, out := c.CreateSubnetRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateTags = "CreateTags"
- // CreateTagsRequest generates a "aws/request.Request" representing the
- // client's request for the CreateTags operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateTags method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateTagsRequest method.
- // req, resp := client.CreateTagsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateTagsRequest(input *CreateTagsInput) (req *request.Request, output *CreateTagsOutput) {
- op := &request.Operation{
- Name: opCreateTags,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateTagsInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &CreateTagsOutput{}
- req.Data = output
- return
- }
- // Adds or overwrites one or more tags for the specified Amazon EC2 resource
- // or resources. Each resource can have a maximum of 10 tags. Each tag consists
- // of a key and optional value. Tag keys must be unique per resource.
- //
- // For more information about tags, see Tagging Your Resources (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html)
- // in the Amazon Elastic Compute Cloud User Guide. For more information about
- // creating IAM policies that control users' access to resources based on tags,
- // see Supported Resource-Level Permissions for Amazon EC2 API Actions (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-supported-iam-actions-resources.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateTags(input *CreateTagsInput) (*CreateTagsOutput, error) {
- req, out := c.CreateTagsRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateVolume = "CreateVolume"
- // CreateVolumeRequest generates a "aws/request.Request" representing the
- // client's request for the CreateVolume operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateVolume method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateVolumeRequest method.
- // req, resp := client.CreateVolumeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateVolumeRequest(input *CreateVolumeInput) (req *request.Request, output *Volume) {
- op := &request.Operation{
- Name: opCreateVolume,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateVolumeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &Volume{}
- req.Data = output
- return
- }
- // Creates an EBS volume that can be attached to an instance in the same Availability
- // Zone. The volume is created in the regional endpoint that you send the HTTP
- // request to. For more information see Regions and Endpoints (http://docs.aws.amazon.com/general/latest/gr/rande.html).
- //
- // You can create a new empty volume or restore a volume from an EBS snapshot.
- // Any AWS Marketplace product codes from the snapshot are propagated to the
- // volume.
- //
- // You can create encrypted volumes with the Encrypted parameter. Encrypted
- // volumes may only be attached to instances that support Amazon EBS encryption.
- // Volumes that are created from encrypted snapshots are also automatically
- // encrypted. For more information, see Amazon EBS Encryption (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // For more information, see Creating or Restoring an Amazon EBS Volume (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-creating-volume.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) CreateVolume(input *CreateVolumeInput) (*Volume, error) {
- req, out := c.CreateVolumeRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateVpc = "CreateVpc"
- // CreateVpcRequest generates a "aws/request.Request" representing the
- // client's request for the CreateVpc operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateVpc method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateVpcRequest method.
- // req, resp := client.CreateVpcRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateVpcRequest(input *CreateVpcInput) (req *request.Request, output *CreateVpcOutput) {
- op := &request.Operation{
- Name: opCreateVpc,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateVpcInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateVpcOutput{}
- req.Data = output
- return
- }
- // Creates a VPC with the specified CIDR block.
- //
- // The smallest VPC you can create uses a /28 netmask (16 IP addresses), and
- // the largest uses a /16 netmask (65,536 IP addresses). To help you decide
- // how big to make your VPC, see Your VPC and Subnets (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Subnets.html)
- // in the Amazon Virtual Private Cloud User Guide.
- //
- // By default, each instance you launch in the VPC has the default DHCP options,
- // which includes only a default DNS server that we provide (AmazonProvidedDNS).
- // For more information about DHCP options, see DHCP Options Sets (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_DHCP_Options.html)
- // in the Amazon Virtual Private Cloud User Guide.
- //
- // You can specify the instance tenancy value for the VPC when you create it.
- // You can't change this value for the VPC after you create it. For more information,
- // see Dedicated Instances (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/dedicated-instance.html.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateVpc(input *CreateVpcInput) (*CreateVpcOutput, error) {
- req, out := c.CreateVpcRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateVpcEndpoint = "CreateVpcEndpoint"
- // CreateVpcEndpointRequest generates a "aws/request.Request" representing the
- // client's request for the CreateVpcEndpoint operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateVpcEndpoint method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateVpcEndpointRequest method.
- // req, resp := client.CreateVpcEndpointRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateVpcEndpointRequest(input *CreateVpcEndpointInput) (req *request.Request, output *CreateVpcEndpointOutput) {
- op := &request.Operation{
- Name: opCreateVpcEndpoint,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateVpcEndpointInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateVpcEndpointOutput{}
- req.Data = output
- return
- }
- // Creates a VPC endpoint for a specified AWS service. An endpoint enables you
- // to create a private connection between your VPC and another AWS service in
- // your account. You can specify an endpoint policy to attach to the endpoint
- // that will control access to the service from your VPC. You can also specify
- // the VPC route tables that use the endpoint.
- //
- // Currently, only endpoints to Amazon S3 are supported.
- func (c *EC2) CreateVpcEndpoint(input *CreateVpcEndpointInput) (*CreateVpcEndpointOutput, error) {
- req, out := c.CreateVpcEndpointRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateVpcPeeringConnection = "CreateVpcPeeringConnection"
- // CreateVpcPeeringConnectionRequest generates a "aws/request.Request" representing the
- // client's request for the CreateVpcPeeringConnection operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateVpcPeeringConnection method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateVpcPeeringConnectionRequest method.
- // req, resp := client.CreateVpcPeeringConnectionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateVpcPeeringConnectionRequest(input *CreateVpcPeeringConnectionInput) (req *request.Request, output *CreateVpcPeeringConnectionOutput) {
- op := &request.Operation{
- Name: opCreateVpcPeeringConnection,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateVpcPeeringConnectionInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateVpcPeeringConnectionOutput{}
- req.Data = output
- return
- }
- // Requests a VPC peering connection between two VPCs: a requester VPC that
- // you own and a peer VPC with which to create the connection. The peer VPC
- // can belong to another AWS account. The requester VPC and peer VPC cannot
- // have overlapping CIDR blocks.
- //
- // The owner of the peer VPC must accept the peering request to activate the
- // peering connection. The VPC peering connection request expires after 7 days,
- // after which it cannot be accepted or rejected.
- //
- // A CreateVpcPeeringConnection request between VPCs with overlapping CIDR
- // blocks results in the VPC peering connection having a status of failed.
- func (c *EC2) CreateVpcPeeringConnection(input *CreateVpcPeeringConnectionInput) (*CreateVpcPeeringConnectionOutput, error) {
- req, out := c.CreateVpcPeeringConnectionRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateVpnConnection = "CreateVpnConnection"
- // CreateVpnConnectionRequest generates a "aws/request.Request" representing the
- // client's request for the CreateVpnConnection operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateVpnConnection method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateVpnConnectionRequest method.
- // req, resp := client.CreateVpnConnectionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateVpnConnectionRequest(input *CreateVpnConnectionInput) (req *request.Request, output *CreateVpnConnectionOutput) {
- op := &request.Operation{
- Name: opCreateVpnConnection,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateVpnConnectionInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateVpnConnectionOutput{}
- req.Data = output
- return
- }
- // Creates a VPN connection between an existing virtual private gateway and
- // a VPN customer gateway. The only supported connection type is ipsec.1.
- //
- // The response includes information that you need to give to your network
- // administrator to configure your customer gateway.
- //
- // We strongly recommend that you use HTTPS when calling this operation because
- // the response contains sensitive cryptographic information for configuring
- // your customer gateway.
- //
- // If you decide to shut down your VPN connection for any reason and later
- // create a new VPN connection, you must reconfigure your customer gateway with
- // the new information returned from this call.
- //
- // This is an idempotent operation. If you perform the operation more than
- // once, Amazon EC2 doesn't return an error.
- //
- // For more information about VPN connections, see Adding a Hardware Virtual
- // Private Gateway to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateVpnConnection(input *CreateVpnConnectionInput) (*CreateVpnConnectionOutput, error) {
- req, out := c.CreateVpnConnectionRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateVpnConnectionRoute = "CreateVpnConnectionRoute"
- // CreateVpnConnectionRouteRequest generates a "aws/request.Request" representing the
- // client's request for the CreateVpnConnectionRoute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateVpnConnectionRoute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateVpnConnectionRouteRequest method.
- // req, resp := client.CreateVpnConnectionRouteRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateVpnConnectionRouteRequest(input *CreateVpnConnectionRouteInput) (req *request.Request, output *CreateVpnConnectionRouteOutput) {
- op := &request.Operation{
- Name: opCreateVpnConnectionRoute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateVpnConnectionRouteInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &CreateVpnConnectionRouteOutput{}
- req.Data = output
- return
- }
- // Creates a static route associated with a VPN connection between an existing
- // virtual private gateway and a VPN customer gateway. The static route allows
- // traffic to be routed from the virtual private gateway to the VPN customer
- // gateway.
- //
- // For more information about VPN connections, see Adding a Hardware Virtual
- // Private Gateway to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateVpnConnectionRoute(input *CreateVpnConnectionRouteInput) (*CreateVpnConnectionRouteOutput, error) {
- req, out := c.CreateVpnConnectionRouteRequest(input)
- err := req.Send()
- return out, err
- }
- const opCreateVpnGateway = "CreateVpnGateway"
- // CreateVpnGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the CreateVpnGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the CreateVpnGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the CreateVpnGatewayRequest method.
- // req, resp := client.CreateVpnGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) CreateVpnGatewayRequest(input *CreateVpnGatewayInput) (req *request.Request, output *CreateVpnGatewayOutput) {
- op := &request.Operation{
- Name: opCreateVpnGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateVpnGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- output = &CreateVpnGatewayOutput{}
- req.Data = output
- return
- }
- // Creates a virtual private gateway. A virtual private gateway is the endpoint
- // on the VPC side of your VPN connection. You can create a virtual private
- // gateway before creating the VPC itself.
- //
- // For more information about virtual private gateways, see Adding a Hardware
- // Virtual Private Gateway to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) CreateVpnGateway(input *CreateVpnGatewayInput) (*CreateVpnGatewayOutput, error) {
- req, out := c.CreateVpnGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteCustomerGateway = "DeleteCustomerGateway"
- // DeleteCustomerGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteCustomerGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteCustomerGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteCustomerGatewayRequest method.
- // req, resp := client.DeleteCustomerGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteCustomerGatewayRequest(input *DeleteCustomerGatewayInput) (req *request.Request, output *DeleteCustomerGatewayOutput) {
- op := &request.Operation{
- Name: opDeleteCustomerGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteCustomerGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteCustomerGatewayOutput{}
- req.Data = output
- return
- }
- // Deletes the specified customer gateway. You must delete the VPN connection
- // before you can delete the customer gateway.
- func (c *EC2) DeleteCustomerGateway(input *DeleteCustomerGatewayInput) (*DeleteCustomerGatewayOutput, error) {
- req, out := c.DeleteCustomerGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteDhcpOptions = "DeleteDhcpOptions"
- // DeleteDhcpOptionsRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteDhcpOptions operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteDhcpOptions method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteDhcpOptionsRequest method.
- // req, resp := client.DeleteDhcpOptionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteDhcpOptionsRequest(input *DeleteDhcpOptionsInput) (req *request.Request, output *DeleteDhcpOptionsOutput) {
- op := &request.Operation{
- Name: opDeleteDhcpOptions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteDhcpOptionsInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteDhcpOptionsOutput{}
- req.Data = output
- return
- }
- // Deletes the specified set of DHCP options. You must disassociate the set
- // of DHCP options before you can delete it. You can disassociate the set of
- // DHCP options by associating either a new set of options or the default set
- // of options with the VPC.
- func (c *EC2) DeleteDhcpOptions(input *DeleteDhcpOptionsInput) (*DeleteDhcpOptionsOutput, error) {
- req, out := c.DeleteDhcpOptionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteFlowLogs = "DeleteFlowLogs"
- // DeleteFlowLogsRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteFlowLogs operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteFlowLogs method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteFlowLogsRequest method.
- // req, resp := client.DeleteFlowLogsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteFlowLogsRequest(input *DeleteFlowLogsInput) (req *request.Request, output *DeleteFlowLogsOutput) {
- op := &request.Operation{
- Name: opDeleteFlowLogs,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteFlowLogsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DeleteFlowLogsOutput{}
- req.Data = output
- return
- }
- // Deletes one or more flow logs.
- func (c *EC2) DeleteFlowLogs(input *DeleteFlowLogsInput) (*DeleteFlowLogsOutput, error) {
- req, out := c.DeleteFlowLogsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteInternetGateway = "DeleteInternetGateway"
- // DeleteInternetGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteInternetGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteInternetGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteInternetGatewayRequest method.
- // req, resp := client.DeleteInternetGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteInternetGatewayRequest(input *DeleteInternetGatewayInput) (req *request.Request, output *DeleteInternetGatewayOutput) {
- op := &request.Operation{
- Name: opDeleteInternetGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteInternetGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteInternetGatewayOutput{}
- req.Data = output
- return
- }
- // Deletes the specified Internet gateway. You must detach the Internet gateway
- // from the VPC before you can delete it.
- func (c *EC2) DeleteInternetGateway(input *DeleteInternetGatewayInput) (*DeleteInternetGatewayOutput, error) {
- req, out := c.DeleteInternetGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteKeyPair = "DeleteKeyPair"
- // DeleteKeyPairRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteKeyPair operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteKeyPair method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteKeyPairRequest method.
- // req, resp := client.DeleteKeyPairRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteKeyPairRequest(input *DeleteKeyPairInput) (req *request.Request, output *DeleteKeyPairOutput) {
- op := &request.Operation{
- Name: opDeleteKeyPair,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteKeyPairInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteKeyPairOutput{}
- req.Data = output
- return
- }
- // Deletes the specified key pair, by removing the public key from Amazon EC2.
- func (c *EC2) DeleteKeyPair(input *DeleteKeyPairInput) (*DeleteKeyPairOutput, error) {
- req, out := c.DeleteKeyPairRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteNatGateway = "DeleteNatGateway"
- // DeleteNatGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteNatGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteNatGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteNatGatewayRequest method.
- // req, resp := client.DeleteNatGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteNatGatewayRequest(input *DeleteNatGatewayInput) (req *request.Request, output *DeleteNatGatewayOutput) {
- op := &request.Operation{
- Name: opDeleteNatGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteNatGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DeleteNatGatewayOutput{}
- req.Data = output
- return
- }
- // Deletes the specified NAT gateway. Deleting a NAT gateway disassociates its
- // Elastic IP address, but does not release the address from your account. Deleting
- // a NAT gateway does not delete any NAT gateway routes in your route tables.
- func (c *EC2) DeleteNatGateway(input *DeleteNatGatewayInput) (*DeleteNatGatewayOutput, error) {
- req, out := c.DeleteNatGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteNetworkAcl = "DeleteNetworkAcl"
- // DeleteNetworkAclRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteNetworkAcl operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteNetworkAcl method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteNetworkAclRequest method.
- // req, resp := client.DeleteNetworkAclRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteNetworkAclRequest(input *DeleteNetworkAclInput) (req *request.Request, output *DeleteNetworkAclOutput) {
- op := &request.Operation{
- Name: opDeleteNetworkAcl,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteNetworkAclInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteNetworkAclOutput{}
- req.Data = output
- return
- }
- // Deletes the specified network ACL. You can't delete the ACL if it's associated
- // with any subnets. You can't delete the default network ACL.
- func (c *EC2) DeleteNetworkAcl(input *DeleteNetworkAclInput) (*DeleteNetworkAclOutput, error) {
- req, out := c.DeleteNetworkAclRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteNetworkAclEntry = "DeleteNetworkAclEntry"
- // DeleteNetworkAclEntryRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteNetworkAclEntry operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteNetworkAclEntry method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteNetworkAclEntryRequest method.
- // req, resp := client.DeleteNetworkAclEntryRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteNetworkAclEntryRequest(input *DeleteNetworkAclEntryInput) (req *request.Request, output *DeleteNetworkAclEntryOutput) {
- op := &request.Operation{
- Name: opDeleteNetworkAclEntry,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteNetworkAclEntryInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteNetworkAclEntryOutput{}
- req.Data = output
- return
- }
- // Deletes the specified ingress or egress entry (rule) from the specified network
- // ACL.
- func (c *EC2) DeleteNetworkAclEntry(input *DeleteNetworkAclEntryInput) (*DeleteNetworkAclEntryOutput, error) {
- req, out := c.DeleteNetworkAclEntryRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteNetworkInterface = "DeleteNetworkInterface"
- // DeleteNetworkInterfaceRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteNetworkInterface operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteNetworkInterface method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteNetworkInterfaceRequest method.
- // req, resp := client.DeleteNetworkInterfaceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteNetworkInterfaceRequest(input *DeleteNetworkInterfaceInput) (req *request.Request, output *DeleteNetworkInterfaceOutput) {
- op := &request.Operation{
- Name: opDeleteNetworkInterface,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteNetworkInterfaceInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteNetworkInterfaceOutput{}
- req.Data = output
- return
- }
- // Deletes the specified network interface. You must detach the network interface
- // before you can delete it.
- func (c *EC2) DeleteNetworkInterface(input *DeleteNetworkInterfaceInput) (*DeleteNetworkInterfaceOutput, error) {
- req, out := c.DeleteNetworkInterfaceRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeletePlacementGroup = "DeletePlacementGroup"
- // DeletePlacementGroupRequest generates a "aws/request.Request" representing the
- // client's request for the DeletePlacementGroup operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeletePlacementGroup method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeletePlacementGroupRequest method.
- // req, resp := client.DeletePlacementGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeletePlacementGroupRequest(input *DeletePlacementGroupInput) (req *request.Request, output *DeletePlacementGroupOutput) {
- op := &request.Operation{
- Name: opDeletePlacementGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeletePlacementGroupInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeletePlacementGroupOutput{}
- req.Data = output
- return
- }
- // Deletes the specified placement group. You must terminate all instances in
- // the placement group before you can delete the placement group. For more information
- // about placement groups and cluster instances, see Cluster Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using_cluster_computing.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DeletePlacementGroup(input *DeletePlacementGroupInput) (*DeletePlacementGroupOutput, error) {
- req, out := c.DeletePlacementGroupRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteRoute = "DeleteRoute"
- // DeleteRouteRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteRoute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteRoute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteRouteRequest method.
- // req, resp := client.DeleteRouteRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteRouteRequest(input *DeleteRouteInput) (req *request.Request, output *DeleteRouteOutput) {
- op := &request.Operation{
- Name: opDeleteRoute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteRouteInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteRouteOutput{}
- req.Data = output
- return
- }
- // Deletes the specified route from the specified route table.
- func (c *EC2) DeleteRoute(input *DeleteRouteInput) (*DeleteRouteOutput, error) {
- req, out := c.DeleteRouteRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteRouteTable = "DeleteRouteTable"
- // DeleteRouteTableRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteRouteTable operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteRouteTable method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteRouteTableRequest method.
- // req, resp := client.DeleteRouteTableRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteRouteTableRequest(input *DeleteRouteTableInput) (req *request.Request, output *DeleteRouteTableOutput) {
- op := &request.Operation{
- Name: opDeleteRouteTable,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteRouteTableInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteRouteTableOutput{}
- req.Data = output
- return
- }
- // Deletes the specified route table. You must disassociate the route table
- // from any subnets before you can delete it. You can't delete the main route
- // table.
- func (c *EC2) DeleteRouteTable(input *DeleteRouteTableInput) (*DeleteRouteTableOutput, error) {
- req, out := c.DeleteRouteTableRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteSecurityGroup = "DeleteSecurityGroup"
- // DeleteSecurityGroupRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteSecurityGroup operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteSecurityGroup method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteSecurityGroupRequest method.
- // req, resp := client.DeleteSecurityGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteSecurityGroupRequest(input *DeleteSecurityGroupInput) (req *request.Request, output *DeleteSecurityGroupOutput) {
- op := &request.Operation{
- Name: opDeleteSecurityGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteSecurityGroupInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteSecurityGroupOutput{}
- req.Data = output
- return
- }
- // Deletes a security group.
- //
- // If you attempt to delete a security group that is associated with an instance,
- // or is referenced by another security group, the operation fails with InvalidGroup.InUse
- // in EC2-Classic or DependencyViolation in EC2-VPC.
- func (c *EC2) DeleteSecurityGroup(input *DeleteSecurityGroupInput) (*DeleteSecurityGroupOutput, error) {
- req, out := c.DeleteSecurityGroupRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteSnapshot = "DeleteSnapshot"
- // DeleteSnapshotRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteSnapshot operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteSnapshot method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteSnapshotRequest method.
- // req, resp := client.DeleteSnapshotRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteSnapshotRequest(input *DeleteSnapshotInput) (req *request.Request, output *DeleteSnapshotOutput) {
- op := &request.Operation{
- Name: opDeleteSnapshot,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteSnapshotInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteSnapshotOutput{}
- req.Data = output
- return
- }
- // Deletes the specified snapshot.
- //
- // When you make periodic snapshots of a volume, the snapshots are incremental,
- // and only the blocks on the device that have changed since your last snapshot
- // are saved in the new snapshot. When you delete a snapshot, only the data
- // not needed for any other snapshot is removed. So regardless of which prior
- // snapshots have been deleted, all active snapshots will have access to all
- // the information needed to restore the volume.
- //
- // You cannot delete a snapshot of the root device of an EBS volume used by
- // a registered AMI. You must first de-register the AMI before you can delete
- // the snapshot.
- //
- // For more information, see Deleting an Amazon EBS Snapshot (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-deleting-snapshot.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DeleteSnapshot(input *DeleteSnapshotInput) (*DeleteSnapshotOutput, error) {
- req, out := c.DeleteSnapshotRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteSpotDatafeedSubscription = "DeleteSpotDatafeedSubscription"
- // DeleteSpotDatafeedSubscriptionRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteSpotDatafeedSubscription operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteSpotDatafeedSubscription method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteSpotDatafeedSubscriptionRequest method.
- // req, resp := client.DeleteSpotDatafeedSubscriptionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteSpotDatafeedSubscriptionRequest(input *DeleteSpotDatafeedSubscriptionInput) (req *request.Request, output *DeleteSpotDatafeedSubscriptionOutput) {
- op := &request.Operation{
- Name: opDeleteSpotDatafeedSubscription,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteSpotDatafeedSubscriptionInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteSpotDatafeedSubscriptionOutput{}
- req.Data = output
- return
- }
- // Deletes the data feed for Spot instances.
- func (c *EC2) DeleteSpotDatafeedSubscription(input *DeleteSpotDatafeedSubscriptionInput) (*DeleteSpotDatafeedSubscriptionOutput, error) {
- req, out := c.DeleteSpotDatafeedSubscriptionRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteSubnet = "DeleteSubnet"
- // DeleteSubnetRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteSubnet operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteSubnet method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteSubnetRequest method.
- // req, resp := client.DeleteSubnetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteSubnetRequest(input *DeleteSubnetInput) (req *request.Request, output *DeleteSubnetOutput) {
- op := &request.Operation{
- Name: opDeleteSubnet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteSubnetInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteSubnetOutput{}
- req.Data = output
- return
- }
- // Deletes the specified subnet. You must terminate all running instances in
- // the subnet before you can delete the subnet.
- func (c *EC2) DeleteSubnet(input *DeleteSubnetInput) (*DeleteSubnetOutput, error) {
- req, out := c.DeleteSubnetRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteTags = "DeleteTags"
- // DeleteTagsRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteTags operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteTags method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteTagsRequest method.
- // req, resp := client.DeleteTagsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteTagsRequest(input *DeleteTagsInput) (req *request.Request, output *DeleteTagsOutput) {
- op := &request.Operation{
- Name: opDeleteTags,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteTagsInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteTagsOutput{}
- req.Data = output
- return
- }
- // Deletes the specified set of tags from the specified set of resources. This
- // call is designed to follow a DescribeTags request.
- //
- // For more information about tags, see Tagging Your Resources (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DeleteTags(input *DeleteTagsInput) (*DeleteTagsOutput, error) {
- req, out := c.DeleteTagsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteVolume = "DeleteVolume"
- // DeleteVolumeRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteVolume operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteVolume method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteVolumeRequest method.
- // req, resp := client.DeleteVolumeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteVolumeRequest(input *DeleteVolumeInput) (req *request.Request, output *DeleteVolumeOutput) {
- op := &request.Operation{
- Name: opDeleteVolume,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteVolumeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteVolumeOutput{}
- req.Data = output
- return
- }
- // Deletes the specified EBS volume. The volume must be in the available state
- // (not attached to an instance).
- //
- // The volume may remain in the deleting state for several minutes.
- //
- // For more information, see Deleting an Amazon EBS Volume (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-deleting-volume.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DeleteVolume(input *DeleteVolumeInput) (*DeleteVolumeOutput, error) {
- req, out := c.DeleteVolumeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteVpc = "DeleteVpc"
- // DeleteVpcRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteVpc operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteVpc method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteVpcRequest method.
- // req, resp := client.DeleteVpcRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteVpcRequest(input *DeleteVpcInput) (req *request.Request, output *DeleteVpcOutput) {
- op := &request.Operation{
- Name: opDeleteVpc,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteVpcInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteVpcOutput{}
- req.Data = output
- return
- }
- // Deletes the specified VPC. You must detach or delete all gateways and resources
- // that are associated with the VPC before you can delete it. For example, you
- // must terminate all instances running in the VPC, delete all security groups
- // associated with the VPC (except the default one), delete all route tables
- // associated with the VPC (except the default one), and so on.
- func (c *EC2) DeleteVpc(input *DeleteVpcInput) (*DeleteVpcOutput, error) {
- req, out := c.DeleteVpcRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteVpcEndpoints = "DeleteVpcEndpoints"
- // DeleteVpcEndpointsRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteVpcEndpoints operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteVpcEndpoints method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteVpcEndpointsRequest method.
- // req, resp := client.DeleteVpcEndpointsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteVpcEndpointsRequest(input *DeleteVpcEndpointsInput) (req *request.Request, output *DeleteVpcEndpointsOutput) {
- op := &request.Operation{
- Name: opDeleteVpcEndpoints,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteVpcEndpointsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DeleteVpcEndpointsOutput{}
- req.Data = output
- return
- }
- // Deletes one or more specified VPC endpoints. Deleting the endpoint also deletes
- // the endpoint routes in the route tables that were associated with the endpoint.
- func (c *EC2) DeleteVpcEndpoints(input *DeleteVpcEndpointsInput) (*DeleteVpcEndpointsOutput, error) {
- req, out := c.DeleteVpcEndpointsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteVpcPeeringConnection = "DeleteVpcPeeringConnection"
- // DeleteVpcPeeringConnectionRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteVpcPeeringConnection operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteVpcPeeringConnection method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteVpcPeeringConnectionRequest method.
- // req, resp := client.DeleteVpcPeeringConnectionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteVpcPeeringConnectionRequest(input *DeleteVpcPeeringConnectionInput) (req *request.Request, output *DeleteVpcPeeringConnectionOutput) {
- op := &request.Operation{
- Name: opDeleteVpcPeeringConnection,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteVpcPeeringConnectionInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DeleteVpcPeeringConnectionOutput{}
- req.Data = output
- return
- }
- // Deletes a VPC peering connection. Either the owner of the requester VPC or
- // the owner of the peer VPC can delete the VPC peering connection if it's in
- // the active state. The owner of the requester VPC can delete a VPC peering
- // connection in the pending-acceptance state.
- func (c *EC2) DeleteVpcPeeringConnection(input *DeleteVpcPeeringConnectionInput) (*DeleteVpcPeeringConnectionOutput, error) {
- req, out := c.DeleteVpcPeeringConnectionRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteVpnConnection = "DeleteVpnConnection"
- // DeleteVpnConnectionRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteVpnConnection operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteVpnConnection method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteVpnConnectionRequest method.
- // req, resp := client.DeleteVpnConnectionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteVpnConnectionRequest(input *DeleteVpnConnectionInput) (req *request.Request, output *DeleteVpnConnectionOutput) {
- op := &request.Operation{
- Name: opDeleteVpnConnection,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteVpnConnectionInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteVpnConnectionOutput{}
- req.Data = output
- return
- }
- // Deletes the specified VPN connection.
- //
- // If you're deleting the VPC and its associated components, we recommend that
- // you detach the virtual private gateway from the VPC and delete the VPC before
- // deleting the VPN connection. If you believe that the tunnel credentials for
- // your VPN connection have been compromised, you can delete the VPN connection
- // and create a new one that has new keys, without needing to delete the VPC
- // or virtual private gateway. If you create a new VPN connection, you must
- // reconfigure the customer gateway using the new configuration information
- // returned with the new VPN connection ID.
- func (c *EC2) DeleteVpnConnection(input *DeleteVpnConnectionInput) (*DeleteVpnConnectionOutput, error) {
- req, out := c.DeleteVpnConnectionRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteVpnConnectionRoute = "DeleteVpnConnectionRoute"
- // DeleteVpnConnectionRouteRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteVpnConnectionRoute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteVpnConnectionRoute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteVpnConnectionRouteRequest method.
- // req, resp := client.DeleteVpnConnectionRouteRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteVpnConnectionRouteRequest(input *DeleteVpnConnectionRouteInput) (req *request.Request, output *DeleteVpnConnectionRouteOutput) {
- op := &request.Operation{
- Name: opDeleteVpnConnectionRoute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteVpnConnectionRouteInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteVpnConnectionRouteOutput{}
- req.Data = output
- return
- }
- // Deletes the specified static route associated with a VPN connection between
- // an existing virtual private gateway and a VPN customer gateway. The static
- // route allows traffic to be routed from the virtual private gateway to the
- // VPN customer gateway.
- func (c *EC2) DeleteVpnConnectionRoute(input *DeleteVpnConnectionRouteInput) (*DeleteVpnConnectionRouteOutput, error) {
- req, out := c.DeleteVpnConnectionRouteRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeleteVpnGateway = "DeleteVpnGateway"
- // DeleteVpnGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteVpnGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeleteVpnGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeleteVpnGatewayRequest method.
- // req, resp := client.DeleteVpnGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeleteVpnGatewayRequest(input *DeleteVpnGatewayInput) (req *request.Request, output *DeleteVpnGatewayOutput) {
- op := &request.Operation{
- Name: opDeleteVpnGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteVpnGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeleteVpnGatewayOutput{}
- req.Data = output
- return
- }
- // Deletes the specified virtual private gateway. We recommend that before you
- // delete a virtual private gateway, you detach it from the VPC and delete the
- // VPN connection. Note that you don't need to delete the virtual private gateway
- // if you plan to delete and recreate the VPN connection between your VPC and
- // your network.
- func (c *EC2) DeleteVpnGateway(input *DeleteVpnGatewayInput) (*DeleteVpnGatewayOutput, error) {
- req, out := c.DeleteVpnGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opDeregisterImage = "DeregisterImage"
- // DeregisterImageRequest generates a "aws/request.Request" representing the
- // client's request for the DeregisterImage operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DeregisterImage method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DeregisterImageRequest method.
- // req, resp := client.DeregisterImageRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DeregisterImageRequest(input *DeregisterImageInput) (req *request.Request, output *DeregisterImageOutput) {
- op := &request.Operation{
- Name: opDeregisterImage,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeregisterImageInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DeregisterImageOutput{}
- req.Data = output
- return
- }
- // Deregisters the specified AMI. After you deregister an AMI, it can't be used
- // to launch new instances.
- //
- // This command does not delete the AMI.
- func (c *EC2) DeregisterImage(input *DeregisterImageInput) (*DeregisterImageOutput, error) {
- req, out := c.DeregisterImageRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeAccountAttributes = "DescribeAccountAttributes"
- // DescribeAccountAttributesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeAccountAttributes operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeAccountAttributes method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeAccountAttributesRequest method.
- // req, resp := client.DescribeAccountAttributesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeAccountAttributesRequest(input *DescribeAccountAttributesInput) (req *request.Request, output *DescribeAccountAttributesOutput) {
- op := &request.Operation{
- Name: opDescribeAccountAttributes,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeAccountAttributesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeAccountAttributesOutput{}
- req.Data = output
- return
- }
- // Describes attributes of your AWS account. The following are the supported
- // account attributes:
- //
- // supported-platforms: Indicates whether your account can launch instances
- // into EC2-Classic and EC2-VPC, or only into EC2-VPC.
- //
- // default-vpc: The ID of the default VPC for your account, or none.
- //
- // max-instances: The maximum number of On-Demand instances that you can
- // run.
- //
- // vpc-max-security-groups-per-interface: The maximum number of security
- // groups that you can assign to a network interface.
- //
- // max-elastic-ips: The maximum number of Elastic IP addresses that you
- // can allocate for use with EC2-Classic.
- //
- // vpc-max-elastic-ips: The maximum number of Elastic IP addresses that
- // you can allocate for use with EC2-VPC.
- func (c *EC2) DescribeAccountAttributes(input *DescribeAccountAttributesInput) (*DescribeAccountAttributesOutput, error) {
- req, out := c.DescribeAccountAttributesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeAddresses = "DescribeAddresses"
- // DescribeAddressesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeAddresses operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeAddresses method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeAddressesRequest method.
- // req, resp := client.DescribeAddressesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeAddressesRequest(input *DescribeAddressesInput) (req *request.Request, output *DescribeAddressesOutput) {
- op := &request.Operation{
- Name: opDescribeAddresses,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeAddressesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeAddressesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your Elastic IP addresses.
- //
- // An Elastic IP address is for use in either the EC2-Classic platform or in
- // a VPC. For more information, see Elastic IP Addresses (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/elastic-ip-addresses-eip.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeAddresses(input *DescribeAddressesInput) (*DescribeAddressesOutput, error) {
- req, out := c.DescribeAddressesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeAvailabilityZones = "DescribeAvailabilityZones"
- // DescribeAvailabilityZonesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeAvailabilityZones operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeAvailabilityZones method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeAvailabilityZonesRequest method.
- // req, resp := client.DescribeAvailabilityZonesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeAvailabilityZonesRequest(input *DescribeAvailabilityZonesInput) (req *request.Request, output *DescribeAvailabilityZonesOutput) {
- op := &request.Operation{
- Name: opDescribeAvailabilityZones,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeAvailabilityZonesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeAvailabilityZonesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of the Availability Zones that are available to you.
- // The results include zones only for the region you're currently using. If
- // there is an event impacting an Availability Zone, you can use this request
- // to view the state and any provided message for that Availability Zone.
- //
- // For more information, see Regions and Availability Zones (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeAvailabilityZones(input *DescribeAvailabilityZonesInput) (*DescribeAvailabilityZonesOutput, error) {
- req, out := c.DescribeAvailabilityZonesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeBundleTasks = "DescribeBundleTasks"
- // DescribeBundleTasksRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeBundleTasks operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeBundleTasks method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeBundleTasksRequest method.
- // req, resp := client.DescribeBundleTasksRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeBundleTasksRequest(input *DescribeBundleTasksInput) (req *request.Request, output *DescribeBundleTasksOutput) {
- op := &request.Operation{
- Name: opDescribeBundleTasks,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeBundleTasksInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeBundleTasksOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your bundling tasks.
- //
- // Completed bundle tasks are listed for only a limited time. If your bundle
- // task is no longer in the list, you can still register an AMI from it. Just
- // use RegisterImage with the Amazon S3 bucket name and image manifest name
- // you provided to the bundle task.
- func (c *EC2) DescribeBundleTasks(input *DescribeBundleTasksInput) (*DescribeBundleTasksOutput, error) {
- req, out := c.DescribeBundleTasksRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeClassicLinkInstances = "DescribeClassicLinkInstances"
- // DescribeClassicLinkInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeClassicLinkInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeClassicLinkInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeClassicLinkInstancesRequest method.
- // req, resp := client.DescribeClassicLinkInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeClassicLinkInstancesRequest(input *DescribeClassicLinkInstancesInput) (req *request.Request, output *DescribeClassicLinkInstancesOutput) {
- op := &request.Operation{
- Name: opDescribeClassicLinkInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeClassicLinkInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeClassicLinkInstancesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your linked EC2-Classic instances. This request
- // only returns information about EC2-Classic instances linked to a VPC through
- // ClassicLink; you cannot use this request to return information about other
- // instances.
- func (c *EC2) DescribeClassicLinkInstances(input *DescribeClassicLinkInstancesInput) (*DescribeClassicLinkInstancesOutput, error) {
- req, out := c.DescribeClassicLinkInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeConversionTasks = "DescribeConversionTasks"
- // DescribeConversionTasksRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeConversionTasks operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeConversionTasks method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeConversionTasksRequest method.
- // req, resp := client.DescribeConversionTasksRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeConversionTasksRequest(input *DescribeConversionTasksInput) (req *request.Request, output *DescribeConversionTasksOutput) {
- op := &request.Operation{
- Name: opDescribeConversionTasks,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeConversionTasksInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeConversionTasksOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your conversion tasks. For more information, see
- // Using the Command Line Tools to Import Your Virtual Machine to Amazon EC2
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UploadingYourInstancesandVolumes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // For information about the import manifest referenced by this API action,
- // see VM Import Manifest (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/manifest.html).
- func (c *EC2) DescribeConversionTasks(input *DescribeConversionTasksInput) (*DescribeConversionTasksOutput, error) {
- req, out := c.DescribeConversionTasksRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeCustomerGateways = "DescribeCustomerGateways"
- // DescribeCustomerGatewaysRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeCustomerGateways operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeCustomerGateways method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeCustomerGatewaysRequest method.
- // req, resp := client.DescribeCustomerGatewaysRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeCustomerGatewaysRequest(input *DescribeCustomerGatewaysInput) (req *request.Request, output *DescribeCustomerGatewaysOutput) {
- op := &request.Operation{
- Name: opDescribeCustomerGateways,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeCustomerGatewaysInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeCustomerGatewaysOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your VPN customer gateways.
- //
- // For more information about VPN customer gateways, see Adding a Hardware
- // Virtual Private Gateway to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeCustomerGateways(input *DescribeCustomerGatewaysInput) (*DescribeCustomerGatewaysOutput, error) {
- req, out := c.DescribeCustomerGatewaysRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeDhcpOptions = "DescribeDhcpOptions"
- // DescribeDhcpOptionsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeDhcpOptions operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeDhcpOptions method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeDhcpOptionsRequest method.
- // req, resp := client.DescribeDhcpOptionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeDhcpOptionsRequest(input *DescribeDhcpOptionsInput) (req *request.Request, output *DescribeDhcpOptionsOutput) {
- op := &request.Operation{
- Name: opDescribeDhcpOptions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeDhcpOptionsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeDhcpOptionsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your DHCP options sets.
- //
- // For more information about DHCP options sets, see DHCP Options Sets (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_DHCP_Options.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeDhcpOptions(input *DescribeDhcpOptionsInput) (*DescribeDhcpOptionsOutput, error) {
- req, out := c.DescribeDhcpOptionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeExportTasks = "DescribeExportTasks"
- // DescribeExportTasksRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeExportTasks operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeExportTasks method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeExportTasksRequest method.
- // req, resp := client.DescribeExportTasksRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeExportTasksRequest(input *DescribeExportTasksInput) (req *request.Request, output *DescribeExportTasksOutput) {
- op := &request.Operation{
- Name: opDescribeExportTasks,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeExportTasksInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeExportTasksOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your export tasks.
- func (c *EC2) DescribeExportTasks(input *DescribeExportTasksInput) (*DescribeExportTasksOutput, error) {
- req, out := c.DescribeExportTasksRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeFlowLogs = "DescribeFlowLogs"
- // DescribeFlowLogsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeFlowLogs operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeFlowLogs method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeFlowLogsRequest method.
- // req, resp := client.DescribeFlowLogsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeFlowLogsRequest(input *DescribeFlowLogsInput) (req *request.Request, output *DescribeFlowLogsOutput) {
- op := &request.Operation{
- Name: opDescribeFlowLogs,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeFlowLogsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeFlowLogsOutput{}
- req.Data = output
- return
- }
- // Describes one or more flow logs. To view the information in your flow logs
- // (the log streams for the network interfaces), you must use the CloudWatch
- // Logs console or the CloudWatch Logs API.
- func (c *EC2) DescribeFlowLogs(input *DescribeFlowLogsInput) (*DescribeFlowLogsOutput, error) {
- req, out := c.DescribeFlowLogsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeHosts = "DescribeHosts"
- // DescribeHostsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeHosts operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeHosts method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeHostsRequest method.
- // req, resp := client.DescribeHostsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeHostsRequest(input *DescribeHostsInput) (req *request.Request, output *DescribeHostsOutput) {
- op := &request.Operation{
- Name: opDescribeHosts,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeHostsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeHostsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your Dedicated hosts.
- //
- // The results describe only the Dedicated hosts in the region you're currently
- // using. All listed instances consume capacity on your Dedicated host. Dedicated
- // hosts that have recently been released will be listed with the state released.
- func (c *EC2) DescribeHosts(input *DescribeHostsInput) (*DescribeHostsOutput, error) {
- req, out := c.DescribeHostsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeIdFormat = "DescribeIdFormat"
- // DescribeIdFormatRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeIdFormat operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeIdFormat method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeIdFormatRequest method.
- // req, resp := client.DescribeIdFormatRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeIdFormatRequest(input *DescribeIdFormatInput) (req *request.Request, output *DescribeIdFormatOutput) {
- op := &request.Operation{
- Name: opDescribeIdFormat,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeIdFormatInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeIdFormatOutput{}
- req.Data = output
- return
- }
- // Describes the ID format settings for your resources on a per-region basis,
- // for example, to view which resource types are enabled for longer IDs. This
- // request only returns information about resource types whose ID formats can
- // be modified; it does not return information about other resource types.
- //
- // The following resource types support longer IDs: instance | reservation
- // | snapshot | volume.
- //
- // These settings apply to the IAM user who makes the request; they do not
- // apply to the entire AWS account. By default, an IAM user defaults to the
- // same settings as the root user, unless they explicitly override the settings
- // by running the ModifyIdFormat command. Resources created with longer IDs
- // are visible to all IAM users, regardless of these settings and provided that
- // they have permission to use the relevant Describe command for the resource
- // type.
- func (c *EC2) DescribeIdFormat(input *DescribeIdFormatInput) (*DescribeIdFormatOutput, error) {
- req, out := c.DescribeIdFormatRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeIdentityIdFormat = "DescribeIdentityIdFormat"
- // DescribeIdentityIdFormatRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeIdentityIdFormat operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeIdentityIdFormat method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeIdentityIdFormatRequest method.
- // req, resp := client.DescribeIdentityIdFormatRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeIdentityIdFormatRequest(input *DescribeIdentityIdFormatInput) (req *request.Request, output *DescribeIdentityIdFormatOutput) {
- op := &request.Operation{
- Name: opDescribeIdentityIdFormat,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeIdentityIdFormatInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeIdentityIdFormatOutput{}
- req.Data = output
- return
- }
- // Describes the ID format settings for resources for the specified IAM user,
- // IAM role, or root user. For example, you can view the resource types that
- // are enabled for longer IDs. This request only returns information about resource
- // types whose ID formats can be modified; it does not return information about
- // other resource types. For more information, see Resource IDs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/resource-ids.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // The following resource types support longer IDs: instance | reservation
- // | snapshot | volume.
- //
- // These settings apply to the principal specified in the request. They do
- // not apply to the principal that makes the request.
- func (c *EC2) DescribeIdentityIdFormat(input *DescribeIdentityIdFormatInput) (*DescribeIdentityIdFormatOutput, error) {
- req, out := c.DescribeIdentityIdFormatRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeImageAttribute = "DescribeImageAttribute"
- // DescribeImageAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeImageAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeImageAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeImageAttributeRequest method.
- // req, resp := client.DescribeImageAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeImageAttributeRequest(input *DescribeImageAttributeInput) (req *request.Request, output *DescribeImageAttributeOutput) {
- op := &request.Operation{
- Name: opDescribeImageAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeImageAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeImageAttributeOutput{}
- req.Data = output
- return
- }
- // Describes the specified attribute of the specified AMI. You can specify only
- // one attribute at a time.
- func (c *EC2) DescribeImageAttribute(input *DescribeImageAttributeInput) (*DescribeImageAttributeOutput, error) {
- req, out := c.DescribeImageAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeImages = "DescribeImages"
- // DescribeImagesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeImages operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeImages method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeImagesRequest method.
- // req, resp := client.DescribeImagesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeImagesRequest(input *DescribeImagesInput) (req *request.Request, output *DescribeImagesOutput) {
- op := &request.Operation{
- Name: opDescribeImages,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeImagesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeImagesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of the images (AMIs, AKIs, and ARIs) available to you.
- // Images available to you include public images, private images that you own,
- // and private images owned by other AWS accounts but for which you have explicit
- // launch permissions.
- //
- // Deregistered images are included in the returned results for an unspecified
- // interval after deregistration.
- func (c *EC2) DescribeImages(input *DescribeImagesInput) (*DescribeImagesOutput, error) {
- req, out := c.DescribeImagesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeImportImageTasks = "DescribeImportImageTasks"
- // DescribeImportImageTasksRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeImportImageTasks operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeImportImageTasks method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeImportImageTasksRequest method.
- // req, resp := client.DescribeImportImageTasksRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeImportImageTasksRequest(input *DescribeImportImageTasksInput) (req *request.Request, output *DescribeImportImageTasksOutput) {
- op := &request.Operation{
- Name: opDescribeImportImageTasks,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeImportImageTasksInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeImportImageTasksOutput{}
- req.Data = output
- return
- }
- // Displays details about an import virtual machine or import snapshot tasks
- // that are already created.
- func (c *EC2) DescribeImportImageTasks(input *DescribeImportImageTasksInput) (*DescribeImportImageTasksOutput, error) {
- req, out := c.DescribeImportImageTasksRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeImportSnapshotTasks = "DescribeImportSnapshotTasks"
- // DescribeImportSnapshotTasksRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeImportSnapshotTasks operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeImportSnapshotTasks method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeImportSnapshotTasksRequest method.
- // req, resp := client.DescribeImportSnapshotTasksRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeImportSnapshotTasksRequest(input *DescribeImportSnapshotTasksInput) (req *request.Request, output *DescribeImportSnapshotTasksOutput) {
- op := &request.Operation{
- Name: opDescribeImportSnapshotTasks,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeImportSnapshotTasksInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeImportSnapshotTasksOutput{}
- req.Data = output
- return
- }
- // Describes your import snapshot tasks.
- func (c *EC2) DescribeImportSnapshotTasks(input *DescribeImportSnapshotTasksInput) (*DescribeImportSnapshotTasksOutput, error) {
- req, out := c.DescribeImportSnapshotTasksRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeInstanceAttribute = "DescribeInstanceAttribute"
- // DescribeInstanceAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeInstanceAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeInstanceAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeInstanceAttributeRequest method.
- // req, resp := client.DescribeInstanceAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeInstanceAttributeRequest(input *DescribeInstanceAttributeInput) (req *request.Request, output *DescribeInstanceAttributeOutput) {
- op := &request.Operation{
- Name: opDescribeInstanceAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeInstanceAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeInstanceAttributeOutput{}
- req.Data = output
- return
- }
- // Describes the specified attribute of the specified instance. You can specify
- // only one attribute at a time. Valid attribute values are: instanceType |
- // kernel | ramdisk | userData | disableApiTermination | instanceInitiatedShutdownBehavior
- // | rootDeviceName | blockDeviceMapping | productCodes | sourceDestCheck |
- // groupSet | ebsOptimized | sriovNetSupport
- func (c *EC2) DescribeInstanceAttribute(input *DescribeInstanceAttributeInput) (*DescribeInstanceAttributeOutput, error) {
- req, out := c.DescribeInstanceAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeInstanceStatus = "DescribeInstanceStatus"
- // DescribeInstanceStatusRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeInstanceStatus operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeInstanceStatus method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeInstanceStatusRequest method.
- // req, resp := client.DescribeInstanceStatusRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeInstanceStatusRequest(input *DescribeInstanceStatusInput) (req *request.Request, output *DescribeInstanceStatusOutput) {
- op := &request.Operation{
- Name: opDescribeInstanceStatus,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeInstanceStatusInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeInstanceStatusOutput{}
- req.Data = output
- return
- }
- // Describes the status of one or more instances. By default, only running instances
- // are described, unless specified otherwise.
- //
- // Instance status includes the following components:
- //
- // Status checks - Amazon EC2 performs status checks on running EC2 instances
- // to identify hardware and software issues. For more information, see Status
- // Checks for Your Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/monitoring-system-instance-status-check.html)
- // and Troubleshooting Instances with Failed Status Checks (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/TroubleshootingInstances.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Scheduled events - Amazon EC2 can schedule events (such as reboot, stop,
- // or terminate) for your instances related to hardware issues, software updates,
- // or system maintenance. For more information, see Scheduled Events for Your
- // Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/monitoring-instances-status-check_sched.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Instance state - You can manage your instances from the moment you launch
- // them through their termination. For more information, see Instance Lifecycle
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-instance-lifecycle.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeInstanceStatus(input *DescribeInstanceStatusInput) (*DescribeInstanceStatusOutput, error) {
- req, out := c.DescribeInstanceStatusRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeInstanceStatusPages iterates over the pages of a DescribeInstanceStatus operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeInstanceStatus method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeInstanceStatus operation.
- // pageNum := 0
- // err := client.DescribeInstanceStatusPages(params,
- // func(page *DescribeInstanceStatusOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeInstanceStatusPages(input *DescribeInstanceStatusInput, fn func(p *DescribeInstanceStatusOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeInstanceStatusRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeInstanceStatusOutput), lastPage)
- })
- }
- const opDescribeInstances = "DescribeInstances"
- // DescribeInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeInstancesRequest method.
- // req, resp := client.DescribeInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeInstancesRequest(input *DescribeInstancesInput) (req *request.Request, output *DescribeInstancesOutput) {
- op := &request.Operation{
- Name: opDescribeInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeInstancesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your instances.
- //
- // If you specify one or more instance IDs, Amazon EC2 returns information
- // for those instances. If you do not specify instance IDs, Amazon EC2 returns
- // information for all relevant instances. If you specify an instance ID that
- // is not valid, an error is returned. If you specify an instance that you do
- // not own, it is not included in the returned results.
- //
- // Recently terminated instances might appear in the returned results. This
- // interval is usually less than one hour.
- //
- // If you describe instances in the rare case where an Availability Zone is
- // experiencing a service disruption and you specify instance IDs that are in
- // the affected zone, or do not specify any instance IDs at all, the call fails.
- // If you describe instances and specify only instance IDs that are in an unaffected
- // zone, the call works normally.
- func (c *EC2) DescribeInstances(input *DescribeInstancesInput) (*DescribeInstancesOutput, error) {
- req, out := c.DescribeInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeInstancesPages iterates over the pages of a DescribeInstances operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeInstances method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeInstances operation.
- // pageNum := 0
- // err := client.DescribeInstancesPages(params,
- // func(page *DescribeInstancesOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeInstancesPages(input *DescribeInstancesInput, fn func(p *DescribeInstancesOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeInstancesRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeInstancesOutput), lastPage)
- })
- }
- const opDescribeInternetGateways = "DescribeInternetGateways"
- // DescribeInternetGatewaysRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeInternetGateways operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeInternetGateways method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeInternetGatewaysRequest method.
- // req, resp := client.DescribeInternetGatewaysRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeInternetGatewaysRequest(input *DescribeInternetGatewaysInput) (req *request.Request, output *DescribeInternetGatewaysOutput) {
- op := &request.Operation{
- Name: opDescribeInternetGateways,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeInternetGatewaysInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeInternetGatewaysOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your Internet gateways.
- func (c *EC2) DescribeInternetGateways(input *DescribeInternetGatewaysInput) (*DescribeInternetGatewaysOutput, error) {
- req, out := c.DescribeInternetGatewaysRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeKeyPairs = "DescribeKeyPairs"
- // DescribeKeyPairsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeKeyPairs operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeKeyPairs method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeKeyPairsRequest method.
- // req, resp := client.DescribeKeyPairsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeKeyPairsRequest(input *DescribeKeyPairsInput) (req *request.Request, output *DescribeKeyPairsOutput) {
- op := &request.Operation{
- Name: opDescribeKeyPairs,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeKeyPairsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeKeyPairsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your key pairs.
- //
- // For more information about key pairs, see Key Pairs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-key-pairs.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeKeyPairs(input *DescribeKeyPairsInput) (*DescribeKeyPairsOutput, error) {
- req, out := c.DescribeKeyPairsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeMovingAddresses = "DescribeMovingAddresses"
- // DescribeMovingAddressesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeMovingAddresses operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeMovingAddresses method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeMovingAddressesRequest method.
- // req, resp := client.DescribeMovingAddressesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeMovingAddressesRequest(input *DescribeMovingAddressesInput) (req *request.Request, output *DescribeMovingAddressesOutput) {
- op := &request.Operation{
- Name: opDescribeMovingAddresses,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeMovingAddressesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeMovingAddressesOutput{}
- req.Data = output
- return
- }
- // Describes your Elastic IP addresses that are being moved to the EC2-VPC platform,
- // or that are being restored to the EC2-Classic platform. This request does
- // not return information about any other Elastic IP addresses in your account.
- func (c *EC2) DescribeMovingAddresses(input *DescribeMovingAddressesInput) (*DescribeMovingAddressesOutput, error) {
- req, out := c.DescribeMovingAddressesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeNatGateways = "DescribeNatGateways"
- // DescribeNatGatewaysRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeNatGateways operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeNatGateways method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeNatGatewaysRequest method.
- // req, resp := client.DescribeNatGatewaysRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeNatGatewaysRequest(input *DescribeNatGatewaysInput) (req *request.Request, output *DescribeNatGatewaysOutput) {
- op := &request.Operation{
- Name: opDescribeNatGateways,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeNatGatewaysInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeNatGatewaysOutput{}
- req.Data = output
- return
- }
- // Describes one or more of the your NAT gateways.
- func (c *EC2) DescribeNatGateways(input *DescribeNatGatewaysInput) (*DescribeNatGatewaysOutput, error) {
- req, out := c.DescribeNatGatewaysRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeNetworkAcls = "DescribeNetworkAcls"
- // DescribeNetworkAclsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeNetworkAcls operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeNetworkAcls method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeNetworkAclsRequest method.
- // req, resp := client.DescribeNetworkAclsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeNetworkAclsRequest(input *DescribeNetworkAclsInput) (req *request.Request, output *DescribeNetworkAclsOutput) {
- op := &request.Operation{
- Name: opDescribeNetworkAcls,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeNetworkAclsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeNetworkAclsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your network ACLs.
- //
- // For more information about network ACLs, see Network ACLs (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_ACLs.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeNetworkAcls(input *DescribeNetworkAclsInput) (*DescribeNetworkAclsOutput, error) {
- req, out := c.DescribeNetworkAclsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeNetworkInterfaceAttribute = "DescribeNetworkInterfaceAttribute"
- // DescribeNetworkInterfaceAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeNetworkInterfaceAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeNetworkInterfaceAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeNetworkInterfaceAttributeRequest method.
- // req, resp := client.DescribeNetworkInterfaceAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeNetworkInterfaceAttributeRequest(input *DescribeNetworkInterfaceAttributeInput) (req *request.Request, output *DescribeNetworkInterfaceAttributeOutput) {
- op := &request.Operation{
- Name: opDescribeNetworkInterfaceAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeNetworkInterfaceAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeNetworkInterfaceAttributeOutput{}
- req.Data = output
- return
- }
- // Describes a network interface attribute. You can specify only one attribute
- // at a time.
- func (c *EC2) DescribeNetworkInterfaceAttribute(input *DescribeNetworkInterfaceAttributeInput) (*DescribeNetworkInterfaceAttributeOutput, error) {
- req, out := c.DescribeNetworkInterfaceAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeNetworkInterfaces = "DescribeNetworkInterfaces"
- // DescribeNetworkInterfacesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeNetworkInterfaces operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeNetworkInterfaces method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeNetworkInterfacesRequest method.
- // req, resp := client.DescribeNetworkInterfacesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeNetworkInterfacesRequest(input *DescribeNetworkInterfacesInput) (req *request.Request, output *DescribeNetworkInterfacesOutput) {
- op := &request.Operation{
- Name: opDescribeNetworkInterfaces,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeNetworkInterfacesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeNetworkInterfacesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your network interfaces.
- func (c *EC2) DescribeNetworkInterfaces(input *DescribeNetworkInterfacesInput) (*DescribeNetworkInterfacesOutput, error) {
- req, out := c.DescribeNetworkInterfacesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribePlacementGroups = "DescribePlacementGroups"
- // DescribePlacementGroupsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribePlacementGroups operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribePlacementGroups method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribePlacementGroupsRequest method.
- // req, resp := client.DescribePlacementGroupsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribePlacementGroupsRequest(input *DescribePlacementGroupsInput) (req *request.Request, output *DescribePlacementGroupsOutput) {
- op := &request.Operation{
- Name: opDescribePlacementGroups,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribePlacementGroupsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribePlacementGroupsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your placement groups. For more information about
- // placement groups and cluster instances, see Cluster Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using_cluster_computing.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribePlacementGroups(input *DescribePlacementGroupsInput) (*DescribePlacementGroupsOutput, error) {
- req, out := c.DescribePlacementGroupsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribePrefixLists = "DescribePrefixLists"
- // DescribePrefixListsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribePrefixLists operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribePrefixLists method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribePrefixListsRequest method.
- // req, resp := client.DescribePrefixListsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribePrefixListsRequest(input *DescribePrefixListsInput) (req *request.Request, output *DescribePrefixListsOutput) {
- op := &request.Operation{
- Name: opDescribePrefixLists,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribePrefixListsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribePrefixListsOutput{}
- req.Data = output
- return
- }
- // Describes available AWS services in a prefix list format, which includes
- // the prefix list name and prefix list ID of the service and the IP address
- // range for the service. A prefix list ID is required for creating an outbound
- // security group rule that allows traffic from a VPC to access an AWS service
- // through a VPC endpoint.
- func (c *EC2) DescribePrefixLists(input *DescribePrefixListsInput) (*DescribePrefixListsOutput, error) {
- req, out := c.DescribePrefixListsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeRegions = "DescribeRegions"
- // DescribeRegionsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeRegions operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeRegions method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeRegionsRequest method.
- // req, resp := client.DescribeRegionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeRegionsRequest(input *DescribeRegionsInput) (req *request.Request, output *DescribeRegionsOutput) {
- op := &request.Operation{
- Name: opDescribeRegions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeRegionsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeRegionsOutput{}
- req.Data = output
- return
- }
- // Describes one or more regions that are currently available to you.
- //
- // For a list of the regions supported by Amazon EC2, see Regions and Endpoints
- // (http://docs.aws.amazon.com/general/latest/gr/rande.html#ec2_region).
- func (c *EC2) DescribeRegions(input *DescribeRegionsInput) (*DescribeRegionsOutput, error) {
- req, out := c.DescribeRegionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeReservedInstances = "DescribeReservedInstances"
- // DescribeReservedInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeReservedInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeReservedInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeReservedInstancesRequest method.
- // req, resp := client.DescribeReservedInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeReservedInstancesRequest(input *DescribeReservedInstancesInput) (req *request.Request, output *DescribeReservedInstancesOutput) {
- op := &request.Operation{
- Name: opDescribeReservedInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeReservedInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeReservedInstancesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of the Reserved Instances that you purchased.
- //
- // For more information about Reserved Instances, see Reserved Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/concepts-on-demand-reserved-instances.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeReservedInstances(input *DescribeReservedInstancesInput) (*DescribeReservedInstancesOutput, error) {
- req, out := c.DescribeReservedInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeReservedInstancesListings = "DescribeReservedInstancesListings"
- // DescribeReservedInstancesListingsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeReservedInstancesListings operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeReservedInstancesListings method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeReservedInstancesListingsRequest method.
- // req, resp := client.DescribeReservedInstancesListingsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeReservedInstancesListingsRequest(input *DescribeReservedInstancesListingsInput) (req *request.Request, output *DescribeReservedInstancesListingsOutput) {
- op := &request.Operation{
- Name: opDescribeReservedInstancesListings,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeReservedInstancesListingsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeReservedInstancesListingsOutput{}
- req.Data = output
- return
- }
- // Describes your account's Reserved Instance listings in the Reserved Instance
- // Marketplace.
- //
- // The Reserved Instance Marketplace matches sellers who want to resell Reserved
- // Instance capacity that they no longer need with buyers who want to purchase
- // additional capacity. Reserved Instances bought and sold through the Reserved
- // Instance Marketplace work like any other Reserved Instances.
- //
- // As a seller, you choose to list some or all of your Reserved Instances,
- // and you specify the upfront price to receive for them. Your Reserved Instances
- // are then listed in the Reserved Instance Marketplace and are available for
- // purchase.
- //
- // As a buyer, you specify the configuration of the Reserved Instance to purchase,
- // and the Marketplace matches what you're searching for with what's available.
- // The Marketplace first sells the lowest priced Reserved Instances to you,
- // and continues to sell available Reserved Instance listings to you until your
- // demand is met. You are charged based on the total price of all of the listings
- // that you purchase.
- //
- // For more information, see Reserved Instance Marketplace (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ri-market-general.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeReservedInstancesListings(input *DescribeReservedInstancesListingsInput) (*DescribeReservedInstancesListingsOutput, error) {
- req, out := c.DescribeReservedInstancesListingsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeReservedInstancesModifications = "DescribeReservedInstancesModifications"
- // DescribeReservedInstancesModificationsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeReservedInstancesModifications operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeReservedInstancesModifications method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeReservedInstancesModificationsRequest method.
- // req, resp := client.DescribeReservedInstancesModificationsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeReservedInstancesModificationsRequest(input *DescribeReservedInstancesModificationsInput) (req *request.Request, output *DescribeReservedInstancesModificationsOutput) {
- op := &request.Operation{
- Name: opDescribeReservedInstancesModifications,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeReservedInstancesModificationsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeReservedInstancesModificationsOutput{}
- req.Data = output
- return
- }
- // Describes the modifications made to your Reserved Instances. If no parameter
- // is specified, information about all your Reserved Instances modification
- // requests is returned. If a modification ID is specified, only information
- // about the specific modification is returned.
- //
- // For more information, see Modifying Reserved Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ri-modifying.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeReservedInstancesModifications(input *DescribeReservedInstancesModificationsInput) (*DescribeReservedInstancesModificationsOutput, error) {
- req, out := c.DescribeReservedInstancesModificationsRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeReservedInstancesModificationsPages iterates over the pages of a DescribeReservedInstancesModifications operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeReservedInstancesModifications method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeReservedInstancesModifications operation.
- // pageNum := 0
- // err := client.DescribeReservedInstancesModificationsPages(params,
- // func(page *DescribeReservedInstancesModificationsOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeReservedInstancesModificationsPages(input *DescribeReservedInstancesModificationsInput, fn func(p *DescribeReservedInstancesModificationsOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeReservedInstancesModificationsRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeReservedInstancesModificationsOutput), lastPage)
- })
- }
- const opDescribeReservedInstancesOfferings = "DescribeReservedInstancesOfferings"
- // DescribeReservedInstancesOfferingsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeReservedInstancesOfferings operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeReservedInstancesOfferings method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeReservedInstancesOfferingsRequest method.
- // req, resp := client.DescribeReservedInstancesOfferingsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeReservedInstancesOfferingsRequest(input *DescribeReservedInstancesOfferingsInput) (req *request.Request, output *DescribeReservedInstancesOfferingsOutput) {
- op := &request.Operation{
- Name: opDescribeReservedInstancesOfferings,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeReservedInstancesOfferingsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeReservedInstancesOfferingsOutput{}
- req.Data = output
- return
- }
- // Describes Reserved Instance offerings that are available for purchase. With
- // Reserved Instances, you purchase the right to launch instances for a period
- // of time. During that time period, you do not receive insufficient capacity
- // errors, and you pay a lower usage rate than the rate charged for On-Demand
- // instances for the actual time used.
- //
- // If you have listed your own Reserved Instances for sale in the Reserved
- // Instance Marketplace, they will be excluded from these results. This is to
- // ensure that you do not purchase your own Reserved Instances.
- //
- // For more information, see Reserved Instance Marketplace (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ri-market-general.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeReservedInstancesOfferings(input *DescribeReservedInstancesOfferingsInput) (*DescribeReservedInstancesOfferingsOutput, error) {
- req, out := c.DescribeReservedInstancesOfferingsRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeReservedInstancesOfferingsPages iterates over the pages of a DescribeReservedInstancesOfferings operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeReservedInstancesOfferings method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeReservedInstancesOfferings operation.
- // pageNum := 0
- // err := client.DescribeReservedInstancesOfferingsPages(params,
- // func(page *DescribeReservedInstancesOfferingsOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeReservedInstancesOfferingsPages(input *DescribeReservedInstancesOfferingsInput, fn func(p *DescribeReservedInstancesOfferingsOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeReservedInstancesOfferingsRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeReservedInstancesOfferingsOutput), lastPage)
- })
- }
- const opDescribeRouteTables = "DescribeRouteTables"
- // DescribeRouteTablesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeRouteTables operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeRouteTables method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeRouteTablesRequest method.
- // req, resp := client.DescribeRouteTablesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeRouteTablesRequest(input *DescribeRouteTablesInput) (req *request.Request, output *DescribeRouteTablesOutput) {
- op := &request.Operation{
- Name: opDescribeRouteTables,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeRouteTablesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeRouteTablesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your route tables.
- //
- // Each subnet in your VPC must be associated with a route table. If a subnet
- // is not explicitly associated with any route table, it is implicitly associated
- // with the main route table. This command does not return the subnet ID for
- // implicit associations.
- //
- // For more information about route tables, see Route Tables (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Route_Tables.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeRouteTables(input *DescribeRouteTablesInput) (*DescribeRouteTablesOutput, error) {
- req, out := c.DescribeRouteTablesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeScheduledInstanceAvailability = "DescribeScheduledInstanceAvailability"
- // DescribeScheduledInstanceAvailabilityRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeScheduledInstanceAvailability operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeScheduledInstanceAvailability method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeScheduledInstanceAvailabilityRequest method.
- // req, resp := client.DescribeScheduledInstanceAvailabilityRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeScheduledInstanceAvailabilityRequest(input *DescribeScheduledInstanceAvailabilityInput) (req *request.Request, output *DescribeScheduledInstanceAvailabilityOutput) {
- op := &request.Operation{
- Name: opDescribeScheduledInstanceAvailability,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeScheduledInstanceAvailabilityInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeScheduledInstanceAvailabilityOutput{}
- req.Data = output
- return
- }
- // Finds available schedules that meet the specified criteria.
- //
- // You can search for an available schedule no more than 3 months in advance.
- // You must meet the minimum required duration of 1,200 hours per year. For
- // example, the minimum daily schedule is 4 hours, the minimum weekly schedule
- // is 24 hours, and the minimum monthly schedule is 100 hours.
- //
- // After you find a schedule that meets your needs, call PurchaseScheduledInstances
- // to purchase Scheduled Instances with that schedule.
- func (c *EC2) DescribeScheduledInstanceAvailability(input *DescribeScheduledInstanceAvailabilityInput) (*DescribeScheduledInstanceAvailabilityOutput, error) {
- req, out := c.DescribeScheduledInstanceAvailabilityRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeScheduledInstances = "DescribeScheduledInstances"
- // DescribeScheduledInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeScheduledInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeScheduledInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeScheduledInstancesRequest method.
- // req, resp := client.DescribeScheduledInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeScheduledInstancesRequest(input *DescribeScheduledInstancesInput) (req *request.Request, output *DescribeScheduledInstancesOutput) {
- op := &request.Operation{
- Name: opDescribeScheduledInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeScheduledInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeScheduledInstancesOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your Scheduled Instances.
- func (c *EC2) DescribeScheduledInstances(input *DescribeScheduledInstancesInput) (*DescribeScheduledInstancesOutput, error) {
- req, out := c.DescribeScheduledInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSecurityGroupReferences = "DescribeSecurityGroupReferences"
- // DescribeSecurityGroupReferencesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSecurityGroupReferences operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSecurityGroupReferences method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSecurityGroupReferencesRequest method.
- // req, resp := client.DescribeSecurityGroupReferencesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSecurityGroupReferencesRequest(input *DescribeSecurityGroupReferencesInput) (req *request.Request, output *DescribeSecurityGroupReferencesOutput) {
- op := &request.Operation{
- Name: opDescribeSecurityGroupReferences,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSecurityGroupReferencesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSecurityGroupReferencesOutput{}
- req.Data = output
- return
- }
- // [EC2-VPC only] Describes the VPCs on the other side of a VPC peering connection
- // that are referencing the security groups you've specified in this request.
- func (c *EC2) DescribeSecurityGroupReferences(input *DescribeSecurityGroupReferencesInput) (*DescribeSecurityGroupReferencesOutput, error) {
- req, out := c.DescribeSecurityGroupReferencesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSecurityGroups = "DescribeSecurityGroups"
- // DescribeSecurityGroupsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSecurityGroups operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSecurityGroups method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSecurityGroupsRequest method.
- // req, resp := client.DescribeSecurityGroupsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSecurityGroupsRequest(input *DescribeSecurityGroupsInput) (req *request.Request, output *DescribeSecurityGroupsOutput) {
- op := &request.Operation{
- Name: opDescribeSecurityGroups,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSecurityGroupsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSecurityGroupsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your security groups.
- //
- // A security group is for use with instances either in the EC2-Classic platform
- // or in a specific VPC. For more information, see Amazon EC2 Security Groups
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-network-security.html)
- // in the Amazon Elastic Compute Cloud User Guide and Security Groups for Your
- // VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_SecurityGroups.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeSecurityGroups(input *DescribeSecurityGroupsInput) (*DescribeSecurityGroupsOutput, error) {
- req, out := c.DescribeSecurityGroupsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSnapshotAttribute = "DescribeSnapshotAttribute"
- // DescribeSnapshotAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSnapshotAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSnapshotAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSnapshotAttributeRequest method.
- // req, resp := client.DescribeSnapshotAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSnapshotAttributeRequest(input *DescribeSnapshotAttributeInput) (req *request.Request, output *DescribeSnapshotAttributeOutput) {
- op := &request.Operation{
- Name: opDescribeSnapshotAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSnapshotAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSnapshotAttributeOutput{}
- req.Data = output
- return
- }
- // Describes the specified attribute of the specified snapshot. You can specify
- // only one attribute at a time.
- //
- // For more information about EBS snapshots, see Amazon EBS Snapshots (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSSnapshots.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeSnapshotAttribute(input *DescribeSnapshotAttributeInput) (*DescribeSnapshotAttributeOutput, error) {
- req, out := c.DescribeSnapshotAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSnapshots = "DescribeSnapshots"
- // DescribeSnapshotsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSnapshots operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSnapshots method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSnapshotsRequest method.
- // req, resp := client.DescribeSnapshotsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSnapshotsRequest(input *DescribeSnapshotsInput) (req *request.Request, output *DescribeSnapshotsOutput) {
- op := &request.Operation{
- Name: opDescribeSnapshots,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeSnapshotsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSnapshotsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of the EBS snapshots available to you. Available snapshots
- // include public snapshots available for any AWS account to launch, private
- // snapshots that you own, and private snapshots owned by another AWS account
- // but for which you've been given explicit create volume permissions.
- //
- // The create volume permissions fall into the following categories:
- //
- // public: The owner of the snapshot granted create volume permissions for
- // the snapshot to the all group. All AWS accounts have create volume permissions
- // for these snapshots.
- //
- // explicit: The owner of the snapshot granted create volume permissions
- // to a specific AWS account.
- //
- // implicit: An AWS account has implicit create volume permissions for all
- // snapshots it owns.
- //
- // The list of snapshots returned can be modified by specifying snapshot
- // IDs, snapshot owners, or AWS accounts with create volume permissions. If
- // no options are specified, Amazon EC2 returns all snapshots for which you
- // have create volume permissions.
- //
- // If you specify one or more snapshot IDs, only snapshots that have the specified
- // IDs are returned. If you specify an invalid snapshot ID, an error is returned.
- // If you specify a snapshot ID for which you do not have access, it is not
- // included in the returned results.
- //
- // If you specify one or more snapshot owners using the OwnerIds option, only
- // snapshots from the specified owners and for which you have access are returned.
- // The results can include the AWS account IDs of the specified owners, amazon
- // for snapshots owned by Amazon, or self for snapshots that you own.
- //
- // If you specify a list of restorable users, only snapshots with create snapshot
- // permissions for those users are returned. You can specify AWS account IDs
- // (if you own the snapshots), self for snapshots for which you own or have
- // explicit permissions, or all for public snapshots.
- //
- // If you are describing a long list of snapshots, you can paginate the output
- // to make the list more manageable. The MaxResults parameter sets the maximum
- // number of results returned in a single page. If the list of results exceeds
- // your MaxResults value, then that number of results is returned along with
- // a NextToken value that can be passed to a subsequent DescribeSnapshots request
- // to retrieve the remaining results.
- //
- // For more information about EBS snapshots, see Amazon EBS Snapshots (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSSnapshots.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeSnapshots(input *DescribeSnapshotsInput) (*DescribeSnapshotsOutput, error) {
- req, out := c.DescribeSnapshotsRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeSnapshotsPages iterates over the pages of a DescribeSnapshots operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeSnapshots method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeSnapshots operation.
- // pageNum := 0
- // err := client.DescribeSnapshotsPages(params,
- // func(page *DescribeSnapshotsOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeSnapshotsPages(input *DescribeSnapshotsInput, fn func(p *DescribeSnapshotsOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeSnapshotsRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeSnapshotsOutput), lastPage)
- })
- }
- const opDescribeSpotDatafeedSubscription = "DescribeSpotDatafeedSubscription"
- // DescribeSpotDatafeedSubscriptionRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSpotDatafeedSubscription operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSpotDatafeedSubscription method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSpotDatafeedSubscriptionRequest method.
- // req, resp := client.DescribeSpotDatafeedSubscriptionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSpotDatafeedSubscriptionRequest(input *DescribeSpotDatafeedSubscriptionInput) (req *request.Request, output *DescribeSpotDatafeedSubscriptionOutput) {
- op := &request.Operation{
- Name: opDescribeSpotDatafeedSubscription,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSpotDatafeedSubscriptionInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSpotDatafeedSubscriptionOutput{}
- req.Data = output
- return
- }
- // Describes the data feed for Spot instances. For more information, see Spot
- // Instance Data Feed (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-data-feeds.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeSpotDatafeedSubscription(input *DescribeSpotDatafeedSubscriptionInput) (*DescribeSpotDatafeedSubscriptionOutput, error) {
- req, out := c.DescribeSpotDatafeedSubscriptionRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSpotFleetInstances = "DescribeSpotFleetInstances"
- // DescribeSpotFleetInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSpotFleetInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSpotFleetInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSpotFleetInstancesRequest method.
- // req, resp := client.DescribeSpotFleetInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSpotFleetInstancesRequest(input *DescribeSpotFleetInstancesInput) (req *request.Request, output *DescribeSpotFleetInstancesOutput) {
- op := &request.Operation{
- Name: opDescribeSpotFleetInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSpotFleetInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSpotFleetInstancesOutput{}
- req.Data = output
- return
- }
- // Describes the running instances for the specified Spot fleet.
- func (c *EC2) DescribeSpotFleetInstances(input *DescribeSpotFleetInstancesInput) (*DescribeSpotFleetInstancesOutput, error) {
- req, out := c.DescribeSpotFleetInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSpotFleetRequestHistory = "DescribeSpotFleetRequestHistory"
- // DescribeSpotFleetRequestHistoryRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSpotFleetRequestHistory operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSpotFleetRequestHistory method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSpotFleetRequestHistoryRequest method.
- // req, resp := client.DescribeSpotFleetRequestHistoryRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSpotFleetRequestHistoryRequest(input *DescribeSpotFleetRequestHistoryInput) (req *request.Request, output *DescribeSpotFleetRequestHistoryOutput) {
- op := &request.Operation{
- Name: opDescribeSpotFleetRequestHistory,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSpotFleetRequestHistoryInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSpotFleetRequestHistoryOutput{}
- req.Data = output
- return
- }
- // Describes the events for the specified Spot fleet request during the specified
- // time.
- //
- // Spot fleet events are delayed by up to 30 seconds before they can be described.
- // This ensures that you can query by the last evaluated time and not miss a
- // recorded event.
- func (c *EC2) DescribeSpotFleetRequestHistory(input *DescribeSpotFleetRequestHistoryInput) (*DescribeSpotFleetRequestHistoryOutput, error) {
- req, out := c.DescribeSpotFleetRequestHistoryRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSpotFleetRequests = "DescribeSpotFleetRequests"
- // DescribeSpotFleetRequestsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSpotFleetRequests operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSpotFleetRequests method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSpotFleetRequestsRequest method.
- // req, resp := client.DescribeSpotFleetRequestsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSpotFleetRequestsRequest(input *DescribeSpotFleetRequestsInput) (req *request.Request, output *DescribeSpotFleetRequestsOutput) {
- op := &request.Operation{
- Name: opDescribeSpotFleetRequests,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeSpotFleetRequestsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSpotFleetRequestsOutput{}
- req.Data = output
- return
- }
- // Describes your Spot fleet requests.
- func (c *EC2) DescribeSpotFleetRequests(input *DescribeSpotFleetRequestsInput) (*DescribeSpotFleetRequestsOutput, error) {
- req, out := c.DescribeSpotFleetRequestsRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeSpotFleetRequestsPages iterates over the pages of a DescribeSpotFleetRequests operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeSpotFleetRequests method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeSpotFleetRequests operation.
- // pageNum := 0
- // err := client.DescribeSpotFleetRequestsPages(params,
- // func(page *DescribeSpotFleetRequestsOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeSpotFleetRequestsPages(input *DescribeSpotFleetRequestsInput, fn func(p *DescribeSpotFleetRequestsOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeSpotFleetRequestsRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeSpotFleetRequestsOutput), lastPage)
- })
- }
- const opDescribeSpotInstanceRequests = "DescribeSpotInstanceRequests"
- // DescribeSpotInstanceRequestsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSpotInstanceRequests operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSpotInstanceRequests method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSpotInstanceRequestsRequest method.
- // req, resp := client.DescribeSpotInstanceRequestsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSpotInstanceRequestsRequest(input *DescribeSpotInstanceRequestsInput) (req *request.Request, output *DescribeSpotInstanceRequestsOutput) {
- op := &request.Operation{
- Name: opDescribeSpotInstanceRequests,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSpotInstanceRequestsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSpotInstanceRequestsOutput{}
- req.Data = output
- return
- }
- // Describes the Spot instance requests that belong to your account. Spot instances
- // are instances that Amazon EC2 launches when the bid price that you specify
- // exceeds the current Spot price. Amazon EC2 periodically sets the Spot price
- // based on available Spot instance capacity and current Spot instance requests.
- // For more information, see Spot Instance Requests (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-requests.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // You can use DescribeSpotInstanceRequests to find a running Spot instance
- // by examining the response. If the status of the Spot instance is fulfilled,
- // the instance ID appears in the response and contains the identifier of the
- // instance. Alternatively, you can use DescribeInstances with a filter to look
- // for instances where the instance lifecycle is spot.
- func (c *EC2) DescribeSpotInstanceRequests(input *DescribeSpotInstanceRequestsInput) (*DescribeSpotInstanceRequestsOutput, error) {
- req, out := c.DescribeSpotInstanceRequestsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSpotPriceHistory = "DescribeSpotPriceHistory"
- // DescribeSpotPriceHistoryRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSpotPriceHistory operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSpotPriceHistory method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSpotPriceHistoryRequest method.
- // req, resp := client.DescribeSpotPriceHistoryRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSpotPriceHistoryRequest(input *DescribeSpotPriceHistoryInput) (req *request.Request, output *DescribeSpotPriceHistoryOutput) {
- op := &request.Operation{
- Name: opDescribeSpotPriceHistory,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeSpotPriceHistoryInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSpotPriceHistoryOutput{}
- req.Data = output
- return
- }
- // Describes the Spot price history. The prices returned are listed in chronological
- // order, from the oldest to the most recent, for up to the past 90 days. For
- // more information, see Spot Instance Pricing History (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-spot-instances-history.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // When you specify a start and end time, this operation returns the prices
- // of the instance types within the time range that you specified and the time
- // when the price changed. The price is valid within the time period that you
- // specified; the response merely indicates the last time that the price changed.
- func (c *EC2) DescribeSpotPriceHistory(input *DescribeSpotPriceHistoryInput) (*DescribeSpotPriceHistoryOutput, error) {
- req, out := c.DescribeSpotPriceHistoryRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeSpotPriceHistoryPages iterates over the pages of a DescribeSpotPriceHistory operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeSpotPriceHistory method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeSpotPriceHistory operation.
- // pageNum := 0
- // err := client.DescribeSpotPriceHistoryPages(params,
- // func(page *DescribeSpotPriceHistoryOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeSpotPriceHistoryPages(input *DescribeSpotPriceHistoryInput, fn func(p *DescribeSpotPriceHistoryOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeSpotPriceHistoryRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeSpotPriceHistoryOutput), lastPage)
- })
- }
- const opDescribeStaleSecurityGroups = "DescribeStaleSecurityGroups"
- // DescribeStaleSecurityGroupsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeStaleSecurityGroups operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeStaleSecurityGroups method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeStaleSecurityGroupsRequest method.
- // req, resp := client.DescribeStaleSecurityGroupsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeStaleSecurityGroupsRequest(input *DescribeStaleSecurityGroupsInput) (req *request.Request, output *DescribeStaleSecurityGroupsOutput) {
- op := &request.Operation{
- Name: opDescribeStaleSecurityGroups,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeStaleSecurityGroupsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeStaleSecurityGroupsOutput{}
- req.Data = output
- return
- }
- // [EC2-VPC only] Describes the stale security group rules for security groups
- // in a specified VPC. Rules are stale when they reference a deleted security
- // group in a peer VPC, or a security group in a peer VPC for which the VPC
- // peering connection has been deleted.
- func (c *EC2) DescribeStaleSecurityGroups(input *DescribeStaleSecurityGroupsInput) (*DescribeStaleSecurityGroupsOutput, error) {
- req, out := c.DescribeStaleSecurityGroupsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeSubnets = "DescribeSubnets"
- // DescribeSubnetsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeSubnets operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeSubnets method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeSubnetsRequest method.
- // req, resp := client.DescribeSubnetsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeSubnetsRequest(input *DescribeSubnetsInput) (req *request.Request, output *DescribeSubnetsOutput) {
- op := &request.Operation{
- Name: opDescribeSubnets,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeSubnetsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeSubnetsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your subnets.
- //
- // For more information about subnets, see Your VPC and Subnets (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Subnets.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeSubnets(input *DescribeSubnetsInput) (*DescribeSubnetsOutput, error) {
- req, out := c.DescribeSubnetsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeTags = "DescribeTags"
- // DescribeTagsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeTags operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeTags method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeTagsRequest method.
- // req, resp := client.DescribeTagsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeTagsRequest(input *DescribeTagsInput) (req *request.Request, output *DescribeTagsOutput) {
- op := &request.Operation{
- Name: opDescribeTags,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeTagsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeTagsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of the tags for your EC2 resources.
- //
- // For more information about tags, see Tagging Your Resources (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeTags(input *DescribeTagsInput) (*DescribeTagsOutput, error) {
- req, out := c.DescribeTagsRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeTagsPages iterates over the pages of a DescribeTags operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeTags method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeTags operation.
- // pageNum := 0
- // err := client.DescribeTagsPages(params,
- // func(page *DescribeTagsOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeTagsPages(input *DescribeTagsInput, fn func(p *DescribeTagsOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeTagsRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeTagsOutput), lastPage)
- })
- }
- const opDescribeVolumeAttribute = "DescribeVolumeAttribute"
- // DescribeVolumeAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVolumeAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVolumeAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVolumeAttributeRequest method.
- // req, resp := client.DescribeVolumeAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVolumeAttributeRequest(input *DescribeVolumeAttributeInput) (req *request.Request, output *DescribeVolumeAttributeOutput) {
- op := &request.Operation{
- Name: opDescribeVolumeAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVolumeAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVolumeAttributeOutput{}
- req.Data = output
- return
- }
- // Describes the specified attribute of the specified volume. You can specify
- // only one attribute at a time.
- //
- // For more information about EBS volumes, see Amazon EBS Volumes (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSVolumes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeVolumeAttribute(input *DescribeVolumeAttributeInput) (*DescribeVolumeAttributeOutput, error) {
- req, out := c.DescribeVolumeAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVolumeStatus = "DescribeVolumeStatus"
- // DescribeVolumeStatusRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVolumeStatus operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVolumeStatus method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVolumeStatusRequest method.
- // req, resp := client.DescribeVolumeStatusRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVolumeStatusRequest(input *DescribeVolumeStatusInput) (req *request.Request, output *DescribeVolumeStatusOutput) {
- op := &request.Operation{
- Name: opDescribeVolumeStatus,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeVolumeStatusInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVolumeStatusOutput{}
- req.Data = output
- return
- }
- // Describes the status of the specified volumes. Volume status provides the
- // result of the checks performed on your volumes to determine events that can
- // impair the performance of your volumes. The performance of a volume can be
- // affected if an issue occurs on the volume's underlying host. If the volume's
- // underlying host experiences a power outage or system issue, after the system
- // is restored, there could be data inconsistencies on the volume. Volume events
- // notify you if this occurs. Volume actions notify you if any action needs
- // to be taken in response to the event.
- //
- // The DescribeVolumeStatus operation provides the following information about
- // the specified volumes:
- //
- // Status: Reflects the current status of the volume. The possible values
- // are ok, impaired , warning, or insufficient-data. If all checks pass, the
- // overall status of the volume is ok. If the check fails, the overall status
- // is impaired. If the status is insufficient-data, then the checks may still
- // be taking place on your volume at the time. We recommend that you retry the
- // request. For more information on volume status, see Monitoring the Status
- // of Your Volumes (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/monitoring-volume-status.html).
- //
- // Events: Reflect the cause of a volume status and may require you to take
- // action. For example, if your volume returns an impaired status, then the
- // volume event might be potential-data-inconsistency. This means that your
- // volume has been affected by an issue with the underlying host, has all I/O
- // operations disabled, and may have inconsistent data.
- //
- // Actions: Reflect the actions you may have to take in response to an event.
- // For example, if the status of the volume is impaired and the volume event
- // shows potential-data-inconsistency, then the action shows enable-volume-io.
- // This means that you may want to enable the I/O operations for the volume
- // by calling the EnableVolumeIO action and then check the volume for data consistency.
- //
- // Volume status is based on the volume status checks, and does not reflect
- // the volume state. Therefore, volume status does not indicate volumes in the
- // error state (for example, when a volume is incapable of accepting I/O.)
- func (c *EC2) DescribeVolumeStatus(input *DescribeVolumeStatusInput) (*DescribeVolumeStatusOutput, error) {
- req, out := c.DescribeVolumeStatusRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeVolumeStatusPages iterates over the pages of a DescribeVolumeStatus operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeVolumeStatus method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeVolumeStatus operation.
- // pageNum := 0
- // err := client.DescribeVolumeStatusPages(params,
- // func(page *DescribeVolumeStatusOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeVolumeStatusPages(input *DescribeVolumeStatusInput, fn func(p *DescribeVolumeStatusOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeVolumeStatusRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeVolumeStatusOutput), lastPage)
- })
- }
- const opDescribeVolumes = "DescribeVolumes"
- // DescribeVolumesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVolumes operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVolumes method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVolumesRequest method.
- // req, resp := client.DescribeVolumesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVolumesRequest(input *DescribeVolumesInput) (req *request.Request, output *DescribeVolumesOutput) {
- op := &request.Operation{
- Name: opDescribeVolumes,
- HTTPMethod: "POST",
- HTTPPath: "/",
- Paginator: &request.Paginator{
- InputTokens: []string{"NextToken"},
- OutputTokens: []string{"NextToken"},
- LimitToken: "MaxResults",
- TruncationToken: "",
- },
- }
- if input == nil {
- input = &DescribeVolumesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVolumesOutput{}
- req.Data = output
- return
- }
- // Describes the specified EBS volumes.
- //
- // If you are describing a long list of volumes, you can paginate the output
- // to make the list more manageable. The MaxResults parameter sets the maximum
- // number of results returned in a single page. If the list of results exceeds
- // your MaxResults value, then that number of results is returned along with
- // a NextToken value that can be passed to a subsequent DescribeVolumes request
- // to retrieve the remaining results.
- //
- // For more information about EBS volumes, see Amazon EBS Volumes (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSVolumes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeVolumes(input *DescribeVolumesInput) (*DescribeVolumesOutput, error) {
- req, out := c.DescribeVolumesRequest(input)
- err := req.Send()
- return out, err
- }
- // DescribeVolumesPages iterates over the pages of a DescribeVolumes operation,
- // calling the "fn" function with the response data for each page. To stop
- // iterating, return false from the fn function.
- //
- // See DescribeVolumes method for more information on how to use this operation.
- //
- // Note: This operation can generate multiple requests to a service.
- //
- // // Example iterating over at most 3 pages of a DescribeVolumes operation.
- // pageNum := 0
- // err := client.DescribeVolumesPages(params,
- // func(page *DescribeVolumesOutput, lastPage bool) bool {
- // pageNum++
- // fmt.Println(page)
- // return pageNum <= 3
- // })
- //
- func (c *EC2) DescribeVolumesPages(input *DescribeVolumesInput, fn func(p *DescribeVolumesOutput, lastPage bool) (shouldContinue bool)) error {
- page, _ := c.DescribeVolumesRequest(input)
- page.Handlers.Build.PushBack(request.MakeAddToUserAgentFreeFormHandler("Paginator"))
- return page.EachPage(func(p interface{}, lastPage bool) bool {
- return fn(p.(*DescribeVolumesOutput), lastPage)
- })
- }
- const opDescribeVpcAttribute = "DescribeVpcAttribute"
- // DescribeVpcAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpcAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpcAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpcAttributeRequest method.
- // req, resp := client.DescribeVpcAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpcAttributeRequest(input *DescribeVpcAttributeInput) (req *request.Request, output *DescribeVpcAttributeOutput) {
- op := &request.Operation{
- Name: opDescribeVpcAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpcAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpcAttributeOutput{}
- req.Data = output
- return
- }
- // Describes the specified attribute of the specified VPC. You can specify only
- // one attribute at a time.
- func (c *EC2) DescribeVpcAttribute(input *DescribeVpcAttributeInput) (*DescribeVpcAttributeOutput, error) {
- req, out := c.DescribeVpcAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpcClassicLink = "DescribeVpcClassicLink"
- // DescribeVpcClassicLinkRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpcClassicLink operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpcClassicLink method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpcClassicLinkRequest method.
- // req, resp := client.DescribeVpcClassicLinkRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpcClassicLinkRequest(input *DescribeVpcClassicLinkInput) (req *request.Request, output *DescribeVpcClassicLinkOutput) {
- op := &request.Operation{
- Name: opDescribeVpcClassicLink,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpcClassicLinkInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpcClassicLinkOutput{}
- req.Data = output
- return
- }
- // Describes the ClassicLink status of one or more VPCs.
- func (c *EC2) DescribeVpcClassicLink(input *DescribeVpcClassicLinkInput) (*DescribeVpcClassicLinkOutput, error) {
- req, out := c.DescribeVpcClassicLinkRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpcClassicLinkDnsSupport = "DescribeVpcClassicLinkDnsSupport"
- // DescribeVpcClassicLinkDnsSupportRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpcClassicLinkDnsSupport operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpcClassicLinkDnsSupport method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpcClassicLinkDnsSupportRequest method.
- // req, resp := client.DescribeVpcClassicLinkDnsSupportRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpcClassicLinkDnsSupportRequest(input *DescribeVpcClassicLinkDnsSupportInput) (req *request.Request, output *DescribeVpcClassicLinkDnsSupportOutput) {
- op := &request.Operation{
- Name: opDescribeVpcClassicLinkDnsSupport,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpcClassicLinkDnsSupportInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpcClassicLinkDnsSupportOutput{}
- req.Data = output
- return
- }
- // Describes the ClassicLink DNS support status of one or more VPCs. If enabled,
- // the DNS hostname of a linked EC2-Classic instance resolves to its private
- // IP address when addressed from an instance in the VPC to which it's linked.
- // Similarly, the DNS hostname of an instance in a VPC resolves to its private
- // IP address when addressed from a linked EC2-Classic instance. For more information
- // about ClassicLink, see ClassicLink (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/vpc-classiclink.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DescribeVpcClassicLinkDnsSupport(input *DescribeVpcClassicLinkDnsSupportInput) (*DescribeVpcClassicLinkDnsSupportOutput, error) {
- req, out := c.DescribeVpcClassicLinkDnsSupportRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpcEndpointServices = "DescribeVpcEndpointServices"
- // DescribeVpcEndpointServicesRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpcEndpointServices operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpcEndpointServices method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpcEndpointServicesRequest method.
- // req, resp := client.DescribeVpcEndpointServicesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpcEndpointServicesRequest(input *DescribeVpcEndpointServicesInput) (req *request.Request, output *DescribeVpcEndpointServicesOutput) {
- op := &request.Operation{
- Name: opDescribeVpcEndpointServices,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpcEndpointServicesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpcEndpointServicesOutput{}
- req.Data = output
- return
- }
- // Describes all supported AWS services that can be specified when creating
- // a VPC endpoint.
- func (c *EC2) DescribeVpcEndpointServices(input *DescribeVpcEndpointServicesInput) (*DescribeVpcEndpointServicesOutput, error) {
- req, out := c.DescribeVpcEndpointServicesRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpcEndpoints = "DescribeVpcEndpoints"
- // DescribeVpcEndpointsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpcEndpoints operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpcEndpoints method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpcEndpointsRequest method.
- // req, resp := client.DescribeVpcEndpointsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpcEndpointsRequest(input *DescribeVpcEndpointsInput) (req *request.Request, output *DescribeVpcEndpointsOutput) {
- op := &request.Operation{
- Name: opDescribeVpcEndpoints,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpcEndpointsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpcEndpointsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your VPC endpoints.
- func (c *EC2) DescribeVpcEndpoints(input *DescribeVpcEndpointsInput) (*DescribeVpcEndpointsOutput, error) {
- req, out := c.DescribeVpcEndpointsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpcPeeringConnections = "DescribeVpcPeeringConnections"
- // DescribeVpcPeeringConnectionsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpcPeeringConnections operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpcPeeringConnections method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpcPeeringConnectionsRequest method.
- // req, resp := client.DescribeVpcPeeringConnectionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpcPeeringConnectionsRequest(input *DescribeVpcPeeringConnectionsInput) (req *request.Request, output *DescribeVpcPeeringConnectionsOutput) {
- op := &request.Operation{
- Name: opDescribeVpcPeeringConnections,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpcPeeringConnectionsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpcPeeringConnectionsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your VPC peering connections.
- func (c *EC2) DescribeVpcPeeringConnections(input *DescribeVpcPeeringConnectionsInput) (*DescribeVpcPeeringConnectionsOutput, error) {
- req, out := c.DescribeVpcPeeringConnectionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpcs = "DescribeVpcs"
- // DescribeVpcsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpcs operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpcs method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpcsRequest method.
- // req, resp := client.DescribeVpcsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpcsRequest(input *DescribeVpcsInput) (req *request.Request, output *DescribeVpcsOutput) {
- op := &request.Operation{
- Name: opDescribeVpcs,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpcsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpcsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your VPCs.
- func (c *EC2) DescribeVpcs(input *DescribeVpcsInput) (*DescribeVpcsOutput, error) {
- req, out := c.DescribeVpcsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpnConnections = "DescribeVpnConnections"
- // DescribeVpnConnectionsRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpnConnections operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpnConnections method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpnConnectionsRequest method.
- // req, resp := client.DescribeVpnConnectionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpnConnectionsRequest(input *DescribeVpnConnectionsInput) (req *request.Request, output *DescribeVpnConnectionsOutput) {
- op := &request.Operation{
- Name: opDescribeVpnConnections,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpnConnectionsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpnConnectionsOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your VPN connections.
- //
- // For more information about VPN connections, see Adding a Hardware Virtual
- // Private Gateway to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeVpnConnections(input *DescribeVpnConnectionsInput) (*DescribeVpnConnectionsOutput, error) {
- req, out := c.DescribeVpnConnectionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opDescribeVpnGateways = "DescribeVpnGateways"
- // DescribeVpnGatewaysRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeVpnGateways operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DescribeVpnGateways method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DescribeVpnGatewaysRequest method.
- // req, resp := client.DescribeVpnGatewaysRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DescribeVpnGatewaysRequest(input *DescribeVpnGatewaysInput) (req *request.Request, output *DescribeVpnGatewaysOutput) {
- op := &request.Operation{
- Name: opDescribeVpnGateways,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeVpnGatewaysInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DescribeVpnGatewaysOutput{}
- req.Data = output
- return
- }
- // Describes one or more of your virtual private gateways.
- //
- // For more information about virtual private gateways, see Adding an IPsec
- // Hardware VPN to Your VPC (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_VPN.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DescribeVpnGateways(input *DescribeVpnGatewaysInput) (*DescribeVpnGatewaysOutput, error) {
- req, out := c.DescribeVpnGatewaysRequest(input)
- err := req.Send()
- return out, err
- }
- const opDetachClassicLinkVpc = "DetachClassicLinkVpc"
- // DetachClassicLinkVpcRequest generates a "aws/request.Request" representing the
- // client's request for the DetachClassicLinkVpc operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DetachClassicLinkVpc method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DetachClassicLinkVpcRequest method.
- // req, resp := client.DetachClassicLinkVpcRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DetachClassicLinkVpcRequest(input *DetachClassicLinkVpcInput) (req *request.Request, output *DetachClassicLinkVpcOutput) {
- op := &request.Operation{
- Name: opDetachClassicLinkVpc,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DetachClassicLinkVpcInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DetachClassicLinkVpcOutput{}
- req.Data = output
- return
- }
- // Unlinks (detaches) a linked EC2-Classic instance from a VPC. After the instance
- // has been unlinked, the VPC security groups are no longer associated with
- // it. An instance is automatically unlinked from a VPC when it's stopped.
- func (c *EC2) DetachClassicLinkVpc(input *DetachClassicLinkVpcInput) (*DetachClassicLinkVpcOutput, error) {
- req, out := c.DetachClassicLinkVpcRequest(input)
- err := req.Send()
- return out, err
- }
- const opDetachInternetGateway = "DetachInternetGateway"
- // DetachInternetGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the DetachInternetGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DetachInternetGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DetachInternetGatewayRequest method.
- // req, resp := client.DetachInternetGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DetachInternetGatewayRequest(input *DetachInternetGatewayInput) (req *request.Request, output *DetachInternetGatewayOutput) {
- op := &request.Operation{
- Name: opDetachInternetGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DetachInternetGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DetachInternetGatewayOutput{}
- req.Data = output
- return
- }
- // Detaches an Internet gateway from a VPC, disabling connectivity between the
- // Internet and the VPC. The VPC must not contain any running instances with
- // Elastic IP addresses.
- func (c *EC2) DetachInternetGateway(input *DetachInternetGatewayInput) (*DetachInternetGatewayOutput, error) {
- req, out := c.DetachInternetGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opDetachNetworkInterface = "DetachNetworkInterface"
- // DetachNetworkInterfaceRequest generates a "aws/request.Request" representing the
- // client's request for the DetachNetworkInterface operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DetachNetworkInterface method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DetachNetworkInterfaceRequest method.
- // req, resp := client.DetachNetworkInterfaceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DetachNetworkInterfaceRequest(input *DetachNetworkInterfaceInput) (req *request.Request, output *DetachNetworkInterfaceOutput) {
- op := &request.Operation{
- Name: opDetachNetworkInterface,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DetachNetworkInterfaceInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DetachNetworkInterfaceOutput{}
- req.Data = output
- return
- }
- // Detaches a network interface from an instance.
- func (c *EC2) DetachNetworkInterface(input *DetachNetworkInterfaceInput) (*DetachNetworkInterfaceOutput, error) {
- req, out := c.DetachNetworkInterfaceRequest(input)
- err := req.Send()
- return out, err
- }
- const opDetachVolume = "DetachVolume"
- // DetachVolumeRequest generates a "aws/request.Request" representing the
- // client's request for the DetachVolume operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DetachVolume method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DetachVolumeRequest method.
- // req, resp := client.DetachVolumeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DetachVolumeRequest(input *DetachVolumeInput) (req *request.Request, output *VolumeAttachment) {
- op := &request.Operation{
- Name: opDetachVolume,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DetachVolumeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &VolumeAttachment{}
- req.Data = output
- return
- }
- // Detaches an EBS volume from an instance. Make sure to unmount any file systems
- // on the device within your operating system before detaching the volume. Failure
- // to do so results in the volume being stuck in a busy state while detaching.
- //
- // If an Amazon EBS volume is the root device of an instance, it can't be detached
- // while the instance is running. To detach the root volume, stop the instance
- // first.
- //
- // When a volume with an AWS Marketplace product code is detached from an instance,
- // the product code is no longer associated with the instance.
- //
- // For more information, see Detaching an Amazon EBS Volume (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-detaching-volume.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DetachVolume(input *DetachVolumeInput) (*VolumeAttachment, error) {
- req, out := c.DetachVolumeRequest(input)
- err := req.Send()
- return out, err
- }
- const opDetachVpnGateway = "DetachVpnGateway"
- // DetachVpnGatewayRequest generates a "aws/request.Request" representing the
- // client's request for the DetachVpnGateway operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DetachVpnGateway method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DetachVpnGatewayRequest method.
- // req, resp := client.DetachVpnGatewayRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DetachVpnGatewayRequest(input *DetachVpnGatewayInput) (req *request.Request, output *DetachVpnGatewayOutput) {
- op := &request.Operation{
- Name: opDetachVpnGateway,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DetachVpnGatewayInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DetachVpnGatewayOutput{}
- req.Data = output
- return
- }
- // Detaches a virtual private gateway from a VPC. You do this if you're planning
- // to turn off the VPC and not use it anymore. You can confirm a virtual private
- // gateway has been completely detached from a VPC by describing the virtual
- // private gateway (any attachments to the virtual private gateway are also
- // described).
- //
- // You must wait for the attachment's state to switch to detached before you
- // can delete the VPC or attach a different VPC to the virtual private gateway.
- func (c *EC2) DetachVpnGateway(input *DetachVpnGatewayInput) (*DetachVpnGatewayOutput, error) {
- req, out := c.DetachVpnGatewayRequest(input)
- err := req.Send()
- return out, err
- }
- const opDisableVgwRoutePropagation = "DisableVgwRoutePropagation"
- // DisableVgwRoutePropagationRequest generates a "aws/request.Request" representing the
- // client's request for the DisableVgwRoutePropagation operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DisableVgwRoutePropagation method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DisableVgwRoutePropagationRequest method.
- // req, resp := client.DisableVgwRoutePropagationRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DisableVgwRoutePropagationRequest(input *DisableVgwRoutePropagationInput) (req *request.Request, output *DisableVgwRoutePropagationOutput) {
- op := &request.Operation{
- Name: opDisableVgwRoutePropagation,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DisableVgwRoutePropagationInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DisableVgwRoutePropagationOutput{}
- req.Data = output
- return
- }
- // Disables a virtual private gateway (VGW) from propagating routes to a specified
- // route table of a VPC.
- func (c *EC2) DisableVgwRoutePropagation(input *DisableVgwRoutePropagationInput) (*DisableVgwRoutePropagationOutput, error) {
- req, out := c.DisableVgwRoutePropagationRequest(input)
- err := req.Send()
- return out, err
- }
- const opDisableVpcClassicLink = "DisableVpcClassicLink"
- // DisableVpcClassicLinkRequest generates a "aws/request.Request" representing the
- // client's request for the DisableVpcClassicLink operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DisableVpcClassicLink method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DisableVpcClassicLinkRequest method.
- // req, resp := client.DisableVpcClassicLinkRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DisableVpcClassicLinkRequest(input *DisableVpcClassicLinkInput) (req *request.Request, output *DisableVpcClassicLinkOutput) {
- op := &request.Operation{
- Name: opDisableVpcClassicLink,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DisableVpcClassicLinkInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DisableVpcClassicLinkOutput{}
- req.Data = output
- return
- }
- // Disables ClassicLink for a VPC. You cannot disable ClassicLink for a VPC
- // that has EC2-Classic instances linked to it.
- func (c *EC2) DisableVpcClassicLink(input *DisableVpcClassicLinkInput) (*DisableVpcClassicLinkOutput, error) {
- req, out := c.DisableVpcClassicLinkRequest(input)
- err := req.Send()
- return out, err
- }
- const opDisableVpcClassicLinkDnsSupport = "DisableVpcClassicLinkDnsSupport"
- // DisableVpcClassicLinkDnsSupportRequest generates a "aws/request.Request" representing the
- // client's request for the DisableVpcClassicLinkDnsSupport operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DisableVpcClassicLinkDnsSupport method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DisableVpcClassicLinkDnsSupportRequest method.
- // req, resp := client.DisableVpcClassicLinkDnsSupportRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DisableVpcClassicLinkDnsSupportRequest(input *DisableVpcClassicLinkDnsSupportInput) (req *request.Request, output *DisableVpcClassicLinkDnsSupportOutput) {
- op := &request.Operation{
- Name: opDisableVpcClassicLinkDnsSupport,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DisableVpcClassicLinkDnsSupportInput{}
- }
- req = c.newRequest(op, input, output)
- output = &DisableVpcClassicLinkDnsSupportOutput{}
- req.Data = output
- return
- }
- // Disables ClassicLink DNS support for a VPC. If disabled, DNS hostnames resolve
- // to public IP addresses when addressed between a linked EC2-Classic instance
- // and instances in the VPC to which it's linked. For more information about
- // ClassicLink, see ClassicLink (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/vpc-classiclink.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) DisableVpcClassicLinkDnsSupport(input *DisableVpcClassicLinkDnsSupportInput) (*DisableVpcClassicLinkDnsSupportOutput, error) {
- req, out := c.DisableVpcClassicLinkDnsSupportRequest(input)
- err := req.Send()
- return out, err
- }
- const opDisassociateAddress = "DisassociateAddress"
- // DisassociateAddressRequest generates a "aws/request.Request" representing the
- // client's request for the DisassociateAddress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DisassociateAddress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DisassociateAddressRequest method.
- // req, resp := client.DisassociateAddressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DisassociateAddressRequest(input *DisassociateAddressInput) (req *request.Request, output *DisassociateAddressOutput) {
- op := &request.Operation{
- Name: opDisassociateAddress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DisassociateAddressInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DisassociateAddressOutput{}
- req.Data = output
- return
- }
- // Disassociates an Elastic IP address from the instance or network interface
- // it's associated with.
- //
- // An Elastic IP address is for use in either the EC2-Classic platform or in
- // a VPC. For more information, see Elastic IP Addresses (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/elastic-ip-addresses-eip.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // This is an idempotent operation. If you perform the operation more than
- // once, Amazon EC2 doesn't return an error.
- func (c *EC2) DisassociateAddress(input *DisassociateAddressInput) (*DisassociateAddressOutput, error) {
- req, out := c.DisassociateAddressRequest(input)
- err := req.Send()
- return out, err
- }
- const opDisassociateRouteTable = "DisassociateRouteTable"
- // DisassociateRouteTableRequest generates a "aws/request.Request" representing the
- // client's request for the DisassociateRouteTable operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the DisassociateRouteTable method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the DisassociateRouteTableRequest method.
- // req, resp := client.DisassociateRouteTableRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) DisassociateRouteTableRequest(input *DisassociateRouteTableInput) (req *request.Request, output *DisassociateRouteTableOutput) {
- op := &request.Operation{
- Name: opDisassociateRouteTable,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DisassociateRouteTableInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &DisassociateRouteTableOutput{}
- req.Data = output
- return
- }
- // Disassociates a subnet from a route table.
- //
- // After you perform this action, the subnet no longer uses the routes in the
- // route table. Instead, it uses the routes in the VPC's main route table. For
- // more information about route tables, see Route Tables (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Route_Tables.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) DisassociateRouteTable(input *DisassociateRouteTableInput) (*DisassociateRouteTableOutput, error) {
- req, out := c.DisassociateRouteTableRequest(input)
- err := req.Send()
- return out, err
- }
- const opEnableVgwRoutePropagation = "EnableVgwRoutePropagation"
- // EnableVgwRoutePropagationRequest generates a "aws/request.Request" representing the
- // client's request for the EnableVgwRoutePropagation operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the EnableVgwRoutePropagation method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the EnableVgwRoutePropagationRequest method.
- // req, resp := client.EnableVgwRoutePropagationRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) EnableVgwRoutePropagationRequest(input *EnableVgwRoutePropagationInput) (req *request.Request, output *EnableVgwRoutePropagationOutput) {
- op := &request.Operation{
- Name: opEnableVgwRoutePropagation,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &EnableVgwRoutePropagationInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &EnableVgwRoutePropagationOutput{}
- req.Data = output
- return
- }
- // Enables a virtual private gateway (VGW) to propagate routes to the specified
- // route table of a VPC.
- func (c *EC2) EnableVgwRoutePropagation(input *EnableVgwRoutePropagationInput) (*EnableVgwRoutePropagationOutput, error) {
- req, out := c.EnableVgwRoutePropagationRequest(input)
- err := req.Send()
- return out, err
- }
- const opEnableVolumeIO = "EnableVolumeIO"
- // EnableVolumeIORequest generates a "aws/request.Request" representing the
- // client's request for the EnableVolumeIO operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the EnableVolumeIO method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the EnableVolumeIORequest method.
- // req, resp := client.EnableVolumeIORequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) EnableVolumeIORequest(input *EnableVolumeIOInput) (req *request.Request, output *EnableVolumeIOOutput) {
- op := &request.Operation{
- Name: opEnableVolumeIO,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &EnableVolumeIOInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &EnableVolumeIOOutput{}
- req.Data = output
- return
- }
- // Enables I/O operations for a volume that had I/O operations disabled because
- // the data on the volume was potentially inconsistent.
- func (c *EC2) EnableVolumeIO(input *EnableVolumeIOInput) (*EnableVolumeIOOutput, error) {
- req, out := c.EnableVolumeIORequest(input)
- err := req.Send()
- return out, err
- }
- const opEnableVpcClassicLink = "EnableVpcClassicLink"
- // EnableVpcClassicLinkRequest generates a "aws/request.Request" representing the
- // client's request for the EnableVpcClassicLink operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the EnableVpcClassicLink method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the EnableVpcClassicLinkRequest method.
- // req, resp := client.EnableVpcClassicLinkRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) EnableVpcClassicLinkRequest(input *EnableVpcClassicLinkInput) (req *request.Request, output *EnableVpcClassicLinkOutput) {
- op := &request.Operation{
- Name: opEnableVpcClassicLink,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &EnableVpcClassicLinkInput{}
- }
- req = c.newRequest(op, input, output)
- output = &EnableVpcClassicLinkOutput{}
- req.Data = output
- return
- }
- // Enables a VPC for ClassicLink. You can then link EC2-Classic instances to
- // your ClassicLink-enabled VPC to allow communication over private IP addresses.
- // You cannot enable your VPC for ClassicLink if any of your VPC's route tables
- // have existing routes for address ranges within the 10.0.0.0/8 IP address
- // range, excluding local routes for VPCs in the 10.0.0.0/16 and 10.1.0.0/16
- // IP address ranges. For more information, see ClassicLink (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/vpc-classiclink.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) EnableVpcClassicLink(input *EnableVpcClassicLinkInput) (*EnableVpcClassicLinkOutput, error) {
- req, out := c.EnableVpcClassicLinkRequest(input)
- err := req.Send()
- return out, err
- }
- const opEnableVpcClassicLinkDnsSupport = "EnableVpcClassicLinkDnsSupport"
- // EnableVpcClassicLinkDnsSupportRequest generates a "aws/request.Request" representing the
- // client's request for the EnableVpcClassicLinkDnsSupport operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the EnableVpcClassicLinkDnsSupport method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the EnableVpcClassicLinkDnsSupportRequest method.
- // req, resp := client.EnableVpcClassicLinkDnsSupportRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) EnableVpcClassicLinkDnsSupportRequest(input *EnableVpcClassicLinkDnsSupportInput) (req *request.Request, output *EnableVpcClassicLinkDnsSupportOutput) {
- op := &request.Operation{
- Name: opEnableVpcClassicLinkDnsSupport,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &EnableVpcClassicLinkDnsSupportInput{}
- }
- req = c.newRequest(op, input, output)
- output = &EnableVpcClassicLinkDnsSupportOutput{}
- req.Data = output
- return
- }
- // Enables a VPC to support DNS hostname resolution for ClassicLink. If enabled,
- // the DNS hostname of a linked EC2-Classic instance resolves to its private
- // IP address when addressed from an instance in the VPC to which it's linked.
- // Similarly, the DNS hostname of an instance in a VPC resolves to its private
- // IP address when addressed from a linked EC2-Classic instance. For more information
- // about ClassicLink, see ClassicLink (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/vpc-classiclink.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) EnableVpcClassicLinkDnsSupport(input *EnableVpcClassicLinkDnsSupportInput) (*EnableVpcClassicLinkDnsSupportOutput, error) {
- req, out := c.EnableVpcClassicLinkDnsSupportRequest(input)
- err := req.Send()
- return out, err
- }
- const opGetConsoleOutput = "GetConsoleOutput"
- // GetConsoleOutputRequest generates a "aws/request.Request" representing the
- // client's request for the GetConsoleOutput operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the GetConsoleOutput method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the GetConsoleOutputRequest method.
- // req, resp := client.GetConsoleOutputRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) GetConsoleOutputRequest(input *GetConsoleOutputInput) (req *request.Request, output *GetConsoleOutputOutput) {
- op := &request.Operation{
- Name: opGetConsoleOutput,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetConsoleOutputInput{}
- }
- req = c.newRequest(op, input, output)
- output = &GetConsoleOutputOutput{}
- req.Data = output
- return
- }
- // Gets the console output for the specified instance.
- //
- // Instances do not have a physical monitor through which you can view their
- // console output. They also lack physical controls that allow you to power
- // up, reboot, or shut them down. To allow these actions, we provide them through
- // the Amazon EC2 API and command line interface.
- //
- // Instance console output is buffered and posted shortly after instance boot,
- // reboot, and termination. Amazon EC2 preserves the most recent 64 KB output
- // which is available for at least one hour after the most recent post.
- //
- // For Linux instances, the instance console output displays the exact console
- // output that would normally be displayed on a physical monitor attached to
- // a computer. This output is buffered because the instance produces it and
- // then posts it to a store where the instance's owner can retrieve it.
- //
- // For Windows instances, the instance console output includes output from
- // the EC2Config service.
- func (c *EC2) GetConsoleOutput(input *GetConsoleOutputInput) (*GetConsoleOutputOutput, error) {
- req, out := c.GetConsoleOutputRequest(input)
- err := req.Send()
- return out, err
- }
- const opGetConsoleScreenshot = "GetConsoleScreenshot"
- // GetConsoleScreenshotRequest generates a "aws/request.Request" representing the
- // client's request for the GetConsoleScreenshot operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the GetConsoleScreenshot method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the GetConsoleScreenshotRequest method.
- // req, resp := client.GetConsoleScreenshotRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) GetConsoleScreenshotRequest(input *GetConsoleScreenshotInput) (req *request.Request, output *GetConsoleScreenshotOutput) {
- op := &request.Operation{
- Name: opGetConsoleScreenshot,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetConsoleScreenshotInput{}
- }
- req = c.newRequest(op, input, output)
- output = &GetConsoleScreenshotOutput{}
- req.Data = output
- return
- }
- // Retrieve a JPG-format screenshot of a running instance to help with troubleshooting.
- //
- // The returned content is Base64-encoded.
- func (c *EC2) GetConsoleScreenshot(input *GetConsoleScreenshotInput) (*GetConsoleScreenshotOutput, error) {
- req, out := c.GetConsoleScreenshotRequest(input)
- err := req.Send()
- return out, err
- }
- const opGetPasswordData = "GetPasswordData"
- // GetPasswordDataRequest generates a "aws/request.Request" representing the
- // client's request for the GetPasswordData operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the GetPasswordData method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the GetPasswordDataRequest method.
- // req, resp := client.GetPasswordDataRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) GetPasswordDataRequest(input *GetPasswordDataInput) (req *request.Request, output *GetPasswordDataOutput) {
- op := &request.Operation{
- Name: opGetPasswordData,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetPasswordDataInput{}
- }
- req = c.newRequest(op, input, output)
- output = &GetPasswordDataOutput{}
- req.Data = output
- return
- }
- // Retrieves the encrypted administrator password for an instance running Windows.
- //
- // The Windows password is generated at boot if the EC2Config service plugin,
- // Ec2SetPassword, is enabled. This usually only happens the first time an AMI
- // is launched, and then Ec2SetPassword is automatically disabled. The password
- // is not generated for rebundled AMIs unless Ec2SetPassword is enabled before
- // bundling.
- //
- // The password is encrypted using the key pair that you specified when you
- // launched the instance. You must provide the corresponding key pair file.
- //
- // Password generation and encryption takes a few moments. We recommend that
- // you wait up to 15 minutes after launching an instance before trying to retrieve
- // the generated password.
- func (c *EC2) GetPasswordData(input *GetPasswordDataInput) (*GetPasswordDataOutput, error) {
- req, out := c.GetPasswordDataRequest(input)
- err := req.Send()
- return out, err
- }
- const opImportImage = "ImportImage"
- // ImportImageRequest generates a "aws/request.Request" representing the
- // client's request for the ImportImage operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ImportImage method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ImportImageRequest method.
- // req, resp := client.ImportImageRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ImportImageRequest(input *ImportImageInput) (req *request.Request, output *ImportImageOutput) {
- op := &request.Operation{
- Name: opImportImage,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ImportImageInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ImportImageOutput{}
- req.Data = output
- return
- }
- // Import single or multi-volume disk images or EBS snapshots into an Amazon
- // Machine Image (AMI).
- func (c *EC2) ImportImage(input *ImportImageInput) (*ImportImageOutput, error) {
- req, out := c.ImportImageRequest(input)
- err := req.Send()
- return out, err
- }
- const opImportInstance = "ImportInstance"
- // ImportInstanceRequest generates a "aws/request.Request" representing the
- // client's request for the ImportInstance operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ImportInstance method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ImportInstanceRequest method.
- // req, resp := client.ImportInstanceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ImportInstanceRequest(input *ImportInstanceInput) (req *request.Request, output *ImportInstanceOutput) {
- op := &request.Operation{
- Name: opImportInstance,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ImportInstanceInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ImportInstanceOutput{}
- req.Data = output
- return
- }
- // Creates an import instance task using metadata from the specified disk image.
- // ImportInstance only supports single-volume VMs. To import multi-volume VMs,
- // use ImportImage. After importing the image, you then upload it using the
- // ec2-import-volume command in the EC2 command line tools. For more information,
- // see Using the Command Line Tools to Import Your Virtual Machine to Amazon
- // EC2 (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UploadingYourInstancesandVolumes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // For information about the import manifest referenced by this API action,
- // see VM Import Manifest (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/manifest.html).
- func (c *EC2) ImportInstance(input *ImportInstanceInput) (*ImportInstanceOutput, error) {
- req, out := c.ImportInstanceRequest(input)
- err := req.Send()
- return out, err
- }
- const opImportKeyPair = "ImportKeyPair"
- // ImportKeyPairRequest generates a "aws/request.Request" representing the
- // client's request for the ImportKeyPair operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ImportKeyPair method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ImportKeyPairRequest method.
- // req, resp := client.ImportKeyPairRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ImportKeyPairRequest(input *ImportKeyPairInput) (req *request.Request, output *ImportKeyPairOutput) {
- op := &request.Operation{
- Name: opImportKeyPair,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ImportKeyPairInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ImportKeyPairOutput{}
- req.Data = output
- return
- }
- // Imports the public key from an RSA key pair that you created with a third-party
- // tool. Compare this with CreateKeyPair, in which AWS creates the key pair
- // and gives the keys to you (AWS keeps a copy of the public key). With ImportKeyPair,
- // you create the key pair and give AWS just the public key. The private key
- // is never transferred between you and AWS.
- //
- // For more information about key pairs, see Key Pairs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-key-pairs.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) ImportKeyPair(input *ImportKeyPairInput) (*ImportKeyPairOutput, error) {
- req, out := c.ImportKeyPairRequest(input)
- err := req.Send()
- return out, err
- }
- const opImportSnapshot = "ImportSnapshot"
- // ImportSnapshotRequest generates a "aws/request.Request" representing the
- // client's request for the ImportSnapshot operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ImportSnapshot method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ImportSnapshotRequest method.
- // req, resp := client.ImportSnapshotRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ImportSnapshotRequest(input *ImportSnapshotInput) (req *request.Request, output *ImportSnapshotOutput) {
- op := &request.Operation{
- Name: opImportSnapshot,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ImportSnapshotInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ImportSnapshotOutput{}
- req.Data = output
- return
- }
- // Imports a disk into an EBS snapshot.
- func (c *EC2) ImportSnapshot(input *ImportSnapshotInput) (*ImportSnapshotOutput, error) {
- req, out := c.ImportSnapshotRequest(input)
- err := req.Send()
- return out, err
- }
- const opImportVolume = "ImportVolume"
- // ImportVolumeRequest generates a "aws/request.Request" representing the
- // client's request for the ImportVolume operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ImportVolume method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ImportVolumeRequest method.
- // req, resp := client.ImportVolumeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ImportVolumeRequest(input *ImportVolumeInput) (req *request.Request, output *ImportVolumeOutput) {
- op := &request.Operation{
- Name: opImportVolume,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ImportVolumeInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ImportVolumeOutput{}
- req.Data = output
- return
- }
- // Creates an import volume task using metadata from the specified disk image.
- // After importing the image, you then upload it using the ec2-import-volume
- // command in the Amazon EC2 command-line interface (CLI) tools. For more information,
- // see Using the Command Line Tools to Import Your Virtual Machine to Amazon
- // EC2 (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UploadingYourInstancesandVolumes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // For information about the import manifest referenced by this API action,
- // see VM Import Manifest (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/manifest.html).
- func (c *EC2) ImportVolume(input *ImportVolumeInput) (*ImportVolumeOutput, error) {
- req, out := c.ImportVolumeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyHosts = "ModifyHosts"
- // ModifyHostsRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyHosts operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyHosts method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyHostsRequest method.
- // req, resp := client.ModifyHostsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyHostsRequest(input *ModifyHostsInput) (req *request.Request, output *ModifyHostsOutput) {
- op := &request.Operation{
- Name: opModifyHosts,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyHostsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ModifyHostsOutput{}
- req.Data = output
- return
- }
- // Modify the auto-placement setting of a Dedicated host. When auto-placement
- // is enabled, AWS will place instances that you launch with a tenancy of host,
- // but without targeting a specific host ID, onto any available Dedicated host
- // in your account which has auto-placement enabled. When auto-placement is
- // disabled, you need to provide a host ID if you want the instance to launch
- // onto a specific host. If no host ID is provided, the instance will be launched
- // onto a suitable host which has auto-placement enabled.
- func (c *EC2) ModifyHosts(input *ModifyHostsInput) (*ModifyHostsOutput, error) {
- req, out := c.ModifyHostsRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyIdFormat = "ModifyIdFormat"
- // ModifyIdFormatRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyIdFormat operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyIdFormat method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyIdFormatRequest method.
- // req, resp := client.ModifyIdFormatRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyIdFormatRequest(input *ModifyIdFormatInput) (req *request.Request, output *ModifyIdFormatOutput) {
- op := &request.Operation{
- Name: opModifyIdFormat,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyIdFormatInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifyIdFormatOutput{}
- req.Data = output
- return
- }
- // Modifies the ID format for the specified resource on a per-region basis.
- // You can specify that resources should receive longer IDs (17-character IDs)
- // when they are created. The following resource types support longer IDs: instance
- // | reservation | snapshot | volume.
- //
- // This setting applies to the IAM user who makes the request; it does not
- // apply to the entire AWS account. By default, an IAM user defaults to the
- // same settings as the root user. If you're using this action as the root user,
- // then these settings apply to the entire account, unless an IAM user explicitly
- // overrides these settings for themselves. For more information, see Resource
- // IDs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/resource-ids.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Resources created with longer IDs are visible to all IAM roles and users,
- // regardless of these settings and provided that they have permission to use
- // the relevant Describe command for the resource type.
- func (c *EC2) ModifyIdFormat(input *ModifyIdFormatInput) (*ModifyIdFormatOutput, error) {
- req, out := c.ModifyIdFormatRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyIdentityIdFormat = "ModifyIdentityIdFormat"
- // ModifyIdentityIdFormatRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyIdentityIdFormat operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyIdentityIdFormat method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyIdentityIdFormatRequest method.
- // req, resp := client.ModifyIdentityIdFormatRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyIdentityIdFormatRequest(input *ModifyIdentityIdFormatInput) (req *request.Request, output *ModifyIdentityIdFormatOutput) {
- op := &request.Operation{
- Name: opModifyIdentityIdFormat,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyIdentityIdFormatInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifyIdentityIdFormatOutput{}
- req.Data = output
- return
- }
- // Modifies the ID format of a resource for the specified IAM user, IAM role,
- // or root user. You can specify that resources should receive longer IDs (17-character
- // IDs) when they are created. The following resource types support longer IDs:
- // instance | reservation | snapshot | volume. For more information, see Resource
- // IDs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/resource-ids.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // This setting applies to the principal specified in the request; it does
- // not apply to the principal that makes the request.
- //
- // Resources created with longer IDs are visible to all IAM roles and users,
- // regardless of these settings and provided that they have permission to use
- // the relevant Describe command for the resource type.
- func (c *EC2) ModifyIdentityIdFormat(input *ModifyIdentityIdFormatInput) (*ModifyIdentityIdFormatOutput, error) {
- req, out := c.ModifyIdentityIdFormatRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyImageAttribute = "ModifyImageAttribute"
- // ModifyImageAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyImageAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyImageAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyImageAttributeRequest method.
- // req, resp := client.ModifyImageAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyImageAttributeRequest(input *ModifyImageAttributeInput) (req *request.Request, output *ModifyImageAttributeOutput) {
- op := &request.Operation{
- Name: opModifyImageAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyImageAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifyImageAttributeOutput{}
- req.Data = output
- return
- }
- // Modifies the specified attribute of the specified AMI. You can specify only
- // one attribute at a time.
- //
- // AWS Marketplace product codes cannot be modified. Images with an AWS Marketplace
- // product code cannot be made public.
- //
- // The SriovNetSupport enhanced networking attribute cannot be changed using
- // this command. Instead, enable SriovNetSupport on an instance and create an
- // AMI from the instance. This will result in an image with SriovNetSupport
- // enabled.
- func (c *EC2) ModifyImageAttribute(input *ModifyImageAttributeInput) (*ModifyImageAttributeOutput, error) {
- req, out := c.ModifyImageAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyInstanceAttribute = "ModifyInstanceAttribute"
- // ModifyInstanceAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyInstanceAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyInstanceAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyInstanceAttributeRequest method.
- // req, resp := client.ModifyInstanceAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyInstanceAttributeRequest(input *ModifyInstanceAttributeInput) (req *request.Request, output *ModifyInstanceAttributeOutput) {
- op := &request.Operation{
- Name: opModifyInstanceAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyInstanceAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifyInstanceAttributeOutput{}
- req.Data = output
- return
- }
- // Modifies the specified attribute of the specified instance. You can specify
- // only one attribute at a time.
- //
- // To modify some attributes, the instance must be stopped. For more information,
- // see Modifying Attributes of a Stopped Instance (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_ChangingAttributesWhileInstanceStopped.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) ModifyInstanceAttribute(input *ModifyInstanceAttributeInput) (*ModifyInstanceAttributeOutput, error) {
- req, out := c.ModifyInstanceAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyInstancePlacement = "ModifyInstancePlacement"
- // ModifyInstancePlacementRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyInstancePlacement operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyInstancePlacement method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyInstancePlacementRequest method.
- // req, resp := client.ModifyInstancePlacementRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyInstancePlacementRequest(input *ModifyInstancePlacementInput) (req *request.Request, output *ModifyInstancePlacementOutput) {
- op := &request.Operation{
- Name: opModifyInstancePlacement,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyInstancePlacementInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ModifyInstancePlacementOutput{}
- req.Data = output
- return
- }
- // Set the instance affinity value for a specific stopped instance and modify
- // the instance tenancy setting.
- //
- // Instance affinity is disabled by default. When instance affinity is host
- // and it is not associated with a specific Dedicated host, the next time it
- // is launched it will automatically be associated with the host it lands on.
- // This relationship will persist if the instance is stopped/started, or rebooted.
- //
- // You can modify the host ID associated with a stopped instance. If a stopped
- // instance has a new host ID association, the instance will target that host
- // when restarted.
- //
- // You can modify the tenancy of a stopped instance with a tenancy of host
- // or dedicated.
- //
- // Affinity, hostID, and tenancy are not required parameters, but at least
- // one of them must be specified in the request. Affinity and tenancy can be
- // modified in the same request, but tenancy can only be modified on instances
- // that are stopped.
- func (c *EC2) ModifyInstancePlacement(input *ModifyInstancePlacementInput) (*ModifyInstancePlacementOutput, error) {
- req, out := c.ModifyInstancePlacementRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyNetworkInterfaceAttribute = "ModifyNetworkInterfaceAttribute"
- // ModifyNetworkInterfaceAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyNetworkInterfaceAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyNetworkInterfaceAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyNetworkInterfaceAttributeRequest method.
- // req, resp := client.ModifyNetworkInterfaceAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyNetworkInterfaceAttributeRequest(input *ModifyNetworkInterfaceAttributeInput) (req *request.Request, output *ModifyNetworkInterfaceAttributeOutput) {
- op := &request.Operation{
- Name: opModifyNetworkInterfaceAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyNetworkInterfaceAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifyNetworkInterfaceAttributeOutput{}
- req.Data = output
- return
- }
- // Modifies the specified network interface attribute. You can specify only
- // one attribute at a time.
- func (c *EC2) ModifyNetworkInterfaceAttribute(input *ModifyNetworkInterfaceAttributeInput) (*ModifyNetworkInterfaceAttributeOutput, error) {
- req, out := c.ModifyNetworkInterfaceAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyReservedInstances = "ModifyReservedInstances"
- // ModifyReservedInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyReservedInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyReservedInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyReservedInstancesRequest method.
- // req, resp := client.ModifyReservedInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyReservedInstancesRequest(input *ModifyReservedInstancesInput) (req *request.Request, output *ModifyReservedInstancesOutput) {
- op := &request.Operation{
- Name: opModifyReservedInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyReservedInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ModifyReservedInstancesOutput{}
- req.Data = output
- return
- }
- // Modifies the Availability Zone, instance count, instance type, or network
- // platform (EC2-Classic or EC2-VPC) of your Reserved Instances. The Reserved
- // Instances to be modified must be identical, except for Availability Zone,
- // network platform, and instance type.
- //
- // For more information, see Modifying Reserved Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ri-modifying.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) ModifyReservedInstances(input *ModifyReservedInstancesInput) (*ModifyReservedInstancesOutput, error) {
- req, out := c.ModifyReservedInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifySnapshotAttribute = "ModifySnapshotAttribute"
- // ModifySnapshotAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ModifySnapshotAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifySnapshotAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifySnapshotAttributeRequest method.
- // req, resp := client.ModifySnapshotAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifySnapshotAttributeRequest(input *ModifySnapshotAttributeInput) (req *request.Request, output *ModifySnapshotAttributeOutput) {
- op := &request.Operation{
- Name: opModifySnapshotAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifySnapshotAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifySnapshotAttributeOutput{}
- req.Data = output
- return
- }
- // Adds or removes permission settings for the specified snapshot. You may add
- // or remove specified AWS account IDs from a snapshot's list of create volume
- // permissions, but you cannot do both in a single API call. If you need to
- // both add and remove account IDs for a snapshot, you must use multiple API
- // calls.
- //
- // Encrypted snapshots and snapshots with AWS Marketplace product codes cannot
- // be made public. Snapshots encrypted with your default CMK cannot be shared
- // with other accounts.
- //
- // For more information on modifying snapshot permissions, see Sharing Snapshots
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-modifying-snapshot-permissions.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) ModifySnapshotAttribute(input *ModifySnapshotAttributeInput) (*ModifySnapshotAttributeOutput, error) {
- req, out := c.ModifySnapshotAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifySpotFleetRequest = "ModifySpotFleetRequest"
- // ModifySpotFleetRequestRequest generates a "aws/request.Request" representing the
- // client's request for the ModifySpotFleetRequest operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifySpotFleetRequest method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifySpotFleetRequestRequest method.
- // req, resp := client.ModifySpotFleetRequestRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifySpotFleetRequestRequest(input *ModifySpotFleetRequestInput) (req *request.Request, output *ModifySpotFleetRequestOutput) {
- op := &request.Operation{
- Name: opModifySpotFleetRequest,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifySpotFleetRequestInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ModifySpotFleetRequestOutput{}
- req.Data = output
- return
- }
- // Modifies the specified Spot fleet request.
- //
- // While the Spot fleet request is being modified, it is in the modifying state.
- //
- // To scale up your Spot fleet, increase its target capacity. The Spot fleet
- // launches the additional Spot instances according to the allocation strategy
- // for the Spot fleet request. If the allocation strategy is lowestPrice, the
- // Spot fleet launches instances using the Spot pool with the lowest price.
- // If the allocation strategy is diversified, the Spot fleet distributes the
- // instances across the Spot pools.
- //
- // To scale down your Spot fleet, decrease its target capacity. First, the
- // Spot fleet cancels any open bids that exceed the new target capacity. You
- // can request that the Spot fleet terminate Spot instances until the size of
- // the fleet no longer exceeds the new target capacity. If the allocation strategy
- // is lowestPrice, the Spot fleet terminates the instances with the highest
- // price per unit. If the allocation strategy is diversified, the Spot fleet
- // terminates instances across the Spot pools. Alternatively, you can request
- // that the Spot fleet keep the fleet at its current size, but not replace any
- // Spot instances that are interrupted or that you terminate manually.
- func (c *EC2) ModifySpotFleetRequest(input *ModifySpotFleetRequestInput) (*ModifySpotFleetRequestOutput, error) {
- req, out := c.ModifySpotFleetRequestRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifySubnetAttribute = "ModifySubnetAttribute"
- // ModifySubnetAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ModifySubnetAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifySubnetAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifySubnetAttributeRequest method.
- // req, resp := client.ModifySubnetAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifySubnetAttributeRequest(input *ModifySubnetAttributeInput) (req *request.Request, output *ModifySubnetAttributeOutput) {
- op := &request.Operation{
- Name: opModifySubnetAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifySubnetAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifySubnetAttributeOutput{}
- req.Data = output
- return
- }
- // Modifies a subnet attribute.
- func (c *EC2) ModifySubnetAttribute(input *ModifySubnetAttributeInput) (*ModifySubnetAttributeOutput, error) {
- req, out := c.ModifySubnetAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyVolumeAttribute = "ModifyVolumeAttribute"
- // ModifyVolumeAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyVolumeAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyVolumeAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyVolumeAttributeRequest method.
- // req, resp := client.ModifyVolumeAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyVolumeAttributeRequest(input *ModifyVolumeAttributeInput) (req *request.Request, output *ModifyVolumeAttributeOutput) {
- op := &request.Operation{
- Name: opModifyVolumeAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyVolumeAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifyVolumeAttributeOutput{}
- req.Data = output
- return
- }
- // Modifies a volume attribute.
- //
- // By default, all I/O operations for the volume are suspended when the data
- // on the volume is determined to be potentially inconsistent, to prevent undetectable,
- // latent data corruption. The I/O access to the volume can be resumed by first
- // enabling I/O access and then checking the data consistency on your volume.
- //
- // You can change the default behavior to resume I/O operations. We recommend
- // that you change this only for boot volumes or for volumes that are stateless
- // or disposable.
- func (c *EC2) ModifyVolumeAttribute(input *ModifyVolumeAttributeInput) (*ModifyVolumeAttributeOutput, error) {
- req, out := c.ModifyVolumeAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyVpcAttribute = "ModifyVpcAttribute"
- // ModifyVpcAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyVpcAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyVpcAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyVpcAttributeRequest method.
- // req, resp := client.ModifyVpcAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyVpcAttributeRequest(input *ModifyVpcAttributeInput) (req *request.Request, output *ModifyVpcAttributeOutput) {
- op := &request.Operation{
- Name: opModifyVpcAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyVpcAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ModifyVpcAttributeOutput{}
- req.Data = output
- return
- }
- // Modifies the specified attribute of the specified VPC.
- func (c *EC2) ModifyVpcAttribute(input *ModifyVpcAttributeInput) (*ModifyVpcAttributeOutput, error) {
- req, out := c.ModifyVpcAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyVpcEndpoint = "ModifyVpcEndpoint"
- // ModifyVpcEndpointRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyVpcEndpoint operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyVpcEndpoint method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyVpcEndpointRequest method.
- // req, resp := client.ModifyVpcEndpointRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyVpcEndpointRequest(input *ModifyVpcEndpointInput) (req *request.Request, output *ModifyVpcEndpointOutput) {
- op := &request.Operation{
- Name: opModifyVpcEndpoint,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyVpcEndpointInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ModifyVpcEndpointOutput{}
- req.Data = output
- return
- }
- // Modifies attributes of a specified VPC endpoint. You can modify the policy
- // associated with the endpoint, and you can add and remove route tables associated
- // with the endpoint.
- func (c *EC2) ModifyVpcEndpoint(input *ModifyVpcEndpointInput) (*ModifyVpcEndpointOutput, error) {
- req, out := c.ModifyVpcEndpointRequest(input)
- err := req.Send()
- return out, err
- }
- const opModifyVpcPeeringConnectionOptions = "ModifyVpcPeeringConnectionOptions"
- // ModifyVpcPeeringConnectionOptionsRequest generates a "aws/request.Request" representing the
- // client's request for the ModifyVpcPeeringConnectionOptions operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ModifyVpcPeeringConnectionOptions method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ModifyVpcPeeringConnectionOptionsRequest method.
- // req, resp := client.ModifyVpcPeeringConnectionOptionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ModifyVpcPeeringConnectionOptionsRequest(input *ModifyVpcPeeringConnectionOptionsInput) (req *request.Request, output *ModifyVpcPeeringConnectionOptionsOutput) {
- op := &request.Operation{
- Name: opModifyVpcPeeringConnectionOptions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ModifyVpcPeeringConnectionOptionsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ModifyVpcPeeringConnectionOptionsOutput{}
- req.Data = output
- return
- }
- // Modifies the VPC peering connection options on one side of a VPC peering
- // connection. You can do the following:
- //
- // Enable/disable communication over the peering connection between an EC2-Classic
- // instance that's linked to your VPC (using ClassicLink) and instances in the
- // peer VPC.
- //
- // Enable/disable communication over the peering connection between instances
- // in your VPC and an EC2-Classic instance that's linked to the peer VPC.
- //
- // Enable/disable a local VPC to resolve public DNS hostnames to private
- // IP addresses when queried from instances in the peer VPC.
- //
- // If the peered VPCs are in different accounts, each owner must initiate
- // a separate request to modify the peering connection options, depending on
- // whether their VPC was the requester or accepter for the VPC peering connection.
- // If the peered VPCs are in the same account, you can modify the requester
- // and accepter options in the same request. To confirm which VPC is the accepter
- // and requester for a VPC peering connection, use the DescribeVpcPeeringConnections
- // command.
- func (c *EC2) ModifyVpcPeeringConnectionOptions(input *ModifyVpcPeeringConnectionOptionsInput) (*ModifyVpcPeeringConnectionOptionsOutput, error) {
- req, out := c.ModifyVpcPeeringConnectionOptionsRequest(input)
- err := req.Send()
- return out, err
- }
- const opMonitorInstances = "MonitorInstances"
- // MonitorInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the MonitorInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the MonitorInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the MonitorInstancesRequest method.
- // req, resp := client.MonitorInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) MonitorInstancesRequest(input *MonitorInstancesInput) (req *request.Request, output *MonitorInstancesOutput) {
- op := &request.Operation{
- Name: opMonitorInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &MonitorInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &MonitorInstancesOutput{}
- req.Data = output
- return
- }
- // Enables monitoring for a running instance. For more information about monitoring
- // instances, see Monitoring Your Instances and Volumes (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-cloudwatch.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) MonitorInstances(input *MonitorInstancesInput) (*MonitorInstancesOutput, error) {
- req, out := c.MonitorInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opMoveAddressToVpc = "MoveAddressToVpc"
- // MoveAddressToVpcRequest generates a "aws/request.Request" representing the
- // client's request for the MoveAddressToVpc operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the MoveAddressToVpc method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the MoveAddressToVpcRequest method.
- // req, resp := client.MoveAddressToVpcRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) MoveAddressToVpcRequest(input *MoveAddressToVpcInput) (req *request.Request, output *MoveAddressToVpcOutput) {
- op := &request.Operation{
- Name: opMoveAddressToVpc,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &MoveAddressToVpcInput{}
- }
- req = c.newRequest(op, input, output)
- output = &MoveAddressToVpcOutput{}
- req.Data = output
- return
- }
- // Moves an Elastic IP address from the EC2-Classic platform to the EC2-VPC
- // platform. The Elastic IP address must be allocated to your account for more
- // than 24 hours, and it must not be associated with an instance. After the
- // Elastic IP address is moved, it is no longer available for use in the EC2-Classic
- // platform, unless you move it back using the RestoreAddressToClassic request.
- // You cannot move an Elastic IP address that was originally allocated for use
- // in the EC2-VPC platform to the EC2-Classic platform.
- func (c *EC2) MoveAddressToVpc(input *MoveAddressToVpcInput) (*MoveAddressToVpcOutput, error) {
- req, out := c.MoveAddressToVpcRequest(input)
- err := req.Send()
- return out, err
- }
- const opPurchaseReservedInstancesOffering = "PurchaseReservedInstancesOffering"
- // PurchaseReservedInstancesOfferingRequest generates a "aws/request.Request" representing the
- // client's request for the PurchaseReservedInstancesOffering operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the PurchaseReservedInstancesOffering method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the PurchaseReservedInstancesOfferingRequest method.
- // req, resp := client.PurchaseReservedInstancesOfferingRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) PurchaseReservedInstancesOfferingRequest(input *PurchaseReservedInstancesOfferingInput) (req *request.Request, output *PurchaseReservedInstancesOfferingOutput) {
- op := &request.Operation{
- Name: opPurchaseReservedInstancesOffering,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &PurchaseReservedInstancesOfferingInput{}
- }
- req = c.newRequest(op, input, output)
- output = &PurchaseReservedInstancesOfferingOutput{}
- req.Data = output
- return
- }
- // Purchases a Reserved Instance for use with your account. With Reserved Instances,
- // you obtain a capacity reservation for a certain instance configuration over
- // a specified period of time and pay a lower hourly rate compared to On-Demand
- // instance pricing.
- //
- // Use DescribeReservedInstancesOfferings to get a list of Reserved Instance
- // offerings that match your specifications. After you've purchased a Reserved
- // Instance, you can check for your new Reserved Instance with DescribeReservedInstances.
- //
- // For more information, see Reserved Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/concepts-on-demand-reserved-instances.html)
- // and Reserved Instance Marketplace (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ri-market-general.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) PurchaseReservedInstancesOffering(input *PurchaseReservedInstancesOfferingInput) (*PurchaseReservedInstancesOfferingOutput, error) {
- req, out := c.PurchaseReservedInstancesOfferingRequest(input)
- err := req.Send()
- return out, err
- }
- const opPurchaseScheduledInstances = "PurchaseScheduledInstances"
- // PurchaseScheduledInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the PurchaseScheduledInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the PurchaseScheduledInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the PurchaseScheduledInstancesRequest method.
- // req, resp := client.PurchaseScheduledInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) PurchaseScheduledInstancesRequest(input *PurchaseScheduledInstancesInput) (req *request.Request, output *PurchaseScheduledInstancesOutput) {
- op := &request.Operation{
- Name: opPurchaseScheduledInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &PurchaseScheduledInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &PurchaseScheduledInstancesOutput{}
- req.Data = output
- return
- }
- // Purchases one or more Scheduled Instances with the specified schedule.
- //
- // Scheduled Instances enable you to purchase Amazon EC2 compute capacity by
- // the hour for a one-year term. Before you can purchase a Scheduled Instance,
- // you must call DescribeScheduledInstanceAvailability to check for available
- // schedules and obtain a purchase token. After you purchase a Scheduled Instance,
- // you must call RunScheduledInstances during each scheduled time period.
- //
- // After you purchase a Scheduled Instance, you can't cancel, modify, or resell
- // your purchase.
- func (c *EC2) PurchaseScheduledInstances(input *PurchaseScheduledInstancesInput) (*PurchaseScheduledInstancesOutput, error) {
- req, out := c.PurchaseScheduledInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opRebootInstances = "RebootInstances"
- // RebootInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the RebootInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RebootInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RebootInstancesRequest method.
- // req, resp := client.RebootInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RebootInstancesRequest(input *RebootInstancesInput) (req *request.Request, output *RebootInstancesOutput) {
- op := &request.Operation{
- Name: opRebootInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RebootInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &RebootInstancesOutput{}
- req.Data = output
- return
- }
- // Requests a reboot of one or more instances. This operation is asynchronous;
- // it only queues a request to reboot the specified instances. The operation
- // succeeds if the instances are valid and belong to you. Requests to reboot
- // terminated instances are ignored.
- //
- // If an instance does not cleanly shut down within four minutes, Amazon EC2
- // performs a hard reboot.
- //
- // For more information about troubleshooting, see Getting Console Output and
- // Rebooting Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instance-console.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) RebootInstances(input *RebootInstancesInput) (*RebootInstancesOutput, error) {
- req, out := c.RebootInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opRegisterImage = "RegisterImage"
- // RegisterImageRequest generates a "aws/request.Request" representing the
- // client's request for the RegisterImage operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RegisterImage method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RegisterImageRequest method.
- // req, resp := client.RegisterImageRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RegisterImageRequest(input *RegisterImageInput) (req *request.Request, output *RegisterImageOutput) {
- op := &request.Operation{
- Name: opRegisterImage,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RegisterImageInput{}
- }
- req = c.newRequest(op, input, output)
- output = &RegisterImageOutput{}
- req.Data = output
- return
- }
- // Registers an AMI. When you're creating an AMI, this is the final step you
- // must complete before you can launch an instance from the AMI. For more information
- // about creating AMIs, see Creating Your Own AMIs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/creating-an-ami.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // For Amazon EBS-backed instances, CreateImage creates and registers the
- // AMI in a single request, so you don't have to register the AMI yourself.
- //
- // You can also use RegisterImage to create an Amazon EBS-backed Linux AMI
- // from a snapshot of a root device volume. For more information, see Launching
- // an Instance from a Snapshot (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_LaunchingInstanceFromSnapshot.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Some Linux distributions, such as Red Hat Enterprise Linux (RHEL) and SUSE
- // Linux Enterprise Server (SLES), use the EC2 billingProduct code associated
- // with an AMI to verify subscription status for package updates. Creating an
- // AMI from an EBS snapshot does not maintain this billing code, and subsequent
- // instances launched from such an AMI will not be able to connect to package
- // update infrastructure.
- //
- // Similarly, although you can create a Windows AMI from a snapshot, you can't
- // successfully launch an instance from the AMI.
- //
- // To create Windows AMIs or to create AMIs for Linux operating systems that
- // must retain AMI billing codes to work properly, see CreateImage.
- //
- // If needed, you can deregister an AMI at any time. Any modifications you
- // make to an AMI backed by an instance store volume invalidates its registration.
- // If you make changes to an image, deregister the previous image and register
- // the new image.
- //
- // You can't register an image where a secondary (non-root) snapshot has AWS
- // Marketplace product codes.
- func (c *EC2) RegisterImage(input *RegisterImageInput) (*RegisterImageOutput, error) {
- req, out := c.RegisterImageRequest(input)
- err := req.Send()
- return out, err
- }
- const opRejectVpcPeeringConnection = "RejectVpcPeeringConnection"
- // RejectVpcPeeringConnectionRequest generates a "aws/request.Request" representing the
- // client's request for the RejectVpcPeeringConnection operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RejectVpcPeeringConnection method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RejectVpcPeeringConnectionRequest method.
- // req, resp := client.RejectVpcPeeringConnectionRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RejectVpcPeeringConnectionRequest(input *RejectVpcPeeringConnectionInput) (req *request.Request, output *RejectVpcPeeringConnectionOutput) {
- op := &request.Operation{
- Name: opRejectVpcPeeringConnection,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RejectVpcPeeringConnectionInput{}
- }
- req = c.newRequest(op, input, output)
- output = &RejectVpcPeeringConnectionOutput{}
- req.Data = output
- return
- }
- // Rejects a VPC peering connection request. The VPC peering connection must
- // be in the pending-acceptance state. Use the DescribeVpcPeeringConnections
- // request to view your outstanding VPC peering connection requests. To delete
- // an active VPC peering connection, or to delete a VPC peering connection request
- // that you initiated, use DeleteVpcPeeringConnection.
- func (c *EC2) RejectVpcPeeringConnection(input *RejectVpcPeeringConnectionInput) (*RejectVpcPeeringConnectionOutput, error) {
- req, out := c.RejectVpcPeeringConnectionRequest(input)
- err := req.Send()
- return out, err
- }
- const opReleaseAddress = "ReleaseAddress"
- // ReleaseAddressRequest generates a "aws/request.Request" representing the
- // client's request for the ReleaseAddress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ReleaseAddress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ReleaseAddressRequest method.
- // req, resp := client.ReleaseAddressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ReleaseAddressRequest(input *ReleaseAddressInput) (req *request.Request, output *ReleaseAddressOutput) {
- op := &request.Operation{
- Name: opReleaseAddress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ReleaseAddressInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ReleaseAddressOutput{}
- req.Data = output
- return
- }
- // Releases the specified Elastic IP address.
- //
- // After releasing an Elastic IP address, it is released to the IP address
- // pool and might be unavailable to you. Be sure to update your DNS records
- // and any servers or devices that communicate with the address. If you attempt
- // to release an Elastic IP address that you already released, you'll get an
- // AuthFailure error if the address is already allocated to another AWS account.
- //
- // [EC2-Classic, default VPC] Releasing an Elastic IP address automatically
- // disassociates it from any instance that it's associated with. To disassociate
- // an Elastic IP address without releasing it, use DisassociateAddress.
- //
- // [Nondefault VPC] You must use DisassociateAddress to disassociate the Elastic
- // IP address before you try to release it. Otherwise, Amazon EC2 returns an
- // error (InvalidIPAddress.InUse).
- func (c *EC2) ReleaseAddress(input *ReleaseAddressInput) (*ReleaseAddressOutput, error) {
- req, out := c.ReleaseAddressRequest(input)
- err := req.Send()
- return out, err
- }
- const opReleaseHosts = "ReleaseHosts"
- // ReleaseHostsRequest generates a "aws/request.Request" representing the
- // client's request for the ReleaseHosts operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ReleaseHosts method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ReleaseHostsRequest method.
- // req, resp := client.ReleaseHostsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ReleaseHostsRequest(input *ReleaseHostsInput) (req *request.Request, output *ReleaseHostsOutput) {
- op := &request.Operation{
- Name: opReleaseHosts,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ReleaseHostsInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ReleaseHostsOutput{}
- req.Data = output
- return
- }
- // When you no longer want to use a Dedicated host it can be released. On-Demand
- // billing is stopped and the host goes into released state. The host ID of
- // Dedicated hosts that have been released can no longer be specified in another
- // request, e.g., ModifyHosts. You must stop or terminate all instances on a
- // host before it can be released.
- //
- // When Dedicated hosts are released, it make take some time for them to stop
- // counting toward your limit and you may receive capacity errors when trying
- // to allocate new Dedicated hosts. Try waiting a few minutes, and then try
- // again.
- //
- // Released hosts will still appear in a DescribeHosts response.
- func (c *EC2) ReleaseHosts(input *ReleaseHostsInput) (*ReleaseHostsOutput, error) {
- req, out := c.ReleaseHostsRequest(input)
- err := req.Send()
- return out, err
- }
- const opReplaceNetworkAclAssociation = "ReplaceNetworkAclAssociation"
- // ReplaceNetworkAclAssociationRequest generates a "aws/request.Request" representing the
- // client's request for the ReplaceNetworkAclAssociation operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ReplaceNetworkAclAssociation method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ReplaceNetworkAclAssociationRequest method.
- // req, resp := client.ReplaceNetworkAclAssociationRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ReplaceNetworkAclAssociationRequest(input *ReplaceNetworkAclAssociationInput) (req *request.Request, output *ReplaceNetworkAclAssociationOutput) {
- op := &request.Operation{
- Name: opReplaceNetworkAclAssociation,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ReplaceNetworkAclAssociationInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ReplaceNetworkAclAssociationOutput{}
- req.Data = output
- return
- }
- // Changes which network ACL a subnet is associated with. By default when you
- // create a subnet, it's automatically associated with the default network ACL.
- // For more information about network ACLs, see Network ACLs (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_ACLs.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) ReplaceNetworkAclAssociation(input *ReplaceNetworkAclAssociationInput) (*ReplaceNetworkAclAssociationOutput, error) {
- req, out := c.ReplaceNetworkAclAssociationRequest(input)
- err := req.Send()
- return out, err
- }
- const opReplaceNetworkAclEntry = "ReplaceNetworkAclEntry"
- // ReplaceNetworkAclEntryRequest generates a "aws/request.Request" representing the
- // client's request for the ReplaceNetworkAclEntry operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ReplaceNetworkAclEntry method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ReplaceNetworkAclEntryRequest method.
- // req, resp := client.ReplaceNetworkAclEntryRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ReplaceNetworkAclEntryRequest(input *ReplaceNetworkAclEntryInput) (req *request.Request, output *ReplaceNetworkAclEntryOutput) {
- op := &request.Operation{
- Name: opReplaceNetworkAclEntry,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ReplaceNetworkAclEntryInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ReplaceNetworkAclEntryOutput{}
- req.Data = output
- return
- }
- // Replaces an entry (rule) in a network ACL. For more information about network
- // ACLs, see Network ACLs (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_ACLs.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) ReplaceNetworkAclEntry(input *ReplaceNetworkAclEntryInput) (*ReplaceNetworkAclEntryOutput, error) {
- req, out := c.ReplaceNetworkAclEntryRequest(input)
- err := req.Send()
- return out, err
- }
- const opReplaceRoute = "ReplaceRoute"
- // ReplaceRouteRequest generates a "aws/request.Request" representing the
- // client's request for the ReplaceRoute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ReplaceRoute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ReplaceRouteRequest method.
- // req, resp := client.ReplaceRouteRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ReplaceRouteRequest(input *ReplaceRouteInput) (req *request.Request, output *ReplaceRouteOutput) {
- op := &request.Operation{
- Name: opReplaceRoute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ReplaceRouteInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ReplaceRouteOutput{}
- req.Data = output
- return
- }
- // Replaces an existing route within a route table in a VPC. You must provide
- // only one of the following: Internet gateway or virtual private gateway, NAT
- // instance, NAT gateway, VPC peering connection, or network interface.
- //
- // For more information about route tables, see Route Tables (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Route_Tables.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) ReplaceRoute(input *ReplaceRouteInput) (*ReplaceRouteOutput, error) {
- req, out := c.ReplaceRouteRequest(input)
- err := req.Send()
- return out, err
- }
- const opReplaceRouteTableAssociation = "ReplaceRouteTableAssociation"
- // ReplaceRouteTableAssociationRequest generates a "aws/request.Request" representing the
- // client's request for the ReplaceRouteTableAssociation operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ReplaceRouteTableAssociation method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ReplaceRouteTableAssociationRequest method.
- // req, resp := client.ReplaceRouteTableAssociationRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ReplaceRouteTableAssociationRequest(input *ReplaceRouteTableAssociationInput) (req *request.Request, output *ReplaceRouteTableAssociationOutput) {
- op := &request.Operation{
- Name: opReplaceRouteTableAssociation,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ReplaceRouteTableAssociationInput{}
- }
- req = c.newRequest(op, input, output)
- output = &ReplaceRouteTableAssociationOutput{}
- req.Data = output
- return
- }
- // Changes the route table associated with a given subnet in a VPC. After the
- // operation completes, the subnet uses the routes in the new route table it's
- // associated with. For more information about route tables, see Route Tables
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Route_Tables.html)
- // in the Amazon Virtual Private Cloud User Guide.
- //
- // You can also use ReplaceRouteTableAssociation to change which table is the
- // main route table in the VPC. You just specify the main route table's association
- // ID and the route table to be the new main route table.
- func (c *EC2) ReplaceRouteTableAssociation(input *ReplaceRouteTableAssociationInput) (*ReplaceRouteTableAssociationOutput, error) {
- req, out := c.ReplaceRouteTableAssociationRequest(input)
- err := req.Send()
- return out, err
- }
- const opReportInstanceStatus = "ReportInstanceStatus"
- // ReportInstanceStatusRequest generates a "aws/request.Request" representing the
- // client's request for the ReportInstanceStatus operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ReportInstanceStatus method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ReportInstanceStatusRequest method.
- // req, resp := client.ReportInstanceStatusRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ReportInstanceStatusRequest(input *ReportInstanceStatusInput) (req *request.Request, output *ReportInstanceStatusOutput) {
- op := &request.Operation{
- Name: opReportInstanceStatus,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ReportInstanceStatusInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ReportInstanceStatusOutput{}
- req.Data = output
- return
- }
- // Submits feedback about the status of an instance. The instance must be in
- // the running state. If your experience with the instance differs from the
- // instance status returned by DescribeInstanceStatus, use ReportInstanceStatus
- // to report your experience with the instance. Amazon EC2 collects this information
- // to improve the accuracy of status checks.
- //
- // Use of this action does not change the value returned by DescribeInstanceStatus.
- func (c *EC2) ReportInstanceStatus(input *ReportInstanceStatusInput) (*ReportInstanceStatusOutput, error) {
- req, out := c.ReportInstanceStatusRequest(input)
- err := req.Send()
- return out, err
- }
- const opRequestSpotFleet = "RequestSpotFleet"
- // RequestSpotFleetRequest generates a "aws/request.Request" representing the
- // client's request for the RequestSpotFleet operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RequestSpotFleet method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RequestSpotFleetRequest method.
- // req, resp := client.RequestSpotFleetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RequestSpotFleetRequest(input *RequestSpotFleetInput) (req *request.Request, output *RequestSpotFleetOutput) {
- op := &request.Operation{
- Name: opRequestSpotFleet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RequestSpotFleetInput{}
- }
- req = c.newRequest(op, input, output)
- output = &RequestSpotFleetOutput{}
- req.Data = output
- return
- }
- // Creates a Spot fleet request.
- //
- // You can submit a single request that includes multiple launch specifications
- // that vary by instance type, AMI, Availability Zone, or subnet.
- //
- // By default, the Spot fleet requests Spot instances in the Spot pool where
- // the price per unit is the lowest. Each launch specification can include its
- // own instance weighting that reflects the value of the instance type to your
- // application workload.
- //
- // Alternatively, you can specify that the Spot fleet distribute the target
- // capacity across the Spot pools included in its launch specifications. By
- // ensuring that the Spot instances in your Spot fleet are in different Spot
- // pools, you can improve the availability of your fleet.
- //
- // For more information, see Spot Fleet Requests (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-fleet-requests.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) RequestSpotFleet(input *RequestSpotFleetInput) (*RequestSpotFleetOutput, error) {
- req, out := c.RequestSpotFleetRequest(input)
- err := req.Send()
- return out, err
- }
- const opRequestSpotInstances = "RequestSpotInstances"
- // RequestSpotInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the RequestSpotInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RequestSpotInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RequestSpotInstancesRequest method.
- // req, resp := client.RequestSpotInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RequestSpotInstancesRequest(input *RequestSpotInstancesInput) (req *request.Request, output *RequestSpotInstancesOutput) {
- op := &request.Operation{
- Name: opRequestSpotInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RequestSpotInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &RequestSpotInstancesOutput{}
- req.Data = output
- return
- }
- // Creates a Spot instance request. Spot instances are instances that Amazon
- // EC2 launches when the bid price that you specify exceeds the current Spot
- // price. Amazon EC2 periodically sets the Spot price based on available Spot
- // Instance capacity and current Spot instance requests. For more information,
- // see Spot Instance Requests (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-requests.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) RequestSpotInstances(input *RequestSpotInstancesInput) (*RequestSpotInstancesOutput, error) {
- req, out := c.RequestSpotInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opResetImageAttribute = "ResetImageAttribute"
- // ResetImageAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ResetImageAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ResetImageAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ResetImageAttributeRequest method.
- // req, resp := client.ResetImageAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ResetImageAttributeRequest(input *ResetImageAttributeInput) (req *request.Request, output *ResetImageAttributeOutput) {
- op := &request.Operation{
- Name: opResetImageAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ResetImageAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ResetImageAttributeOutput{}
- req.Data = output
- return
- }
- // Resets an attribute of an AMI to its default value.
- //
- // The productCodes attribute can't be reset.
- func (c *EC2) ResetImageAttribute(input *ResetImageAttributeInput) (*ResetImageAttributeOutput, error) {
- req, out := c.ResetImageAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opResetInstanceAttribute = "ResetInstanceAttribute"
- // ResetInstanceAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ResetInstanceAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ResetInstanceAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ResetInstanceAttributeRequest method.
- // req, resp := client.ResetInstanceAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ResetInstanceAttributeRequest(input *ResetInstanceAttributeInput) (req *request.Request, output *ResetInstanceAttributeOutput) {
- op := &request.Operation{
- Name: opResetInstanceAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ResetInstanceAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ResetInstanceAttributeOutput{}
- req.Data = output
- return
- }
- // Resets an attribute of an instance to its default value. To reset the kernel
- // or ramdisk, the instance must be in a stopped state. To reset the sourceDestCheck,
- // the instance can be either running or stopped.
- //
- // The sourceDestCheck attribute controls whether source/destination checking
- // is enabled. The default value is true, which means checking is enabled. This
- // value must be false for a NAT instance to perform NAT. For more information,
- // see NAT Instances (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_NAT_Instance.html)
- // in the Amazon Virtual Private Cloud User Guide.
- func (c *EC2) ResetInstanceAttribute(input *ResetInstanceAttributeInput) (*ResetInstanceAttributeOutput, error) {
- req, out := c.ResetInstanceAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opResetNetworkInterfaceAttribute = "ResetNetworkInterfaceAttribute"
- // ResetNetworkInterfaceAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ResetNetworkInterfaceAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ResetNetworkInterfaceAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ResetNetworkInterfaceAttributeRequest method.
- // req, resp := client.ResetNetworkInterfaceAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ResetNetworkInterfaceAttributeRequest(input *ResetNetworkInterfaceAttributeInput) (req *request.Request, output *ResetNetworkInterfaceAttributeOutput) {
- op := &request.Operation{
- Name: opResetNetworkInterfaceAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ResetNetworkInterfaceAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ResetNetworkInterfaceAttributeOutput{}
- req.Data = output
- return
- }
- // Resets a network interface attribute. You can specify only one attribute
- // at a time.
- func (c *EC2) ResetNetworkInterfaceAttribute(input *ResetNetworkInterfaceAttributeInput) (*ResetNetworkInterfaceAttributeOutput, error) {
- req, out := c.ResetNetworkInterfaceAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opResetSnapshotAttribute = "ResetSnapshotAttribute"
- // ResetSnapshotAttributeRequest generates a "aws/request.Request" representing the
- // client's request for the ResetSnapshotAttribute operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the ResetSnapshotAttribute method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the ResetSnapshotAttributeRequest method.
- // req, resp := client.ResetSnapshotAttributeRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) ResetSnapshotAttributeRequest(input *ResetSnapshotAttributeInput) (req *request.Request, output *ResetSnapshotAttributeOutput) {
- op := &request.Operation{
- Name: opResetSnapshotAttribute,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ResetSnapshotAttributeInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &ResetSnapshotAttributeOutput{}
- req.Data = output
- return
- }
- // Resets permission settings for the specified snapshot.
- //
- // For more information on modifying snapshot permissions, see Sharing Snapshots
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-modifying-snapshot-permissions.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) ResetSnapshotAttribute(input *ResetSnapshotAttributeInput) (*ResetSnapshotAttributeOutput, error) {
- req, out := c.ResetSnapshotAttributeRequest(input)
- err := req.Send()
- return out, err
- }
- const opRestoreAddressToClassic = "RestoreAddressToClassic"
- // RestoreAddressToClassicRequest generates a "aws/request.Request" representing the
- // client's request for the RestoreAddressToClassic operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RestoreAddressToClassic method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RestoreAddressToClassicRequest method.
- // req, resp := client.RestoreAddressToClassicRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RestoreAddressToClassicRequest(input *RestoreAddressToClassicInput) (req *request.Request, output *RestoreAddressToClassicOutput) {
- op := &request.Operation{
- Name: opRestoreAddressToClassic,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RestoreAddressToClassicInput{}
- }
- req = c.newRequest(op, input, output)
- output = &RestoreAddressToClassicOutput{}
- req.Data = output
- return
- }
- // Restores an Elastic IP address that was previously moved to the EC2-VPC platform
- // back to the EC2-Classic platform. You cannot move an Elastic IP address that
- // was originally allocated for use in EC2-VPC. The Elastic IP address must
- // not be associated with an instance or network interface.
- func (c *EC2) RestoreAddressToClassic(input *RestoreAddressToClassicInput) (*RestoreAddressToClassicOutput, error) {
- req, out := c.RestoreAddressToClassicRequest(input)
- err := req.Send()
- return out, err
- }
- const opRevokeSecurityGroupEgress = "RevokeSecurityGroupEgress"
- // RevokeSecurityGroupEgressRequest generates a "aws/request.Request" representing the
- // client's request for the RevokeSecurityGroupEgress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RevokeSecurityGroupEgress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RevokeSecurityGroupEgressRequest method.
- // req, resp := client.RevokeSecurityGroupEgressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RevokeSecurityGroupEgressRequest(input *RevokeSecurityGroupEgressInput) (req *request.Request, output *RevokeSecurityGroupEgressOutput) {
- op := &request.Operation{
- Name: opRevokeSecurityGroupEgress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RevokeSecurityGroupEgressInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &RevokeSecurityGroupEgressOutput{}
- req.Data = output
- return
- }
- // [EC2-VPC only] Removes one or more egress rules from a security group for
- // EC2-VPC. This action doesn't apply to security groups for use in EC2-Classic.
- // The values that you specify in the revoke request (for example, ports) must
- // match the existing rule's values for the rule to be revoked.
- //
- // Each rule consists of the protocol and the CIDR range or source security
- // group. For the TCP and UDP protocols, you must also specify the destination
- // port or range of ports. For the ICMP protocol, you must also specify the
- // ICMP type and code.
- //
- // Rule changes are propagated to instances within the security group as quickly
- // as possible. However, a small delay might occur.
- func (c *EC2) RevokeSecurityGroupEgress(input *RevokeSecurityGroupEgressInput) (*RevokeSecurityGroupEgressOutput, error) {
- req, out := c.RevokeSecurityGroupEgressRequest(input)
- err := req.Send()
- return out, err
- }
- const opRevokeSecurityGroupIngress = "RevokeSecurityGroupIngress"
- // RevokeSecurityGroupIngressRequest generates a "aws/request.Request" representing the
- // client's request for the RevokeSecurityGroupIngress operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RevokeSecurityGroupIngress method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RevokeSecurityGroupIngressRequest method.
- // req, resp := client.RevokeSecurityGroupIngressRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RevokeSecurityGroupIngressRequest(input *RevokeSecurityGroupIngressInput) (req *request.Request, output *RevokeSecurityGroupIngressOutput) {
- op := &request.Operation{
- Name: opRevokeSecurityGroupIngress,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RevokeSecurityGroupIngressInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &RevokeSecurityGroupIngressOutput{}
- req.Data = output
- return
- }
- // Removes one or more ingress rules from a security group. The values that
- // you specify in the revoke request (for example, ports) must match the existing
- // rule's values for the rule to be removed.
- //
- // Each rule consists of the protocol and the CIDR range or source security
- // group. For the TCP and UDP protocols, you must also specify the destination
- // port or range of ports. For the ICMP protocol, you must also specify the
- // ICMP type and code.
- //
- // Rule changes are propagated to instances within the security group as quickly
- // as possible. However, a small delay might occur.
- func (c *EC2) RevokeSecurityGroupIngress(input *RevokeSecurityGroupIngressInput) (*RevokeSecurityGroupIngressOutput, error) {
- req, out := c.RevokeSecurityGroupIngressRequest(input)
- err := req.Send()
- return out, err
- }
- const opRunInstances = "RunInstances"
- // RunInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the RunInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RunInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RunInstancesRequest method.
- // req, resp := client.RunInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RunInstancesRequest(input *RunInstancesInput) (req *request.Request, output *Reservation) {
- op := &request.Operation{
- Name: opRunInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RunInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &Reservation{}
- req.Data = output
- return
- }
- // Launches the specified number of instances using an AMI for which you have
- // permissions.
- //
- // When you launch an instance, it enters the pending state. After the instance
- // is ready for you, it enters the running state. To check the state of your
- // instance, call DescribeInstances.
- //
- // To ensure faster instance launches, break up large requests into smaller
- // batches. For example, create five separate launch requests for 100 instances
- // each instead of one launch request for 500 instances.
- //
- // To tag your instance, ensure that it is running as CreateTags requires a
- // resource ID. For more information about tagging, see Tagging Your Amazon
- // EC2 Resources (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html).
- //
- // If you don't specify a security group when launching an instance, Amazon
- // EC2 uses the default security group. For more information, see Security Groups
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-network-security.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // [EC2-VPC only accounts] If you don't specify a subnet in the request, we
- // choose a default subnet from your default VPC for you.
- //
- // [EC2-Classic accounts] If you're launching into EC2-Classic and you don't
- // specify an Availability Zone, we choose one for you.
- //
- // Linux instances have access to the public key of the key pair at boot. You
- // can use this key to provide secure access to the instance. Amazon EC2 public
- // images use this feature to provide secure access without passwords. For more
- // information, see Key Pairs (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-key-pairs.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // You can provide optional user data when launching an instance. For more
- // information, see Instance Metadata (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/AESDG-chapter-instancedata.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // If any of the AMIs have a product code attached for which the user has not
- // subscribed, RunInstances fails.
- //
- // Some instance types can only be launched into a VPC. If you do not have
- // a default VPC, or if you do not specify a subnet ID in the request, RunInstances
- // fails. For more information, see Instance Types Available Only in a VPC (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-vpc.html#vpc-only-instance-types).
- //
- // For more information about troubleshooting, see What To Do If An Instance
- // Immediately Terminates (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_InstanceStraightToTerminated.html),
- // and Troubleshooting Connecting to Your Instance (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/TroubleshootingInstancesConnecting.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) RunInstances(input *RunInstancesInput) (*Reservation, error) {
- req, out := c.RunInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opRunScheduledInstances = "RunScheduledInstances"
- // RunScheduledInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the RunScheduledInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the RunScheduledInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the RunScheduledInstancesRequest method.
- // req, resp := client.RunScheduledInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) RunScheduledInstancesRequest(input *RunScheduledInstancesInput) (req *request.Request, output *RunScheduledInstancesOutput) {
- op := &request.Operation{
- Name: opRunScheduledInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &RunScheduledInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &RunScheduledInstancesOutput{}
- req.Data = output
- return
- }
- // Launches the specified Scheduled Instances.
- //
- // Before you can launch a Scheduled Instance, you must purchase it and obtain
- // an identifier using PurchaseScheduledInstances.
- //
- // You must launch a Scheduled Instance during its scheduled time period. You
- // can't stop or reboot a Scheduled Instance, but you can terminate it as needed.
- // If you terminate a Scheduled Instance before the current scheduled time period
- // ends, you can launch it again after a few minutes. For more information,
- // see Scheduled Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-scheduled-instances.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) RunScheduledInstances(input *RunScheduledInstancesInput) (*RunScheduledInstancesOutput, error) {
- req, out := c.RunScheduledInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opStartInstances = "StartInstances"
- // StartInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the StartInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the StartInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the StartInstancesRequest method.
- // req, resp := client.StartInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) StartInstancesRequest(input *StartInstancesInput) (req *request.Request, output *StartInstancesOutput) {
- op := &request.Operation{
- Name: opStartInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &StartInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &StartInstancesOutput{}
- req.Data = output
- return
- }
- // Starts an Amazon EBS-backed AMI that you've previously stopped.
- //
- // Instances that use Amazon EBS volumes as their root devices can be quickly
- // stopped and started. When an instance is stopped, the compute resources are
- // released and you are not billed for hourly instance usage. However, your
- // root partition Amazon EBS volume remains, continues to persist your data,
- // and you are charged for Amazon EBS volume usage. You can restart your instance
- // at any time. Each time you transition an instance from stopped to started,
- // Amazon EC2 charges a full instance hour, even if transitions happen multiple
- // times within a single hour.
- //
- // Before stopping an instance, make sure it is in a state from which it can
- // be restarted. Stopping an instance does not preserve data stored in RAM.
- //
- // Performing this operation on an instance that uses an instance store as
- // its root device returns an error.
- //
- // For more information, see Stopping Instances (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Stop_Start.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) StartInstances(input *StartInstancesInput) (*StartInstancesOutput, error) {
- req, out := c.StartInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opStopInstances = "StopInstances"
- // StopInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the StopInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the StopInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the StopInstancesRequest method.
- // req, resp := client.StopInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) StopInstancesRequest(input *StopInstancesInput) (req *request.Request, output *StopInstancesOutput) {
- op := &request.Operation{
- Name: opStopInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &StopInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &StopInstancesOutput{}
- req.Data = output
- return
- }
- // Stops an Amazon EBS-backed instance.
- //
- // We don't charge hourly usage for a stopped instance, or data transfer fees;
- // however, your root partition Amazon EBS volume remains, continues to persist
- // your data, and you are charged for Amazon EBS volume usage. Each time you
- // transition an instance from stopped to started, Amazon EC2 charges a full
- // instance hour, even if transitions happen multiple times within a single
- // hour.
- //
- // You can't start or stop Spot instances, and you can't stop instance store-backed
- // instances.
- //
- // When you stop an instance, we shut it down. You can restart your instance
- // at any time. Before stopping an instance, make sure it is in a state from
- // which it can be restarted. Stopping an instance does not preserve data stored
- // in RAM.
- //
- // Stopping an instance is different to rebooting or terminating it. For example,
- // when you stop an instance, the root device and any other devices attached
- // to the instance persist. When you terminate an instance, the root device
- // and any other devices attached during the instance launch are automatically
- // deleted. For more information about the differences between rebooting, stopping,
- // and terminating instances, see Instance Lifecycle (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-instance-lifecycle.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // When you stop an instance, we attempt to shut it down forcibly after a short
- // while. If your instance appears stuck in the stopping state after a period
- // of time, there may be an issue with the underlying host computer. For more
- // information, see Troubleshooting Stopping Your Instance (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/TroubleshootingInstancesStopping.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) StopInstances(input *StopInstancesInput) (*StopInstancesOutput, error) {
- req, out := c.StopInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opTerminateInstances = "TerminateInstances"
- // TerminateInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the TerminateInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the TerminateInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the TerminateInstancesRequest method.
- // req, resp := client.TerminateInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) TerminateInstancesRequest(input *TerminateInstancesInput) (req *request.Request, output *TerminateInstancesOutput) {
- op := &request.Operation{
- Name: opTerminateInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &TerminateInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &TerminateInstancesOutput{}
- req.Data = output
- return
- }
- // Shuts down one or more instances. This operation is idempotent; if you terminate
- // an instance more than once, each call succeeds.
- //
- // Terminated instances remain visible after termination (for approximately
- // one hour).
- //
- // By default, Amazon EC2 deletes all EBS volumes that were attached when the
- // instance launched. Volumes attached after instance launch continue running.
- //
- // You can stop, start, and terminate EBS-backed instances. You can only terminate
- // instance store-backed instances. What happens to an instance differs if you
- // stop it or terminate it. For example, when you stop an instance, the root
- // device and any other devices attached to the instance persist. When you terminate
- // an instance, any attached EBS volumes with the DeleteOnTermination block
- // device mapping parameter set to true are automatically deleted. For more
- // information about the differences between stopping and terminating instances,
- // see Instance Lifecycle (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-instance-lifecycle.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // For more information about troubleshooting, see Troubleshooting Terminating
- // Your Instance (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/TroubleshootingInstancesShuttingDown.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) TerminateInstances(input *TerminateInstancesInput) (*TerminateInstancesOutput, error) {
- req, out := c.TerminateInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- const opUnassignPrivateIpAddresses = "UnassignPrivateIpAddresses"
- // UnassignPrivateIpAddressesRequest generates a "aws/request.Request" representing the
- // client's request for the UnassignPrivateIpAddresses operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the UnassignPrivateIpAddresses method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the UnassignPrivateIpAddressesRequest method.
- // req, resp := client.UnassignPrivateIpAddressesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) UnassignPrivateIpAddressesRequest(input *UnassignPrivateIpAddressesInput) (req *request.Request, output *UnassignPrivateIpAddressesOutput) {
- op := &request.Operation{
- Name: opUnassignPrivateIpAddresses,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UnassignPrivateIpAddressesInput{}
- }
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Remove(ec2query.UnmarshalHandler)
- req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
- output = &UnassignPrivateIpAddressesOutput{}
- req.Data = output
- return
- }
- // Unassigns one or more secondary private IP addresses from a network interface.
- func (c *EC2) UnassignPrivateIpAddresses(input *UnassignPrivateIpAddressesInput) (*UnassignPrivateIpAddressesOutput, error) {
- req, out := c.UnassignPrivateIpAddressesRequest(input)
- err := req.Send()
- return out, err
- }
- const opUnmonitorInstances = "UnmonitorInstances"
- // UnmonitorInstancesRequest generates a "aws/request.Request" representing the
- // client's request for the UnmonitorInstances operation. The "output" return
- // value can be used to capture response data after the request's "Send" method
- // is called.
- //
- // Creating a request object using this method should be used when you want to inject
- // custom logic into the request's lifecycle using a custom handler, or if you want to
- // access properties on the request object before or after sending the request. If
- // you just want the service response, call the UnmonitorInstances method directly
- // instead.
- //
- // Note: You must call the "Send" method on the returned request object in order
- // to execute the request.
- //
- // // Example sending a request using the UnmonitorInstancesRequest method.
- // req, resp := client.UnmonitorInstancesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- func (c *EC2) UnmonitorInstancesRequest(input *UnmonitorInstancesInput) (req *request.Request, output *UnmonitorInstancesOutput) {
- op := &request.Operation{
- Name: opUnmonitorInstances,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UnmonitorInstancesInput{}
- }
- req = c.newRequest(op, input, output)
- output = &UnmonitorInstancesOutput{}
- req.Data = output
- return
- }
- // Disables monitoring for a running instance. For more information about monitoring
- // instances, see Monitoring Your Instances and Volumes (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-cloudwatch.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- func (c *EC2) UnmonitorInstances(input *UnmonitorInstancesInput) (*UnmonitorInstancesOutput, error) {
- req, out := c.UnmonitorInstancesRequest(input)
- err := req.Send()
- return out, err
- }
- // Contains the parameters for AcceptVpcPeeringConnection.
- type AcceptVpcPeeringConnectionInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string"`
- }
- // String returns the string representation
- func (s AcceptVpcPeeringConnectionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AcceptVpcPeeringConnectionInput) GoString() string {
- return s.String()
- }
- // Contains the output of AcceptVpcPeeringConnection.
- type AcceptVpcPeeringConnectionOutput struct {
- _ struct{} `type:"structure"`
- // Information about the VPC peering connection.
- VpcPeeringConnection *VpcPeeringConnection `locationName:"vpcPeeringConnection" type:"structure"`
- }
- // String returns the string representation
- func (s AcceptVpcPeeringConnectionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AcceptVpcPeeringConnectionOutput) GoString() string {
- return s.String()
- }
- // Describes an account attribute.
- type AccountAttribute struct {
- _ struct{} `type:"structure"`
- // The name of the account attribute.
- AttributeName *string `locationName:"attributeName" type:"string"`
- // One or more values for the account attribute.
- AttributeValues []*AccountAttributeValue `locationName:"attributeValueSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s AccountAttribute) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AccountAttribute) GoString() string {
- return s.String()
- }
- // Describes a value of an account attribute.
- type AccountAttributeValue struct {
- _ struct{} `type:"structure"`
- // The value of the attribute.
- AttributeValue *string `locationName:"attributeValue" type:"string"`
- }
- // String returns the string representation
- func (s AccountAttributeValue) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AccountAttributeValue) GoString() string {
- return s.String()
- }
- // Describes a running instance in a Spot fleet.
- type ActiveInstance struct {
- _ struct{} `type:"structure"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The instance type.
- InstanceType *string `locationName:"instanceType" type:"string"`
- // The ID of the Spot instance request.
- SpotInstanceRequestId *string `locationName:"spotInstanceRequestId" type:"string"`
- }
- // String returns the string representation
- func (s ActiveInstance) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ActiveInstance) GoString() string {
- return s.String()
- }
- // Describes an Elastic IP address.
- type Address struct {
- _ struct{} `type:"structure"`
- // The ID representing the allocation of the address for use with EC2-VPC.
- AllocationId *string `locationName:"allocationId" type:"string"`
- // The ID representing the association of the address with an instance in a
- // VPC.
- AssociationId *string `locationName:"associationId" type:"string"`
- // Indicates whether this Elastic IP address is for use with instances in EC2-Classic
- // (standard) or instances in a VPC (vpc).
- Domain *string `locationName:"domain" type:"string" enum:"DomainType"`
- // The ID of the instance that the address is associated with (if any).
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // The ID of the AWS account that owns the network interface.
- NetworkInterfaceOwnerId *string `locationName:"networkInterfaceOwnerId" type:"string"`
- // The private IP address associated with the Elastic IP address.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // The Elastic IP address.
- PublicIp *string `locationName:"publicIp" type:"string"`
- }
- // String returns the string representation
- func (s Address) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Address) GoString() string {
- return s.String()
- }
- // Contains the parameters for AllocateAddress.
- type AllocateAddressInput struct {
- _ struct{} `type:"structure"`
- // Set to vpc to allocate the address for use with instances in a VPC.
- //
- // Default: The address is for use with instances in EC2-Classic.
- Domain *string `type:"string" enum:"DomainType"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s AllocateAddressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AllocateAddressInput) GoString() string {
- return s.String()
- }
- // Contains the output of AllocateAddress.
- type AllocateAddressOutput struct {
- _ struct{} `type:"structure"`
- // [EC2-VPC] The ID that AWS assigns to represent the allocation of the Elastic
- // IP address for use with instances in a VPC.
- AllocationId *string `locationName:"allocationId" type:"string"`
- // Indicates whether this Elastic IP address is for use with instances in EC2-Classic
- // (standard) or instances in a VPC (vpc).
- Domain *string `locationName:"domain" type:"string" enum:"DomainType"`
- // The Elastic IP address.
- PublicIp *string `locationName:"publicIp" type:"string"`
- }
- // String returns the string representation
- func (s AllocateAddressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AllocateAddressOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AllocateHosts.
- type AllocateHostsInput struct {
- _ struct{} `type:"structure"`
- // This is enabled by default. This property allows instances to be automatically
- // placed onto available Dedicated hosts, when you are launching instances without
- // specifying a host ID.
- //
- // Default: Enabled
- AutoPlacement *string `locationName:"autoPlacement" type:"string" enum:"AutoPlacement"`
- // The Availability Zone for the Dedicated hosts.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string" required:"true"`
- // Unique, case-sensitive identifier you provide to ensure idempotency of the
- // request. For more information, see How to Ensure Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- ClientToken *string `locationName:"clientToken" type:"string"`
- // Specify the instance type that you want your Dedicated hosts to be configured
- // for. When you specify the instance type, that is the only instance type that
- // you can launch onto that host.
- InstanceType *string `locationName:"instanceType" type:"string" required:"true"`
- // The number of Dedicated hosts you want to allocate to your account with these
- // parameters.
- Quantity *int64 `locationName:"quantity" type:"integer" required:"true"`
- }
- // String returns the string representation
- func (s AllocateHostsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AllocateHostsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AllocateHostsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AllocateHostsInput"}
- if s.AvailabilityZone == nil {
- invalidParams.Add(request.NewErrParamRequired("AvailabilityZone"))
- }
- if s.InstanceType == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceType"))
- }
- if s.Quantity == nil {
- invalidParams.Add(request.NewErrParamRequired("Quantity"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of AllocateHosts.
- type AllocateHostsOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the allocated Dedicated host. This is used when you want to launch
- // an instance onto a specific host.
- HostIds []*string `locationName:"hostIdSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s AllocateHostsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AllocateHostsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AssignPrivateIpAddresses.
- type AssignPrivateIpAddressesInput struct {
- _ struct{} `type:"structure"`
- // Indicates whether to allow an IP address that is already assigned to another
- // network interface or instance to be reassigned to the specified network interface.
- AllowReassignment *bool `locationName:"allowReassignment" type:"boolean"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string" required:"true"`
- // One or more IP addresses to be assigned as a secondary private IP address
- // to the network interface. You can't specify this parameter when also specifying
- // a number of secondary IP addresses.
- //
- // If you don't specify an IP address, Amazon EC2 automatically selects an
- // IP address within the subnet range.
- PrivateIpAddresses []*string `locationName:"privateIpAddress" locationNameList:"PrivateIpAddress" type:"list"`
- // The number of secondary IP addresses to assign to the network interface.
- // You can't specify this parameter when also specifying private IP addresses.
- SecondaryPrivateIpAddressCount *int64 `locationName:"secondaryPrivateIpAddressCount" type:"integer"`
- }
- // String returns the string representation
- func (s AssignPrivateIpAddressesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssignPrivateIpAddressesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AssignPrivateIpAddressesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AssignPrivateIpAddressesInput"}
- if s.NetworkInterfaceId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkInterfaceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type AssignPrivateIpAddressesOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s AssignPrivateIpAddressesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssignPrivateIpAddressesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AssociateAddress.
- type AssociateAddressInput struct {
- _ struct{} `type:"structure"`
- // [EC2-VPC] The allocation ID. This is required for EC2-VPC.
- AllocationId *string `type:"string"`
- // [EC2-VPC] For a VPC in an EC2-Classic account, specify true to allow an Elastic
- // IP address that is already associated with an instance or network interface
- // to be reassociated with the specified instance or network interface. Otherwise,
- // the operation fails. In a VPC in an EC2-VPC-only account, reassociation is
- // automatic, therefore you can specify false to ensure the operation fails
- // if the Elastic IP address is already associated with another resource.
- AllowReassociation *bool `locationName:"allowReassociation" type:"boolean"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance. This is required for EC2-Classic. For EC2-VPC, you
- // can specify either the instance ID or the network interface ID, but not both.
- // The operation fails if you specify an instance ID unless exactly one network
- // interface is attached.
- InstanceId *string `type:"string"`
- // [EC2-VPC] The ID of the network interface. If the instance has more than
- // one network interface, you must specify a network interface ID.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // [EC2-VPC] The primary or secondary private IP address to associate with the
- // Elastic IP address. If no private IP address is specified, the Elastic IP
- // address is associated with the primary private IP address.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // The Elastic IP address. This is required for EC2-Classic.
- PublicIp *string `type:"string"`
- }
- // String returns the string representation
- func (s AssociateAddressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssociateAddressInput) GoString() string {
- return s.String()
- }
- // Contains the output of AssociateAddress.
- type AssociateAddressOutput struct {
- _ struct{} `type:"structure"`
- // [EC2-VPC] The ID that represents the association of the Elastic IP address
- // with an instance.
- AssociationId *string `locationName:"associationId" type:"string"`
- }
- // String returns the string representation
- func (s AssociateAddressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssociateAddressOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AssociateDhcpOptions.
- type AssociateDhcpOptionsInput struct {
- _ struct{} `type:"structure"`
- // The ID of the DHCP options set, or default to associate no DHCP options with
- // the VPC.
- DhcpOptionsId *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s AssociateDhcpOptionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssociateDhcpOptionsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AssociateDhcpOptionsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AssociateDhcpOptionsInput"}
- if s.DhcpOptionsId == nil {
- invalidParams.Add(request.NewErrParamRequired("DhcpOptionsId"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type AssociateDhcpOptionsOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s AssociateDhcpOptionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssociateDhcpOptionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AssociateRouteTable.
- type AssociateRouteTableInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the route table.
- RouteTableId *string `locationName:"routeTableId" type:"string" required:"true"`
- // The ID of the subnet.
- SubnetId *string `locationName:"subnetId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s AssociateRouteTableInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssociateRouteTableInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AssociateRouteTableInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AssociateRouteTableInput"}
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if s.SubnetId == nil {
- invalidParams.Add(request.NewErrParamRequired("SubnetId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of AssociateRouteTable.
- type AssociateRouteTableOutput struct {
- _ struct{} `type:"structure"`
- // The route table association ID (needed to disassociate the route table).
- AssociationId *string `locationName:"associationId" type:"string"`
- }
- // String returns the string representation
- func (s AssociateRouteTableOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AssociateRouteTableOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AttachClassicLinkVpc.
- type AttachClassicLinkVpcInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of one or more of the VPC's security groups. You cannot specify security
- // groups from a different VPC.
- Groups []*string `locationName:"SecurityGroupId" locationNameList:"groupId" type:"list" required:"true"`
- // The ID of an EC2-Classic instance to link to the ClassicLink-enabled VPC.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- // The ID of a ClassicLink-enabled VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s AttachClassicLinkVpcInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachClassicLinkVpcInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AttachClassicLinkVpcInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AttachClassicLinkVpcInput"}
- if s.Groups == nil {
- invalidParams.Add(request.NewErrParamRequired("Groups"))
- }
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of AttachClassicLinkVpc.
- type AttachClassicLinkVpcOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s AttachClassicLinkVpcOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachClassicLinkVpcOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AttachInternetGateway.
- type AttachInternetGatewayInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the Internet gateway.
- InternetGatewayId *string `locationName:"internetGatewayId" type:"string" required:"true"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s AttachInternetGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachInternetGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AttachInternetGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AttachInternetGatewayInput"}
- if s.InternetGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("InternetGatewayId"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type AttachInternetGatewayOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s AttachInternetGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachInternetGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AttachNetworkInterface.
- type AttachNetworkInterfaceInput struct {
- _ struct{} `type:"structure"`
- // The index of the device for the network interface attachment.
- DeviceIndex *int64 `locationName:"deviceIndex" type:"integer" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s AttachNetworkInterfaceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachNetworkInterfaceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AttachNetworkInterfaceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AttachNetworkInterfaceInput"}
- if s.DeviceIndex == nil {
- invalidParams.Add(request.NewErrParamRequired("DeviceIndex"))
- }
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if s.NetworkInterfaceId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkInterfaceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of AttachNetworkInterface.
- type AttachNetworkInterfaceOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the network interface attachment.
- AttachmentId *string `locationName:"attachmentId" type:"string"`
- }
- // String returns the string representation
- func (s AttachNetworkInterfaceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachNetworkInterfaceOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AttachVolume.
- type AttachVolumeInput struct {
- _ struct{} `type:"structure"`
- // The device name to expose to the instance (for example, /dev/sdh or xvdh).
- Device *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance.
- InstanceId *string `type:"string" required:"true"`
- // The ID of the EBS volume. The volume and instance must be within the same
- // Availability Zone.
- VolumeId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s AttachVolumeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachVolumeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AttachVolumeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AttachVolumeInput"}
- if s.Device == nil {
- invalidParams.Add(request.NewErrParamRequired("Device"))
- }
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if s.VolumeId == nil {
- invalidParams.Add(request.NewErrParamRequired("VolumeId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the parameters for AttachVpnGateway.
- type AttachVpnGatewayInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `type:"string" required:"true"`
- // The ID of the virtual private gateway.
- VpnGatewayId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s AttachVpnGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachVpnGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AttachVpnGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AttachVpnGatewayInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if s.VpnGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpnGatewayId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of AttachVpnGateway.
- type AttachVpnGatewayOutput struct {
- _ struct{} `type:"structure"`
- // Information about the attachment.
- VpcAttachment *VpcAttachment `locationName:"attachment" type:"structure"`
- }
- // String returns the string representation
- func (s AttachVpnGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttachVpnGatewayOutput) GoString() string {
- return s.String()
- }
- // Describes a value for a resource attribute that is a Boolean value.
- type AttributeBooleanValue struct {
- _ struct{} `type:"structure"`
- // The attribute value. The valid values are true or false.
- Value *bool `locationName:"value" type:"boolean"`
- }
- // String returns the string representation
- func (s AttributeBooleanValue) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttributeBooleanValue) GoString() string {
- return s.String()
- }
- // Describes a value for a resource attribute that is a String.
- type AttributeValue struct {
- _ struct{} `type:"structure"`
- // The attribute value. Note that the value is case-sensitive.
- Value *string `locationName:"value" type:"string"`
- }
- // String returns the string representation
- func (s AttributeValue) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AttributeValue) GoString() string {
- return s.String()
- }
- // Contains the parameters for AuthorizeSecurityGroupEgress.
- type AuthorizeSecurityGroupEgressInput struct {
- _ struct{} `type:"structure"`
- // The CIDR IP address range. We recommend that you specify the CIDR range in
- // a set of IP permissions instead.
- CidrIp *string `locationName:"cidrIp" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The start of port range for the TCP and UDP protocols, or an ICMP type number.
- // We recommend that you specify the port range in a set of IP permissions instead.
- FromPort *int64 `locationName:"fromPort" type:"integer"`
- // The ID of the security group.
- GroupId *string `locationName:"groupId" type:"string" required:"true"`
- // A set of IP permissions. You can't specify a destination security group and
- // a CIDR IP address range.
- IpPermissions []*IpPermission `locationName:"ipPermissions" locationNameList:"item" type:"list"`
- // The IP protocol name or number. We recommend that you specify the protocol
- // in a set of IP permissions instead.
- IpProtocol *string `locationName:"ipProtocol" type:"string"`
- // The name of a destination security group. To authorize outbound access to
- // a destination security group, we recommend that you use a set of IP permissions
- // instead.
- SourceSecurityGroupName *string `locationName:"sourceSecurityGroupName" type:"string"`
- // The AWS account number for a destination security group. To authorize outbound
- // access to a destination security group, we recommend that you use a set of
- // IP permissions instead.
- SourceSecurityGroupOwnerId *string `locationName:"sourceSecurityGroupOwnerId" type:"string"`
- // The end of port range for the TCP and UDP protocols, or an ICMP type number.
- // We recommend that you specify the port range in a set of IP permissions instead.
- ToPort *int64 `locationName:"toPort" type:"integer"`
- }
- // String returns the string representation
- func (s AuthorizeSecurityGroupEgressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AuthorizeSecurityGroupEgressInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AuthorizeSecurityGroupEgressInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AuthorizeSecurityGroupEgressInput"}
- if s.GroupId == nil {
- invalidParams.Add(request.NewErrParamRequired("GroupId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type AuthorizeSecurityGroupEgressOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s AuthorizeSecurityGroupEgressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AuthorizeSecurityGroupEgressOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for AuthorizeSecurityGroupIngress.
- type AuthorizeSecurityGroupIngressInput struct {
- _ struct{} `type:"structure"`
- // The CIDR IP address range. You can't specify this parameter when specifying
- // a source security group.
- CidrIp *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The start of port range for the TCP and UDP protocols, or an ICMP type number.
- // For the ICMP type number, use -1 to specify all ICMP types.
- FromPort *int64 `type:"integer"`
- // The ID of the security group. Required for a nondefault VPC.
- GroupId *string `type:"string"`
- // [EC2-Classic, default VPC] The name of the security group.
- GroupName *string `type:"string"`
- // A set of IP permissions. Can be used to specify multiple rules in a single
- // command.
- IpPermissions []*IpPermission `locationNameList:"item" type:"list"`
- // The IP protocol name (tcp, udp, icmp) or number (see Protocol Numbers (http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xhtml)).
- // (VPC only) Use -1 to specify all traffic. If you specify -1, traffic on all
- // ports is allowed, regardless of any ports you specify.
- IpProtocol *string `type:"string"`
- // [EC2-Classic, default VPC] The name of the source security group. You can't
- // specify this parameter in combination with the following parameters: the
- // CIDR IP address range, the start of the port range, the IP protocol, and
- // the end of the port range. Creates rules that grant full ICMP, UDP, and TCP
- // access. To create a rule with a specific IP protocol and port range, use
- // a set of IP permissions instead. For EC2-VPC, the source security group must
- // be in the same VPC.
- SourceSecurityGroupName *string `type:"string"`
- // [EC2-Classic] The AWS account number for the source security group, if the
- // source security group is in a different account. You can't specify this parameter
- // in combination with the following parameters: the CIDR IP address range,
- // the IP protocol, the start of the port range, and the end of the port range.
- // Creates rules that grant full ICMP, UDP, and TCP access. To create a rule
- // with a specific IP protocol and port range, use a set of IP permissions instead.
- SourceSecurityGroupOwnerId *string `type:"string"`
- // The end of port range for the TCP and UDP protocols, or an ICMP code number.
- // For the ICMP code number, use -1 to specify all ICMP codes for the ICMP type.
- ToPort *int64 `type:"integer"`
- }
- // String returns the string representation
- func (s AuthorizeSecurityGroupIngressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AuthorizeSecurityGroupIngressInput) GoString() string {
- return s.String()
- }
- type AuthorizeSecurityGroupIngressOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s AuthorizeSecurityGroupIngressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AuthorizeSecurityGroupIngressOutput) GoString() string {
- return s.String()
- }
- // Describes an Availability Zone.
- type AvailabilityZone struct {
- _ struct{} `type:"structure"`
- // Any messages about the Availability Zone.
- Messages []*AvailabilityZoneMessage `locationName:"messageSet" locationNameList:"item" type:"list"`
- // The name of the region.
- RegionName *string `locationName:"regionName" type:"string"`
- // The state of the Availability Zone.
- State *string `locationName:"zoneState" type:"string" enum:"AvailabilityZoneState"`
- // The name of the Availability Zone.
- ZoneName *string `locationName:"zoneName" type:"string"`
- }
- // String returns the string representation
- func (s AvailabilityZone) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AvailabilityZone) GoString() string {
- return s.String()
- }
- // Describes a message about an Availability Zone.
- type AvailabilityZoneMessage struct {
- _ struct{} `type:"structure"`
- // The message about the Availability Zone.
- Message *string `locationName:"message" type:"string"`
- }
- // String returns the string representation
- func (s AvailabilityZoneMessage) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AvailabilityZoneMessage) GoString() string {
- return s.String()
- }
- // The capacity information for instances launched onto the Dedicated host.
- type AvailableCapacity struct {
- _ struct{} `type:"structure"`
- // The total number of instances that the Dedicated host supports.
- AvailableInstanceCapacity []*InstanceCapacity `locationName:"availableInstanceCapacity" locationNameList:"item" type:"list"`
- // The number of vCPUs available on the Dedicated host.
- AvailableVCpus *int64 `locationName:"availableVCpus" type:"integer"`
- }
- // String returns the string representation
- func (s AvailableCapacity) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s AvailableCapacity) GoString() string {
- return s.String()
- }
- type BlobAttributeValue struct {
- _ struct{} `type:"structure"`
- // Value is automatically base64 encoded/decoded by the SDK.
- Value []byte `locationName:"value" type:"blob"`
- }
- // String returns the string representation
- func (s BlobAttributeValue) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s BlobAttributeValue) GoString() string {
- return s.String()
- }
- // Describes a block device mapping.
- type BlockDeviceMapping struct {
- _ struct{} `type:"structure"`
- // The device name exposed to the instance (for example, /dev/sdh or xvdh).
- DeviceName *string `locationName:"deviceName" type:"string"`
- // Parameters used to automatically set up EBS volumes when the instance is
- // launched.
- Ebs *EbsBlockDevice `locationName:"ebs" type:"structure"`
- // Suppresses the specified device included in the block device mapping of the
- // AMI.
- NoDevice *string `locationName:"noDevice" type:"string"`
- // The virtual device name (ephemeralN). Instance store volumes are numbered
- // starting from 0. An instance type with 2 available instance store volumes
- // can specify mappings for ephemeral0 and ephemeral1.The number of available
- // instance store volumes depends on the instance type. After you connect to
- // the instance, you must mount the volume.
- //
- // Constraints: For M3 instances, you must specify instance store volumes in
- // the block device mapping for the instance. When you launch an M3 instance,
- // we ignore any instance store volumes specified in the block device mapping
- // for the AMI.
- VirtualName *string `locationName:"virtualName" type:"string"`
- }
- // String returns the string representation
- func (s BlockDeviceMapping) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s BlockDeviceMapping) GoString() string {
- return s.String()
- }
- // Contains the parameters for BundleInstance.
- type BundleInstanceInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance to bundle.
- //
- // Type: String
- //
- // Default: None
- //
- // Required: Yes
- InstanceId *string `type:"string" required:"true"`
- // The bucket in which to store the AMI. You can specify a bucket that you already
- // own or a new bucket that Amazon EC2 creates on your behalf. If you specify
- // a bucket that belongs to someone else, Amazon EC2 returns an error.
- Storage *Storage `type:"structure" required:"true"`
- }
- // String returns the string representation
- func (s BundleInstanceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s BundleInstanceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *BundleInstanceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "BundleInstanceInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if s.Storage == nil {
- invalidParams.Add(request.NewErrParamRequired("Storage"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of BundleInstance.
- type BundleInstanceOutput struct {
- _ struct{} `type:"structure"`
- // Information about the bundle task.
- BundleTask *BundleTask `locationName:"bundleInstanceTask" type:"structure"`
- }
- // String returns the string representation
- func (s BundleInstanceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s BundleInstanceOutput) GoString() string {
- return s.String()
- }
- // Describes a bundle task.
- type BundleTask struct {
- _ struct{} `type:"structure"`
- // The ID of the bundle task.
- BundleId *string `locationName:"bundleId" type:"string"`
- // If the task fails, a description of the error.
- BundleTaskError *BundleTaskError `locationName:"error" type:"structure"`
- // The ID of the instance associated with this bundle task.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The level of task completion, as a percent (for example, 20%).
- Progress *string `locationName:"progress" type:"string"`
- // The time this task started.
- StartTime *time.Time `locationName:"startTime" type:"timestamp" timestampFormat:"iso8601"`
- // The state of the task.
- State *string `locationName:"state" type:"string" enum:"BundleTaskState"`
- // The Amazon S3 storage locations.
- Storage *Storage `locationName:"storage" type:"structure"`
- // The time of the most recent update for the task.
- UpdateTime *time.Time `locationName:"updateTime" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s BundleTask) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s BundleTask) GoString() string {
- return s.String()
- }
- // Describes an error for BundleInstance.
- type BundleTaskError struct {
- _ struct{} `type:"structure"`
- // The error code.
- Code *string `locationName:"code" type:"string"`
- // The error message.
- Message *string `locationName:"message" type:"string"`
- }
- // String returns the string representation
- func (s BundleTaskError) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s BundleTaskError) GoString() string {
- return s.String()
- }
- // Contains the parameters for CancelBundleTask.
- type CancelBundleTaskInput struct {
- _ struct{} `type:"structure"`
- // The ID of the bundle task.
- BundleId *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s CancelBundleTaskInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelBundleTaskInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CancelBundleTaskInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CancelBundleTaskInput"}
- if s.BundleId == nil {
- invalidParams.Add(request.NewErrParamRequired("BundleId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CancelBundleTask.
- type CancelBundleTaskOutput struct {
- _ struct{} `type:"structure"`
- // Information about the bundle task.
- BundleTask *BundleTask `locationName:"bundleInstanceTask" type:"structure"`
- }
- // String returns the string representation
- func (s CancelBundleTaskOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelBundleTaskOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CancelConversionTask.
- type CancelConversionTaskInput struct {
- _ struct{} `type:"structure"`
- // The ID of the conversion task.
- ConversionTaskId *string `locationName:"conversionTaskId" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The reason for canceling the conversion task.
- ReasonMessage *string `locationName:"reasonMessage" type:"string"`
- }
- // String returns the string representation
- func (s CancelConversionTaskInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelConversionTaskInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CancelConversionTaskInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CancelConversionTaskInput"}
- if s.ConversionTaskId == nil {
- invalidParams.Add(request.NewErrParamRequired("ConversionTaskId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type CancelConversionTaskOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s CancelConversionTaskOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelConversionTaskOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CancelExportTask.
- type CancelExportTaskInput struct {
- _ struct{} `type:"structure"`
- // The ID of the export task. This is the ID returned by CreateInstanceExportTask.
- ExportTaskId *string `locationName:"exportTaskId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CancelExportTaskInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelExportTaskInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CancelExportTaskInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CancelExportTaskInput"}
- if s.ExportTaskId == nil {
- invalidParams.Add(request.NewErrParamRequired("ExportTaskId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type CancelExportTaskOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s CancelExportTaskOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelExportTaskOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CancelImportTask.
- type CancelImportTaskInput struct {
- _ struct{} `type:"structure"`
- // The reason for canceling the task.
- CancelReason *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The ID of the import image or import snapshot task to be canceled.
- ImportTaskId *string `type:"string"`
- }
- // String returns the string representation
- func (s CancelImportTaskInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelImportTaskInput) GoString() string {
- return s.String()
- }
- // Contains the output for CancelImportTask.
- type CancelImportTaskOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the task being canceled.
- ImportTaskId *string `locationName:"importTaskId" type:"string"`
- // The current state of the task being canceled.
- PreviousState *string `locationName:"previousState" type:"string"`
- // The current state of the task being canceled.
- State *string `locationName:"state" type:"string"`
- }
- // String returns the string representation
- func (s CancelImportTaskOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelImportTaskOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CancelReservedInstancesListing.
- type CancelReservedInstancesListingInput struct {
- _ struct{} `type:"structure"`
- // The ID of the Reserved Instance listing.
- ReservedInstancesListingId *string `locationName:"reservedInstancesListingId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CancelReservedInstancesListingInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelReservedInstancesListingInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CancelReservedInstancesListingInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CancelReservedInstancesListingInput"}
- if s.ReservedInstancesListingId == nil {
- invalidParams.Add(request.NewErrParamRequired("ReservedInstancesListingId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CancelReservedInstancesListing.
- type CancelReservedInstancesListingOutput struct {
- _ struct{} `type:"structure"`
- // The Reserved Instance listing.
- ReservedInstancesListings []*ReservedInstancesListing `locationName:"reservedInstancesListingsSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s CancelReservedInstancesListingOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelReservedInstancesListingOutput) GoString() string {
- return s.String()
- }
- // Describes a Spot fleet error.
- type CancelSpotFleetRequestsError struct {
- _ struct{} `type:"structure"`
- // The error code.
- Code *string `locationName:"code" type:"string" required:"true" enum:"CancelBatchErrorCode"`
- // The description for the error code.
- Message *string `locationName:"message" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CancelSpotFleetRequestsError) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelSpotFleetRequestsError) GoString() string {
- return s.String()
- }
- // Describes a Spot fleet request that was not successfully canceled.
- type CancelSpotFleetRequestsErrorItem struct {
- _ struct{} `type:"structure"`
- // The error.
- Error *CancelSpotFleetRequestsError `locationName:"error" type:"structure" required:"true"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CancelSpotFleetRequestsErrorItem) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelSpotFleetRequestsErrorItem) GoString() string {
- return s.String()
- }
- // Contains the parameters for CancelSpotFleetRequests.
- type CancelSpotFleetRequestsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The IDs of the Spot fleet requests.
- SpotFleetRequestIds []*string `locationName:"spotFleetRequestId" locationNameList:"item" type:"list" required:"true"`
- // Indicates whether to terminate instances for a Spot fleet request if it is
- // canceled successfully.
- TerminateInstances *bool `locationName:"terminateInstances" type:"boolean" required:"true"`
- }
- // String returns the string representation
- func (s CancelSpotFleetRequestsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelSpotFleetRequestsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CancelSpotFleetRequestsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CancelSpotFleetRequestsInput"}
- if s.SpotFleetRequestIds == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotFleetRequestIds"))
- }
- if s.TerminateInstances == nil {
- invalidParams.Add(request.NewErrParamRequired("TerminateInstances"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CancelSpotFleetRequests.
- type CancelSpotFleetRequestsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the Spot fleet requests that are successfully canceled.
- SuccessfulFleetRequests []*CancelSpotFleetRequestsSuccessItem `locationName:"successfulFleetRequestSet" locationNameList:"item" type:"list"`
- // Information about the Spot fleet requests that are not successfully canceled.
- UnsuccessfulFleetRequests []*CancelSpotFleetRequestsErrorItem `locationName:"unsuccessfulFleetRequestSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s CancelSpotFleetRequestsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelSpotFleetRequestsOutput) GoString() string {
- return s.String()
- }
- // Describes a Spot fleet request that was successfully canceled.
- type CancelSpotFleetRequestsSuccessItem struct {
- _ struct{} `type:"structure"`
- // The current state of the Spot fleet request.
- CurrentSpotFleetRequestState *string `locationName:"currentSpotFleetRequestState" type:"string" required:"true" enum:"BatchState"`
- // The previous state of the Spot fleet request.
- PreviousSpotFleetRequestState *string `locationName:"previousSpotFleetRequestState" type:"string" required:"true" enum:"BatchState"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CancelSpotFleetRequestsSuccessItem) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelSpotFleetRequestsSuccessItem) GoString() string {
- return s.String()
- }
- // Contains the parameters for CancelSpotInstanceRequests.
- type CancelSpotInstanceRequestsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more Spot instance request IDs.
- SpotInstanceRequestIds []*string `locationName:"SpotInstanceRequestId" locationNameList:"SpotInstanceRequestId" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s CancelSpotInstanceRequestsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelSpotInstanceRequestsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CancelSpotInstanceRequestsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CancelSpotInstanceRequestsInput"}
- if s.SpotInstanceRequestIds == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotInstanceRequestIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CancelSpotInstanceRequests.
- type CancelSpotInstanceRequestsOutput struct {
- _ struct{} `type:"structure"`
- // One or more Spot instance requests.
- CancelledSpotInstanceRequests []*CancelledSpotInstanceRequest `locationName:"spotInstanceRequestSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s CancelSpotInstanceRequestsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelSpotInstanceRequestsOutput) GoString() string {
- return s.String()
- }
- // Describes a request to cancel a Spot instance.
- type CancelledSpotInstanceRequest struct {
- _ struct{} `type:"structure"`
- // The ID of the Spot instance request.
- SpotInstanceRequestId *string `locationName:"spotInstanceRequestId" type:"string"`
- // The state of the Spot instance request.
- State *string `locationName:"state" type:"string" enum:"CancelSpotInstanceRequestState"`
- }
- // String returns the string representation
- func (s CancelledSpotInstanceRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CancelledSpotInstanceRequest) GoString() string {
- return s.String()
- }
- // Describes the ClassicLink DNS support status of a VPC.
- type ClassicLinkDnsSupport struct {
- _ struct{} `type:"structure"`
- // Indicates whether ClassicLink DNS support is enabled for the VPC.
- ClassicLinkDnsSupported *bool `locationName:"classicLinkDnsSupported" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s ClassicLinkDnsSupport) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ClassicLinkDnsSupport) GoString() string {
- return s.String()
- }
- // Describes a linked EC2-Classic instance.
- type ClassicLinkInstance struct {
- _ struct{} `type:"structure"`
- // A list of security groups.
- Groups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // Any tags assigned to the instance.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s ClassicLinkInstance) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ClassicLinkInstance) GoString() string {
- return s.String()
- }
- // Describes the client-specific data.
- type ClientData struct {
- _ struct{} `type:"structure"`
- // A user-defined comment about the disk upload.
- Comment *string `type:"string"`
- // The time that the disk upload ends.
- UploadEnd *time.Time `type:"timestamp" timestampFormat:"iso8601"`
- // The size of the uploaded disk image, in GiB.
- UploadSize *float64 `type:"double"`
- // The time that the disk upload starts.
- UploadStart *time.Time `type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s ClientData) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ClientData) GoString() string {
- return s.String()
- }
- // Contains the parameters for ConfirmProductInstance.
- type ConfirmProductInstanceInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance.
- InstanceId *string `type:"string" required:"true"`
- // The product code. This must be a product code that you own.
- ProductCode *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ConfirmProductInstanceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ConfirmProductInstanceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ConfirmProductInstanceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ConfirmProductInstanceInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if s.ProductCode == nil {
- invalidParams.Add(request.NewErrParamRequired("ProductCode"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ConfirmProductInstance.
- type ConfirmProductInstanceOutput struct {
- _ struct{} `type:"structure"`
- // The AWS account ID of the instance owner. This is only present if the product
- // code is attached to the instance.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // The return value of the request. Returns true if the specified product code
- // is owned by the requester and associated with the specified instance.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s ConfirmProductInstanceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ConfirmProductInstanceOutput) GoString() string {
- return s.String()
- }
- // Describes a conversion task.
- type ConversionTask struct {
- _ struct{} `type:"structure"`
- // The ID of the conversion task.
- ConversionTaskId *string `locationName:"conversionTaskId" type:"string" required:"true"`
- // The time when the task expires. If the upload isn't complete before the expiration
- // time, we automatically cancel the task.
- ExpirationTime *string `locationName:"expirationTime" type:"string"`
- // If the task is for importing an instance, this contains information about
- // the import instance task.
- ImportInstance *ImportInstanceTaskDetails `locationName:"importInstance" type:"structure"`
- // If the task is for importing a volume, this contains information about the
- // import volume task.
- ImportVolume *ImportVolumeTaskDetails `locationName:"importVolume" type:"structure"`
- // The state of the conversion task.
- State *string `locationName:"state" type:"string" required:"true" enum:"ConversionTaskState"`
- // The status message related to the conversion task.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- // Any tags assigned to the task.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s ConversionTask) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ConversionTask) GoString() string {
- return s.String()
- }
- // Contains the parameters for CopyImage.
- type CopyImageInput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier you provide to ensure idempotency of the
- // request. For more information, see How to Ensure Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- ClientToken *string `type:"string"`
- // A description for the new AMI in the destination region.
- Description *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Specifies whether the destination snapshots of the copied image should be
- // encrypted. The default CMK for EBS is used unless a non-default AWS Key Management
- // Service (AWS KMS) CMK is specified with KmsKeyId. For more information, see
- // Amazon EBS Encryption (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- Encrypted *bool `locationName:"encrypted" type:"boolean"`
- // The full ARN of the AWS Key Management Service (AWS KMS) CMK to use when
- // encrypting the snapshots of an image during a copy operation. This parameter
- // is only required if you want to use a non-default CMK; if this parameter
- // is not specified, the default CMK for EBS is used. The ARN contains the arn:aws:kms
- // namespace, followed by the region of the CMK, the AWS account ID of the CMK
- // owner, the key namespace, and then the CMK ID. For example, arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.
- // The specified CMK must exist in the region that the snapshot is being copied
- // to. If a KmsKeyId is specified, the Encrypted flag must also be set.
- KmsKeyId *string `locationName:"kmsKeyId" type:"string"`
- // The name of the new AMI in the destination region.
- Name *string `type:"string" required:"true"`
- // The ID of the AMI to copy.
- SourceImageId *string `type:"string" required:"true"`
- // The name of the region that contains the AMI to copy.
- SourceRegion *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CopyImageInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CopyImageInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CopyImageInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CopyImageInput"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.SourceImageId == nil {
- invalidParams.Add(request.NewErrParamRequired("SourceImageId"))
- }
- if s.SourceRegion == nil {
- invalidParams.Add(request.NewErrParamRequired("SourceRegion"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CopyImage.
- type CopyImageOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the new AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- }
- // String returns the string representation
- func (s CopyImageOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CopyImageOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CopySnapshot.
- type CopySnapshotInput struct {
- _ struct{} `type:"structure"`
- // A description for the EBS snapshot.
- Description *string `type:"string"`
- // The destination region to use in the PresignedUrl parameter of a snapshot
- // copy operation. This parameter is only valid for specifying the destination
- // region in a PresignedUrl parameter, where it is required.
- //
- // CopySnapshot sends the snapshot copy to the regional endpoint that you
- // send the HTTP request to, such as ec2.us-east-1.amazonaws.com (in the AWS
- // CLI, this is specified with the --region parameter or the default region
- // in your AWS configuration file).
- DestinationRegion *string `locationName:"destinationRegion" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Specifies whether the destination snapshot should be encrypted. You can encrypt
- // a copy of an unencrypted snapshot using this flag, but you cannot use it
- // to create an unencrypted copy from an encrypted snapshot. Your default CMK
- // for EBS is used unless a non-default AWS Key Management Service (AWS KMS)
- // CMK is specified with KmsKeyId. For more information, see Amazon EBS Encryption
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html) in
- // the Amazon Elastic Compute Cloud User Guide.
- Encrypted *bool `locationName:"encrypted" type:"boolean"`
- // The full ARN of the AWS Key Management Service (AWS KMS) CMK to use when
- // creating the snapshot copy. This parameter is only required if you want to
- // use a non-default CMK; if this parameter is not specified, the default CMK
- // for EBS is used. The ARN contains the arn:aws:kms namespace, followed by
- // the region of the CMK, the AWS account ID of the CMK owner, the key namespace,
- // and then the CMK ID. For example, arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.
- // The specified CMK must exist in the region that the snapshot is being copied
- // to. If a KmsKeyId is specified, the Encrypted flag must also be set.
- KmsKeyId *string `locationName:"kmsKeyId" type:"string"`
- // The pre-signed URL that facilitates copying an encrypted snapshot. This parameter
- // is only required when copying an encrypted snapshot with the Amazon EC2 Query
- // API; it is available as an optional parameter in all other cases. The PresignedUrl
- // should use the snapshot source endpoint, the CopySnapshot action, and include
- // the SourceRegion, SourceSnapshotId, and DestinationRegion parameters. The
- // PresignedUrl must be signed using AWS Signature Version 4. Because EBS snapshots
- // are stored in Amazon S3, the signing algorithm for this parameter uses the
- // same logic that is described in Authenticating Requests by Using Query Parameters
- // (AWS Signature Version 4) (http://docs.aws.amazon.com/AmazonS3/latest/API/sigv4-query-string-auth.html)
- // in the Amazon Simple Storage Service API Reference. An invalid or improperly
- // signed PresignedUrl will cause the copy operation to fail asynchronously,
- // and the snapshot will move to an error state.
- PresignedUrl *string `locationName:"presignedUrl" type:"string"`
- // The ID of the region that contains the snapshot to be copied.
- SourceRegion *string `type:"string" required:"true"`
- // The ID of the EBS snapshot to copy.
- SourceSnapshotId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CopySnapshotInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CopySnapshotInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CopySnapshotInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CopySnapshotInput"}
- if s.SourceRegion == nil {
- invalidParams.Add(request.NewErrParamRequired("SourceRegion"))
- }
- if s.SourceSnapshotId == nil {
- invalidParams.Add(request.NewErrParamRequired("SourceSnapshotId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CopySnapshot.
- type CopySnapshotOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the new snapshot.
- SnapshotId *string `locationName:"snapshotId" type:"string"`
- }
- // String returns the string representation
- func (s CopySnapshotOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CopySnapshotOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateCustomerGateway.
- type CreateCustomerGatewayInput struct {
- _ struct{} `type:"structure"`
- // For devices that support BGP, the customer gateway's BGP ASN.
- //
- // Default: 65000
- BgpAsn *int64 `type:"integer" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The Internet-routable IP address for the customer gateway's outside interface.
- // The address must be static.
- PublicIp *string `locationName:"IpAddress" type:"string" required:"true"`
- // The type of VPN connection that this customer gateway supports (ipsec.1).
- Type *string `type:"string" required:"true" enum:"GatewayType"`
- }
- // String returns the string representation
- func (s CreateCustomerGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateCustomerGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateCustomerGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateCustomerGatewayInput"}
- if s.BgpAsn == nil {
- invalidParams.Add(request.NewErrParamRequired("BgpAsn"))
- }
- if s.PublicIp == nil {
- invalidParams.Add(request.NewErrParamRequired("PublicIp"))
- }
- if s.Type == nil {
- invalidParams.Add(request.NewErrParamRequired("Type"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateCustomerGateway.
- type CreateCustomerGatewayOutput struct {
- _ struct{} `type:"structure"`
- // Information about the customer gateway.
- CustomerGateway *CustomerGateway `locationName:"customerGateway" type:"structure"`
- }
- // String returns the string representation
- func (s CreateCustomerGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateCustomerGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateDhcpOptions.
- type CreateDhcpOptionsInput struct {
- _ struct{} `type:"structure"`
- // A DHCP configuration option.
- DhcpConfigurations []*NewDhcpConfiguration `locationName:"dhcpConfiguration" locationNameList:"item" type:"list" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s CreateDhcpOptionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateDhcpOptionsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateDhcpOptionsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateDhcpOptionsInput"}
- if s.DhcpConfigurations == nil {
- invalidParams.Add(request.NewErrParamRequired("DhcpConfigurations"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateDhcpOptions.
- type CreateDhcpOptionsOutput struct {
- _ struct{} `type:"structure"`
- // A set of DHCP options.
- DhcpOptions *DhcpOptions `locationName:"dhcpOptions" type:"structure"`
- }
- // String returns the string representation
- func (s CreateDhcpOptionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateDhcpOptionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateFlowLogs.
- type CreateFlowLogsInput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier you provide to ensure the idempotency of
- // the request. For more information, see How to Ensure Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html).
- ClientToken *string `type:"string"`
- // The ARN for the IAM role that's used to post flow logs to a CloudWatch Logs
- // log group.
- DeliverLogsPermissionArn *string `type:"string" required:"true"`
- // The name of the CloudWatch log group.
- LogGroupName *string `type:"string" required:"true"`
- // One or more subnet, network interface, or VPC IDs.
- //
- // Constraints: Maximum of 1000 resources
- ResourceIds []*string `locationName:"ResourceId" locationNameList:"item" type:"list" required:"true"`
- // The type of resource on which to create the flow log.
- ResourceType *string `type:"string" required:"true" enum:"FlowLogsResourceType"`
- // The type of traffic to log.
- TrafficType *string `type:"string" required:"true" enum:"TrafficType"`
- }
- // String returns the string representation
- func (s CreateFlowLogsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateFlowLogsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateFlowLogsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateFlowLogsInput"}
- if s.DeliverLogsPermissionArn == nil {
- invalidParams.Add(request.NewErrParamRequired("DeliverLogsPermissionArn"))
- }
- if s.LogGroupName == nil {
- invalidParams.Add(request.NewErrParamRequired("LogGroupName"))
- }
- if s.ResourceIds == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceIds"))
- }
- if s.ResourceType == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceType"))
- }
- if s.TrafficType == nil {
- invalidParams.Add(request.NewErrParamRequired("TrafficType"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateFlowLogs.
- type CreateFlowLogsOutput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier you provide to ensure the idempotency of
- // the request.
- ClientToken *string `locationName:"clientToken" type:"string"`
- // The IDs of the flow logs.
- FlowLogIds []*string `locationName:"flowLogIdSet" locationNameList:"item" type:"list"`
- // Information about the flow logs that could not be created successfully.
- Unsuccessful []*UnsuccessfulItem `locationName:"unsuccessful" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s CreateFlowLogsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateFlowLogsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateImage.
- type CreateImageInput struct {
- _ struct{} `type:"structure"`
- // Information about one or more block device mappings.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"BlockDeviceMapping" type:"list"`
- // A description for the new image.
- Description *string `locationName:"description" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- // A name for the new image.
- //
- // Constraints: 3-128 alphanumeric characters, parentheses (()), square brackets
- // ([]), spaces ( ), periods (.), slashes (/), dashes (-), single quotes ('),
- // at-signs (@), or underscores(_)
- Name *string `locationName:"name" type:"string" required:"true"`
- // By default, Amazon EC2 attempts to shut down and reboot the instance before
- // creating the image. If the 'No Reboot' option is set, Amazon EC2 doesn't
- // shut down the instance before creating the image. When this option is used,
- // file system integrity on the created image can't be guaranteed.
- NoReboot *bool `locationName:"noReboot" type:"boolean"`
- }
- // String returns the string representation
- func (s CreateImageInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateImageInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateImageInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateImageInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateImage.
- type CreateImageOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the new AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- }
- // String returns the string representation
- func (s CreateImageOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateImageOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateInstanceExportTask.
- type CreateInstanceExportTaskInput struct {
- _ struct{} `type:"structure"`
- // A description for the conversion task or the resource being exported. The
- // maximum length is 255 bytes.
- Description *string `locationName:"description" type:"string"`
- // The format and location for an instance export task.
- ExportToS3Task *ExportToS3TaskSpecification `locationName:"exportToS3" type:"structure"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- // The target virtualization environment.
- TargetEnvironment *string `locationName:"targetEnvironment" type:"string" enum:"ExportEnvironment"`
- }
- // String returns the string representation
- func (s CreateInstanceExportTaskInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateInstanceExportTaskInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateInstanceExportTaskInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateInstanceExportTaskInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output for CreateInstanceExportTask.
- type CreateInstanceExportTaskOutput struct {
- _ struct{} `type:"structure"`
- // Information about the instance export task.
- ExportTask *ExportTask `locationName:"exportTask" type:"structure"`
- }
- // String returns the string representation
- func (s CreateInstanceExportTaskOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateInstanceExportTaskOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateInternetGateway.
- type CreateInternetGatewayInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s CreateInternetGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateInternetGatewayInput) GoString() string {
- return s.String()
- }
- // Contains the output of CreateInternetGateway.
- type CreateInternetGatewayOutput struct {
- _ struct{} `type:"structure"`
- // Information about the Internet gateway.
- InternetGateway *InternetGateway `locationName:"internetGateway" type:"structure"`
- }
- // String returns the string representation
- func (s CreateInternetGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateInternetGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateKeyPair.
- type CreateKeyPairInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // A unique name for the key pair.
- //
- // Constraints: Up to 255 ASCII characters
- KeyName *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateKeyPairInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateKeyPairInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateKeyPairInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateKeyPairInput"}
- if s.KeyName == nil {
- invalidParams.Add(request.NewErrParamRequired("KeyName"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a key pair.
- type CreateKeyPairOutput struct {
- _ struct{} `type:"structure"`
- // The SHA-1 digest of the DER encoded private key.
- KeyFingerprint *string `locationName:"keyFingerprint" type:"string"`
- // An unencrypted PEM encoded RSA private key.
- KeyMaterial *string `locationName:"keyMaterial" type:"string"`
- // The name of the key pair.
- KeyName *string `locationName:"keyName" type:"string"`
- }
- // String returns the string representation
- func (s CreateKeyPairOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateKeyPairOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateNatGateway.
- type CreateNatGatewayInput struct {
- _ struct{} `type:"structure"`
- // The allocation ID of an Elastic IP address to associate with the NAT gateway.
- // If the Elastic IP address is associated with another resource, you must first
- // disassociate it.
- AllocationId *string `type:"string" required:"true"`
- // Unique, case-sensitive identifier you provide to ensure the idempotency of
- // the request. For more information, see How to Ensure Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- //
- // Constraint: Maximum 64 ASCII characters.
- ClientToken *string `type:"string"`
- // The subnet in which to create the NAT gateway.
- SubnetId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateNatGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNatGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateNatGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateNatGatewayInput"}
- if s.AllocationId == nil {
- invalidParams.Add(request.NewErrParamRequired("AllocationId"))
- }
- if s.SubnetId == nil {
- invalidParams.Add(request.NewErrParamRequired("SubnetId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateNatGateway.
- type CreateNatGatewayOutput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier to ensure the idempotency of the request.
- // Only returned if a client token was provided in the request.
- ClientToken *string `locationName:"clientToken" type:"string"`
- // Information about the NAT gateway.
- NatGateway *NatGateway `locationName:"natGateway" type:"structure"`
- }
- // String returns the string representation
- func (s CreateNatGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNatGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateNetworkAclEntry.
- type CreateNetworkAclEntryInput struct {
- _ struct{} `type:"structure"`
- // The network range to allow or deny, in CIDR notation (for example 172.16.0.0/24).
- CidrBlock *string `locationName:"cidrBlock" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Indicates whether this is an egress rule (rule is applied to traffic leaving
- // the subnet).
- Egress *bool `locationName:"egress" type:"boolean" required:"true"`
- // ICMP protocol: The ICMP type and code. Required if specifying ICMP for the
- // protocol.
- IcmpTypeCode *IcmpTypeCode `locationName:"Icmp" type:"structure"`
- // The ID of the network ACL.
- NetworkAclId *string `locationName:"networkAclId" type:"string" required:"true"`
- // TCP or UDP protocols: The range of ports the rule applies to.
- PortRange *PortRange `locationName:"portRange" type:"structure"`
- // The protocol. A value of -1 means all protocols.
- Protocol *string `locationName:"protocol" type:"string" required:"true"`
- // Indicates whether to allow or deny the traffic that matches the rule.
- RuleAction *string `locationName:"ruleAction" type:"string" required:"true" enum:"RuleAction"`
- // The rule number for the entry (for example, 100). ACL entries are processed
- // in ascending order by rule number.
- //
- // Constraints: Positive integer from 1 to 32766. The range 32767 to 65535
- // is reserved for internal use.
- RuleNumber *int64 `locationName:"ruleNumber" type:"integer" required:"true"`
- }
- // String returns the string representation
- func (s CreateNetworkAclEntryInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNetworkAclEntryInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateNetworkAclEntryInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateNetworkAclEntryInput"}
- if s.CidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("CidrBlock"))
- }
- if s.Egress == nil {
- invalidParams.Add(request.NewErrParamRequired("Egress"))
- }
- if s.NetworkAclId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkAclId"))
- }
- if s.Protocol == nil {
- invalidParams.Add(request.NewErrParamRequired("Protocol"))
- }
- if s.RuleAction == nil {
- invalidParams.Add(request.NewErrParamRequired("RuleAction"))
- }
- if s.RuleNumber == nil {
- invalidParams.Add(request.NewErrParamRequired("RuleNumber"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type CreateNetworkAclEntryOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s CreateNetworkAclEntryOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNetworkAclEntryOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateNetworkAcl.
- type CreateNetworkAclInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateNetworkAclInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNetworkAclInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateNetworkAclInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateNetworkAclInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateNetworkAcl.
- type CreateNetworkAclOutput struct {
- _ struct{} `type:"structure"`
- // Information about the network ACL.
- NetworkAcl *NetworkAcl `locationName:"networkAcl" type:"structure"`
- }
- // String returns the string representation
- func (s CreateNetworkAclOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNetworkAclOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateNetworkInterface.
- type CreateNetworkInterfaceInput struct {
- _ struct{} `type:"structure"`
- // A description for the network interface.
- Description *string `locationName:"description" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The IDs of one or more security groups.
- Groups []*string `locationName:"SecurityGroupId" locationNameList:"SecurityGroupId" type:"list"`
- // The primary private IP address of the network interface. If you don't specify
- // an IP address, Amazon EC2 selects one for you from the subnet range. If you
- // specify an IP address, you cannot indicate any IP addresses specified in
- // privateIpAddresses as primary (only one IP address can be designated as primary).
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // One or more private IP addresses.
- PrivateIpAddresses []*PrivateIpAddressSpecification `locationName:"privateIpAddresses" locationNameList:"item" type:"list"`
- // The number of secondary private IP addresses to assign to a network interface.
- // When you specify a number of secondary IP addresses, Amazon EC2 selects these
- // IP addresses within the subnet range. You can't specify this option and specify
- // more than one private IP address using privateIpAddresses.
- //
- // The number of IP addresses you can assign to a network interface varies
- // by instance type. For more information, see Private IP Addresses Per ENI
- // Per Instance Type (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-eni.html#AvailableIpPerENI)
- // in the Amazon Elastic Compute Cloud User Guide.
- SecondaryPrivateIpAddressCount *int64 `locationName:"secondaryPrivateIpAddressCount" type:"integer"`
- // The ID of the subnet to associate with the network interface.
- SubnetId *string `locationName:"subnetId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateNetworkInterfaceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNetworkInterfaceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateNetworkInterfaceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateNetworkInterfaceInput"}
- if s.SubnetId == nil {
- invalidParams.Add(request.NewErrParamRequired("SubnetId"))
- }
- if s.PrivateIpAddresses != nil {
- for i, v := range s.PrivateIpAddresses {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "PrivateIpAddresses", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateNetworkInterface.
- type CreateNetworkInterfaceOutput struct {
- _ struct{} `type:"structure"`
- // Information about the network interface.
- NetworkInterface *NetworkInterface `locationName:"networkInterface" type:"structure"`
- }
- // String returns the string representation
- func (s CreateNetworkInterfaceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateNetworkInterfaceOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreatePlacementGroup.
- type CreatePlacementGroupInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // A name for the placement group.
- //
- // Constraints: Up to 255 ASCII characters
- GroupName *string `locationName:"groupName" type:"string" required:"true"`
- // The placement strategy.
- Strategy *string `locationName:"strategy" type:"string" required:"true" enum:"PlacementStrategy"`
- }
- // String returns the string representation
- func (s CreatePlacementGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreatePlacementGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreatePlacementGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreatePlacementGroupInput"}
- if s.GroupName == nil {
- invalidParams.Add(request.NewErrParamRequired("GroupName"))
- }
- if s.Strategy == nil {
- invalidParams.Add(request.NewErrParamRequired("Strategy"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type CreatePlacementGroupOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s CreatePlacementGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreatePlacementGroupOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateReservedInstancesListing.
- type CreateReservedInstancesListingInput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier you provide to ensure idempotency of your
- // listings. This helps avoid duplicate listings. For more information, see
- // Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `locationName:"clientToken" type:"string" required:"true"`
- // The number of instances that are a part of a Reserved Instance account to
- // be listed in the Reserved Instance Marketplace. This number should be less
- // than or equal to the instance count associated with the Reserved Instance
- // ID specified in this call.
- InstanceCount *int64 `locationName:"instanceCount" type:"integer" required:"true"`
- // A list specifying the price of the Reserved Instance for each month remaining
- // in the Reserved Instance term.
- PriceSchedules []*PriceScheduleSpecification `locationName:"priceSchedules" locationNameList:"item" type:"list" required:"true"`
- // The ID of the active Reserved Instance.
- ReservedInstancesId *string `locationName:"reservedInstancesId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateReservedInstancesListingInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateReservedInstancesListingInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateReservedInstancesListingInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateReservedInstancesListingInput"}
- if s.ClientToken == nil {
- invalidParams.Add(request.NewErrParamRequired("ClientToken"))
- }
- if s.InstanceCount == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceCount"))
- }
- if s.PriceSchedules == nil {
- invalidParams.Add(request.NewErrParamRequired("PriceSchedules"))
- }
- if s.ReservedInstancesId == nil {
- invalidParams.Add(request.NewErrParamRequired("ReservedInstancesId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateReservedInstancesListing.
- type CreateReservedInstancesListingOutput struct {
- _ struct{} `type:"structure"`
- // Information about the Reserved Instance listing.
- ReservedInstancesListings []*ReservedInstancesListing `locationName:"reservedInstancesListingsSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s CreateReservedInstancesListingOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateReservedInstancesListingOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateRoute.
- type CreateRouteInput struct {
- _ struct{} `type:"structure"`
- // The CIDR address block used for the destination match. Routing decisions
- // are based on the most specific match.
- DestinationCidrBlock *string `locationName:"destinationCidrBlock" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of an Internet gateway or virtual private gateway attached to your
- // VPC.
- GatewayId *string `locationName:"gatewayId" type:"string"`
- // The ID of a NAT instance in your VPC. The operation fails if you specify
- // an instance ID unless exactly one network interface is attached.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The ID of a NAT gateway.
- NatGatewayId *string `locationName:"natGatewayId" type:"string"`
- // The ID of a network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // The ID of the route table for the route.
- RouteTableId *string `locationName:"routeTableId" type:"string" required:"true"`
- // The ID of a VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string"`
- }
- // String returns the string representation
- func (s CreateRouteInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateRouteInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateRouteInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateRouteInput"}
- if s.DestinationCidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("DestinationCidrBlock"))
- }
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateRoute.
- type CreateRouteOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s CreateRouteOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateRouteOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateRouteTable.
- type CreateRouteTableInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateRouteTableInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateRouteTableInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateRouteTableInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateRouteTableInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateRouteTable.
- type CreateRouteTableOutput struct {
- _ struct{} `type:"structure"`
- // Information about the route table.
- RouteTable *RouteTable `locationName:"routeTable" type:"structure"`
- }
- // String returns the string representation
- func (s CreateRouteTableOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateRouteTableOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateSecurityGroup.
- type CreateSecurityGroupInput struct {
- _ struct{} `type:"structure"`
- // A description for the security group. This is informational only.
- //
- // Constraints: Up to 255 characters in length
- //
- // Constraints for EC2-Classic: ASCII characters
- //
- // Constraints for EC2-VPC: a-z, A-Z, 0-9, spaces, and ._-:/()#,@[]+=&;{}!$*
- Description *string `locationName:"GroupDescription" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The name of the security group.
- //
- // Constraints: Up to 255 characters in length
- //
- // Constraints for EC2-Classic: ASCII characters
- //
- // Constraints for EC2-VPC: a-z, A-Z, 0-9, spaces, and ._-:/()#,@[]+=&;{}!$*
- GroupName *string `type:"string" required:"true"`
- // [EC2-VPC] The ID of the VPC. Required for EC2-VPC.
- VpcId *string `type:"string"`
- }
- // String returns the string representation
- func (s CreateSecurityGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateSecurityGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateSecurityGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateSecurityGroupInput"}
- if s.Description == nil {
- invalidParams.Add(request.NewErrParamRequired("Description"))
- }
- if s.GroupName == nil {
- invalidParams.Add(request.NewErrParamRequired("GroupName"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateSecurityGroup.
- type CreateSecurityGroupOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the security group.
- GroupId *string `locationName:"groupId" type:"string"`
- }
- // String returns the string representation
- func (s CreateSecurityGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateSecurityGroupOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateSnapshot.
- type CreateSnapshotInput struct {
- _ struct{} `type:"structure"`
- // A description for the snapshot.
- Description *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the EBS volume.
- VolumeId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateSnapshotInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateSnapshotInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateSnapshotInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateSnapshotInput"}
- if s.VolumeId == nil {
- invalidParams.Add(request.NewErrParamRequired("VolumeId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the parameters for CreateSpotDatafeedSubscription.
- type CreateSpotDatafeedSubscriptionInput struct {
- _ struct{} `type:"structure"`
- // The Amazon S3 bucket in which to store the Spot instance data feed.
- Bucket *string `locationName:"bucket" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // A prefix for the data feed file names.
- Prefix *string `locationName:"prefix" type:"string"`
- }
- // String returns the string representation
- func (s CreateSpotDatafeedSubscriptionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateSpotDatafeedSubscriptionInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateSpotDatafeedSubscriptionInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateSpotDatafeedSubscriptionInput"}
- if s.Bucket == nil {
- invalidParams.Add(request.NewErrParamRequired("Bucket"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateSpotDatafeedSubscription.
- type CreateSpotDatafeedSubscriptionOutput struct {
- _ struct{} `type:"structure"`
- // The Spot instance data feed subscription.
- SpotDatafeedSubscription *SpotDatafeedSubscription `locationName:"spotDatafeedSubscription" type:"structure"`
- }
- // String returns the string representation
- func (s CreateSpotDatafeedSubscriptionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateSpotDatafeedSubscriptionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateSubnet.
- type CreateSubnetInput struct {
- _ struct{} `type:"structure"`
- // The Availability Zone for the subnet.
- //
- // Default: AWS selects one for you. If you create more than one subnet in
- // your VPC, we may not necessarily select a different zone for each subnet.
- AvailabilityZone *string `type:"string"`
- // The network range for the subnet, in CIDR notation. For example, 10.0.0.0/24.
- CidrBlock *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateSubnetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateSubnetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateSubnetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateSubnetInput"}
- if s.CidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("CidrBlock"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateSubnet.
- type CreateSubnetOutput struct {
- _ struct{} `type:"structure"`
- // Information about the subnet.
- Subnet *Subnet `locationName:"subnet" type:"structure"`
- }
- // String returns the string representation
- func (s CreateSubnetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateSubnetOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateTags.
- type CreateTagsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The IDs of one or more resources to tag. For example, ami-1a2b3c4d.
- Resources []*string `locationName:"ResourceId" type:"list" required:"true"`
- // One or more tags. The value parameter is required, but if you don't want
- // the tag to have a value, specify the parameter with no value, and we set
- // the value to an empty string.
- Tags []*Tag `locationName:"Tag" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s CreateTagsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateTagsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateTagsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateTagsInput"}
- if s.Resources == nil {
- invalidParams.Add(request.NewErrParamRequired("Resources"))
- }
- if s.Tags == nil {
- invalidParams.Add(request.NewErrParamRequired("Tags"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type CreateTagsOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s CreateTagsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateTagsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateVolume.
- type CreateVolumeInput struct {
- _ struct{} `type:"structure"`
- // The Availability Zone in which to create the volume. Use DescribeAvailabilityZones
- // to list the Availability Zones that are currently available to you.
- AvailabilityZone *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Specifies whether the volume should be encrypted. Encrypted Amazon EBS volumes
- // may only be attached to instances that support Amazon EBS encryption. Volumes
- // that are created from encrypted snapshots are automatically encrypted. There
- // is no way to create an encrypted volume from an unencrypted snapshot or vice
- // versa. If your AMI uses encrypted volumes, you can only launch it on supported
- // instance types. For more information, see Amazon EBS Encryption (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- Encrypted *bool `locationName:"encrypted" type:"boolean"`
- // Only valid for Provisioned IOPS SSD volumes. The number of I/O operations
- // per second (IOPS) to provision for the volume, with a maximum ratio of 30
- // IOPS/GiB.
- //
- // Constraint: Range is 100 to 20000 for Provisioned IOPS SSD volumes
- Iops *int64 `type:"integer"`
- // The full ARN of the AWS Key Management Service (AWS KMS) customer master
- // key (CMK) to use when creating the encrypted volume. This parameter is only
- // required if you want to use a non-default CMK; if this parameter is not specified,
- // the default CMK for EBS is used. The ARN contains the arn:aws:kms namespace,
- // followed by the region of the CMK, the AWS account ID of the CMK owner, the
- // key namespace, and then the CMK ID. For example, arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.
- // If a KmsKeyId is specified, the Encrypted flag must also be set.
- KmsKeyId *string `type:"string"`
- // The size of the volume, in GiBs.
- //
- // Constraints: 1-16384 for gp2, 4-16384 for io1, 500-16384 for st1, 500-16384
- // for sc1, and 1-1024 for standard. If you specify a snapshot, the volume size
- // must be equal to or larger than the snapshot size.
- //
- // Default: If you're creating the volume from a snapshot and don't specify
- // a volume size, the default is the snapshot size.
- Size *int64 `type:"integer"`
- // The snapshot from which to create the volume.
- SnapshotId *string `type:"string"`
- // The volume type. This can be gp2 for General Purpose SSD, io1 for Provisioned
- // IOPS SSD, st1 for Throughput Optimized HDD, sc1 for Cold HDD, or standard
- // for Magnetic volumes.
- //
- // Default: standard
- VolumeType *string `type:"string" enum:"VolumeType"`
- }
- // String returns the string representation
- func (s CreateVolumeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVolumeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateVolumeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateVolumeInput"}
- if s.AvailabilityZone == nil {
- invalidParams.Add(request.NewErrParamRequired("AvailabilityZone"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes the user or group to be added or removed from the permissions for
- // a volume.
- type CreateVolumePermission struct {
- _ struct{} `type:"structure"`
- // The specific group that is to be added or removed from a volume's list of
- // create volume permissions.
- Group *string `locationName:"group" type:"string" enum:"PermissionGroup"`
- // The specific AWS account ID that is to be added or removed from a volume's
- // list of create volume permissions.
- UserId *string `locationName:"userId" type:"string"`
- }
- // String returns the string representation
- func (s CreateVolumePermission) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVolumePermission) GoString() string {
- return s.String()
- }
- // Describes modifications to the permissions for a volume.
- type CreateVolumePermissionModifications struct {
- _ struct{} `type:"structure"`
- // Adds a specific AWS account ID or group to a volume's list of create volume
- // permissions.
- Add []*CreateVolumePermission `locationNameList:"item" type:"list"`
- // Removes a specific AWS account ID or group from a volume's list of create
- // volume permissions.
- Remove []*CreateVolumePermission `locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s CreateVolumePermissionModifications) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVolumePermissionModifications) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateVpcEndpoint.
- type CreateVpcEndpointInput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier you provide to ensure the idempotency of
- // the request. For more information, see How to Ensure Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // A policy to attach to the endpoint that controls access to the service. The
- // policy must be in valid JSON format. If this parameter is not specified,
- // we attach a default policy that allows full access to the service.
- PolicyDocument *string `type:"string"`
- // One or more route table IDs.
- RouteTableIds []*string `locationName:"RouteTableId" locationNameList:"item" type:"list"`
- // The AWS service name, in the form com.amazonaws.region.service . To get a
- // list of available services, use the DescribeVpcEndpointServices request.
- ServiceName *string `type:"string" required:"true"`
- // The ID of the VPC in which the endpoint will be used.
- VpcId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateVpcEndpointInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpcEndpointInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateVpcEndpointInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateVpcEndpointInput"}
- if s.ServiceName == nil {
- invalidParams.Add(request.NewErrParamRequired("ServiceName"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateVpcEndpoint.
- type CreateVpcEndpointOutput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier you provide to ensure the idempotency of
- // the request.
- ClientToken *string `locationName:"clientToken" type:"string"`
- // Information about the endpoint.
- VpcEndpoint *VpcEndpoint `locationName:"vpcEndpoint" type:"structure"`
- }
- // String returns the string representation
- func (s CreateVpcEndpointOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpcEndpointOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateVpc.
- type CreateVpcInput struct {
- _ struct{} `type:"structure"`
- // The network range for the VPC, in CIDR notation. For example, 10.0.0.0/16.
- CidrBlock *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The tenancy options for instances launched into the VPC. For default, instances
- // are launched with shared tenancy by default. You can launch instances with
- // any tenancy into a shared tenancy VPC. For dedicated, instances are launched
- // as dedicated tenancy instances by default. You can only launch instances
- // with a tenancy of dedicated or host into a dedicated tenancy VPC.
- //
- // Important: The host value cannot be used with this parameter. Use the default
- // or dedicated values only.
- //
- // Default: default
- InstanceTenancy *string `locationName:"instanceTenancy" type:"string" enum:"Tenancy"`
- }
- // String returns the string representation
- func (s CreateVpcInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpcInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateVpcInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateVpcInput"}
- if s.CidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("CidrBlock"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateVpc.
- type CreateVpcOutput struct {
- _ struct{} `type:"structure"`
- // Information about the VPC.
- Vpc *Vpc `locationName:"vpc" type:"structure"`
- }
- // String returns the string representation
- func (s CreateVpcOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpcOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateVpcPeeringConnection.
- type CreateVpcPeeringConnectionInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The AWS account ID of the owner of the peer VPC.
- //
- // Default: Your AWS account ID
- PeerOwnerId *string `locationName:"peerOwnerId" type:"string"`
- // The ID of the VPC with which you are creating the VPC peering connection.
- PeerVpcId *string `locationName:"peerVpcId" type:"string"`
- // The ID of the requester VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s CreateVpcPeeringConnectionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpcPeeringConnectionInput) GoString() string {
- return s.String()
- }
- // Contains the output of CreateVpcPeeringConnection.
- type CreateVpcPeeringConnectionOutput struct {
- _ struct{} `type:"structure"`
- // Information about the VPC peering connection.
- VpcPeeringConnection *VpcPeeringConnection `locationName:"vpcPeeringConnection" type:"structure"`
- }
- // String returns the string representation
- func (s CreateVpcPeeringConnectionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpcPeeringConnectionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateVpnConnection.
- type CreateVpnConnectionInput struct {
- _ struct{} `type:"structure"`
- // The ID of the customer gateway.
- CustomerGatewayId *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Indicates whether the VPN connection requires static routes. If you are creating
- // a VPN connection for a device that does not support BGP, you must specify
- // true.
- //
- // Default: false
- Options *VpnConnectionOptionsSpecification `locationName:"options" type:"structure"`
- // The type of VPN connection (ipsec.1).
- Type *string `type:"string" required:"true"`
- // The ID of the virtual private gateway.
- VpnGatewayId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateVpnConnectionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpnConnectionInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateVpnConnectionInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateVpnConnectionInput"}
- if s.CustomerGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("CustomerGatewayId"))
- }
- if s.Type == nil {
- invalidParams.Add(request.NewErrParamRequired("Type"))
- }
- if s.VpnGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpnGatewayId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateVpnConnection.
- type CreateVpnConnectionOutput struct {
- _ struct{} `type:"structure"`
- // Information about the VPN connection.
- VpnConnection *VpnConnection `locationName:"vpnConnection" type:"structure"`
- }
- // String returns the string representation
- func (s CreateVpnConnectionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpnConnectionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateVpnConnectionRoute.
- type CreateVpnConnectionRouteInput struct {
- _ struct{} `type:"structure"`
- // The CIDR block associated with the local subnet of the customer network.
- DestinationCidrBlock *string `type:"string" required:"true"`
- // The ID of the VPN connection.
- VpnConnectionId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s CreateVpnConnectionRouteInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpnConnectionRouteInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateVpnConnectionRouteInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateVpnConnectionRouteInput"}
- if s.DestinationCidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("DestinationCidrBlock"))
- }
- if s.VpnConnectionId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpnConnectionId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type CreateVpnConnectionRouteOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s CreateVpnConnectionRouteOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpnConnectionRouteOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for CreateVpnGateway.
- type CreateVpnGatewayInput struct {
- _ struct{} `type:"structure"`
- // The Availability Zone for the virtual private gateway.
- AvailabilityZone *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The type of VPN connection this virtual private gateway supports.
- Type *string `type:"string" required:"true" enum:"GatewayType"`
- }
- // String returns the string representation
- func (s CreateVpnGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpnGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateVpnGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateVpnGatewayInput"}
- if s.Type == nil {
- invalidParams.Add(request.NewErrParamRequired("Type"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of CreateVpnGateway.
- type CreateVpnGatewayOutput struct {
- _ struct{} `type:"structure"`
- // Information about the virtual private gateway.
- VpnGateway *VpnGateway `locationName:"vpnGateway" type:"structure"`
- }
- // String returns the string representation
- func (s CreateVpnGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CreateVpnGatewayOutput) GoString() string {
- return s.String()
- }
- // Describes a customer gateway.
- type CustomerGateway struct {
- _ struct{} `type:"structure"`
- // The customer gateway's Border Gateway Protocol (BGP) Autonomous System Number
- // (ASN).
- BgpAsn *string `locationName:"bgpAsn" type:"string"`
- // The ID of the customer gateway.
- CustomerGatewayId *string `locationName:"customerGatewayId" type:"string"`
- // The Internet-routable IP address of the customer gateway's outside interface.
- IpAddress *string `locationName:"ipAddress" type:"string"`
- // The current state of the customer gateway (pending | available | deleting
- // | deleted).
- State *string `locationName:"state" type:"string"`
- // Any tags assigned to the customer gateway.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The type of VPN connection the customer gateway supports (ipsec.1).
- Type *string `locationName:"type" type:"string"`
- }
- // String returns the string representation
- func (s CustomerGateway) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s CustomerGateway) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteCustomerGateway.
- type DeleteCustomerGatewayInput struct {
- _ struct{} `type:"structure"`
- // The ID of the customer gateway.
- CustomerGatewayId *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s DeleteCustomerGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteCustomerGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteCustomerGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteCustomerGatewayInput"}
- if s.CustomerGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("CustomerGatewayId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteCustomerGatewayOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteCustomerGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteCustomerGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteDhcpOptions.
- type DeleteDhcpOptionsInput struct {
- _ struct{} `type:"structure"`
- // The ID of the DHCP options set.
- DhcpOptionsId *string `type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s DeleteDhcpOptionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteDhcpOptionsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteDhcpOptionsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteDhcpOptionsInput"}
- if s.DhcpOptionsId == nil {
- invalidParams.Add(request.NewErrParamRequired("DhcpOptionsId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteDhcpOptionsOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteDhcpOptionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteDhcpOptionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteFlowLogs.
- type DeleteFlowLogsInput struct {
- _ struct{} `type:"structure"`
- // One or more flow log IDs.
- FlowLogIds []*string `locationName:"FlowLogId" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s DeleteFlowLogsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteFlowLogsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteFlowLogsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteFlowLogsInput"}
- if s.FlowLogIds == nil {
- invalidParams.Add(request.NewErrParamRequired("FlowLogIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DeleteFlowLogs.
- type DeleteFlowLogsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the flow logs that could not be deleted successfully.
- Unsuccessful []*UnsuccessfulItem `locationName:"unsuccessful" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DeleteFlowLogsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteFlowLogsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteInternetGateway.
- type DeleteInternetGatewayInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the Internet gateway.
- InternetGatewayId *string `locationName:"internetGatewayId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteInternetGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteInternetGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteInternetGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteInternetGatewayInput"}
- if s.InternetGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("InternetGatewayId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteInternetGatewayOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteInternetGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteInternetGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteKeyPair.
- type DeleteKeyPairInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The name of the key pair.
- KeyName *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteKeyPairInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteKeyPairInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteKeyPairInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteKeyPairInput"}
- if s.KeyName == nil {
- invalidParams.Add(request.NewErrParamRequired("KeyName"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteKeyPairOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteKeyPairOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteKeyPairOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteNatGateway.
- type DeleteNatGatewayInput struct {
- _ struct{} `type:"structure"`
- // The ID of the NAT gateway.
- NatGatewayId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteNatGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNatGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteNatGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteNatGatewayInput"}
- if s.NatGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("NatGatewayId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DeleteNatGateway.
- type DeleteNatGatewayOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the NAT gateway.
- NatGatewayId *string `locationName:"natGatewayId" type:"string"`
- }
- // String returns the string representation
- func (s DeleteNatGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNatGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteNetworkAclEntry.
- type DeleteNetworkAclEntryInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Indicates whether the rule is an egress rule.
- Egress *bool `locationName:"egress" type:"boolean" required:"true"`
- // The ID of the network ACL.
- NetworkAclId *string `locationName:"networkAclId" type:"string" required:"true"`
- // The rule number of the entry to delete.
- RuleNumber *int64 `locationName:"ruleNumber" type:"integer" required:"true"`
- }
- // String returns the string representation
- func (s DeleteNetworkAclEntryInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNetworkAclEntryInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteNetworkAclEntryInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteNetworkAclEntryInput"}
- if s.Egress == nil {
- invalidParams.Add(request.NewErrParamRequired("Egress"))
- }
- if s.NetworkAclId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkAclId"))
- }
- if s.RuleNumber == nil {
- invalidParams.Add(request.NewErrParamRequired("RuleNumber"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteNetworkAclEntryOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteNetworkAclEntryOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNetworkAclEntryOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteNetworkAcl.
- type DeleteNetworkAclInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the network ACL.
- NetworkAclId *string `locationName:"networkAclId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteNetworkAclInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNetworkAclInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteNetworkAclInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteNetworkAclInput"}
- if s.NetworkAclId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkAclId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteNetworkAclOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteNetworkAclOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNetworkAclOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteNetworkInterface.
- type DeleteNetworkInterfaceInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteNetworkInterfaceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNetworkInterfaceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteNetworkInterfaceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteNetworkInterfaceInput"}
- if s.NetworkInterfaceId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkInterfaceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteNetworkInterfaceOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteNetworkInterfaceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteNetworkInterfaceOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeletePlacementGroup.
- type DeletePlacementGroupInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The name of the placement group.
- GroupName *string `locationName:"groupName" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeletePlacementGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeletePlacementGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeletePlacementGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeletePlacementGroupInput"}
- if s.GroupName == nil {
- invalidParams.Add(request.NewErrParamRequired("GroupName"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeletePlacementGroupOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeletePlacementGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeletePlacementGroupOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteRoute.
- type DeleteRouteInput struct {
- _ struct{} `type:"structure"`
- // The CIDR range for the route. The value you specify must match the CIDR for
- // the route exactly.
- DestinationCidrBlock *string `locationName:"destinationCidrBlock" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the route table.
- RouteTableId *string `locationName:"routeTableId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteRouteInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteRouteInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteRouteInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteRouteInput"}
- if s.DestinationCidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("DestinationCidrBlock"))
- }
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteRouteOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteRouteOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteRouteOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteRouteTable.
- type DeleteRouteTableInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the route table.
- RouteTableId *string `locationName:"routeTableId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteRouteTableInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteRouteTableInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteRouteTableInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteRouteTableInput"}
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteRouteTableOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteRouteTableOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteRouteTableOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteSecurityGroup.
- type DeleteSecurityGroupInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the security group. Required for a nondefault VPC.
- GroupId *string `type:"string"`
- // [EC2-Classic, default VPC] The name of the security group. You can specify
- // either the security group name or the security group ID.
- GroupName *string `type:"string"`
- }
- // String returns the string representation
- func (s DeleteSecurityGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSecurityGroupInput) GoString() string {
- return s.String()
- }
- type DeleteSecurityGroupOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteSecurityGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSecurityGroupOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteSnapshot.
- type DeleteSnapshotInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the EBS snapshot.
- SnapshotId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteSnapshotInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSnapshotInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteSnapshotInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteSnapshotInput"}
- if s.SnapshotId == nil {
- invalidParams.Add(request.NewErrParamRequired("SnapshotId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteSnapshotOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteSnapshotOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSnapshotOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteSpotDatafeedSubscription.
- type DeleteSpotDatafeedSubscriptionInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s DeleteSpotDatafeedSubscriptionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSpotDatafeedSubscriptionInput) GoString() string {
- return s.String()
- }
- type DeleteSpotDatafeedSubscriptionOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteSpotDatafeedSubscriptionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSpotDatafeedSubscriptionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteSubnet.
- type DeleteSubnetInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the subnet.
- SubnetId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteSubnetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSubnetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteSubnetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteSubnetInput"}
- if s.SubnetId == nil {
- invalidParams.Add(request.NewErrParamRequired("SubnetId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteSubnetOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteSubnetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteSubnetOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteTags.
- type DeleteTagsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the resource. For example, ami-1a2b3c4d. You can specify more than
- // one resource ID.
- Resources []*string `locationName:"resourceId" type:"list" required:"true"`
- // One or more tags to delete. If you omit the value parameter, we delete the
- // tag regardless of its value. If you specify this parameter with an empty
- // string as the value, we delete the key only if its value is an empty string.
- Tags []*Tag `locationName:"tag" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DeleteTagsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteTagsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteTagsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteTagsInput"}
- if s.Resources == nil {
- invalidParams.Add(request.NewErrParamRequired("Resources"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteTagsOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteTagsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteTagsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteVolume.
- type DeleteVolumeInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the volume.
- VolumeId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteVolumeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVolumeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteVolumeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteVolumeInput"}
- if s.VolumeId == nil {
- invalidParams.Add(request.NewErrParamRequired("VolumeId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteVolumeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteVolumeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVolumeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteVpcEndpoints.
- type DeleteVpcEndpointsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more endpoint IDs.
- VpcEndpointIds []*string `locationName:"VpcEndpointId" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s DeleteVpcEndpointsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpcEndpointsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteVpcEndpointsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteVpcEndpointsInput"}
- if s.VpcEndpointIds == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcEndpointIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DeleteVpcEndpoints.
- type DeleteVpcEndpointsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the endpoints that were not successfully deleted.
- Unsuccessful []*UnsuccessfulItem `locationName:"unsuccessful" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DeleteVpcEndpointsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpcEndpointsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteVpc.
- type DeleteVpcInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteVpcInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpcInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteVpcInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteVpcInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteVpcOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteVpcOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpcOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteVpcPeeringConnection.
- type DeleteVpcPeeringConnectionInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteVpcPeeringConnectionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpcPeeringConnectionInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteVpcPeeringConnectionInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteVpcPeeringConnectionInput"}
- if s.VpcPeeringConnectionId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcPeeringConnectionId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DeleteVpcPeeringConnection.
- type DeleteVpcPeeringConnectionOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s DeleteVpcPeeringConnectionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpcPeeringConnectionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteVpnConnection.
- type DeleteVpnConnectionInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPN connection.
- VpnConnectionId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteVpnConnectionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpnConnectionInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteVpnConnectionInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteVpnConnectionInput"}
- if s.VpnConnectionId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpnConnectionId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteVpnConnectionOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteVpnConnectionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpnConnectionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteVpnConnectionRoute.
- type DeleteVpnConnectionRouteInput struct {
- _ struct{} `type:"structure"`
- // The CIDR block associated with the local subnet of the customer network.
- DestinationCidrBlock *string `type:"string" required:"true"`
- // The ID of the VPN connection.
- VpnConnectionId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteVpnConnectionRouteInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpnConnectionRouteInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteVpnConnectionRouteInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteVpnConnectionRouteInput"}
- if s.DestinationCidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("DestinationCidrBlock"))
- }
- if s.VpnConnectionId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpnConnectionId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteVpnConnectionRouteOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteVpnConnectionRouteOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpnConnectionRouteOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeleteVpnGateway.
- type DeleteVpnGatewayInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the virtual private gateway.
- VpnGatewayId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeleteVpnGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpnGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteVpnGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteVpnGatewayInput"}
- if s.VpnGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpnGatewayId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeleteVpnGatewayOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeleteVpnGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeleteVpnGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DeregisterImage.
- type DeregisterImageInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the AMI.
- ImageId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DeregisterImageInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeregisterImageInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeregisterImageInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeregisterImageInput"}
- if s.ImageId == nil {
- invalidParams.Add(request.NewErrParamRequired("ImageId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DeregisterImageOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DeregisterImageOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DeregisterImageOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeAccountAttributes.
- type DescribeAccountAttributesInput struct {
- _ struct{} `type:"structure"`
- // One or more account attribute names.
- AttributeNames []*string `locationName:"attributeName" locationNameList:"attributeName" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s DescribeAccountAttributesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeAccountAttributesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeAccountAttributes.
- type DescribeAccountAttributesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more account attributes.
- AccountAttributes []*AccountAttribute `locationName:"accountAttributeSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeAccountAttributesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeAccountAttributesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeAddresses.
- type DescribeAddressesInput struct {
- _ struct{} `type:"structure"`
- // [EC2-VPC] One or more allocation IDs.
- //
- // Default: Describes all your Elastic IP addresses.
- AllocationIds []*string `locationName:"AllocationId" locationNameList:"AllocationId" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters. Filter names and values are case-sensitive.
- //
- // allocation-id - [EC2-VPC] The allocation ID for the address.
- //
- // association-id - [EC2-VPC] The association ID for the address.
- //
- // domain - Indicates whether the address is for use in EC2-Classic (standard)
- // or in a VPC (vpc).
- //
- // instance-id - The ID of the instance the address is associated with,
- // if any.
- //
- // network-interface-id - [EC2-VPC] The ID of the network interface that
- // the address is associated with, if any.
- //
- // network-interface-owner-id - The AWS account ID of the owner.
- //
- // private-ip-address - [EC2-VPC] The private IP address associated with
- // the Elastic IP address.
- //
- // public-ip - The Elastic IP address.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // [EC2-Classic] One or more Elastic IP addresses.
- //
- // Default: Describes all your Elastic IP addresses.
- PublicIps []*string `locationName:"PublicIp" locationNameList:"PublicIp" type:"list"`
- }
- // String returns the string representation
- func (s DescribeAddressesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeAddressesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeAddresses.
- type DescribeAddressesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more Elastic IP addresses.
- Addresses []*Address `locationName:"addressesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeAddressesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeAddressesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeAvailabilityZones.
- type DescribeAvailabilityZonesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // message - Information about the Availability Zone.
- //
- // region-name - The name of the region for the Availability Zone (for example,
- // us-east-1).
- //
- // state - The state of the Availability Zone (available | information |
- // impaired | unavailable).
- //
- // zone-name - The name of the Availability Zone (for example, us-east-1a).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The names of one or more Availability Zones.
- ZoneNames []*string `locationName:"ZoneName" locationNameList:"ZoneName" type:"list"`
- }
- // String returns the string representation
- func (s DescribeAvailabilityZonesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeAvailabilityZonesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeAvailabiltyZones.
- type DescribeAvailabilityZonesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more Availability Zones.
- AvailabilityZones []*AvailabilityZone `locationName:"availabilityZoneInfo" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeAvailabilityZonesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeAvailabilityZonesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeBundleTasks.
- type DescribeBundleTasksInput struct {
- _ struct{} `type:"structure"`
- // One or more bundle task IDs.
- //
- // Default: Describes all your bundle tasks.
- BundleIds []*string `locationName:"BundleId" locationNameList:"BundleId" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // bundle-id - The ID of the bundle task.
- //
- // error-code - If the task failed, the error code returned.
- //
- // error-message - If the task failed, the error message returned.
- //
- // instance-id - The ID of the instance.
- //
- // progress - The level of task completion, as a percentage (for example,
- // 20%).
- //
- // s3-bucket - The Amazon S3 bucket to store the AMI.
- //
- // s3-prefix - The beginning of the AMI name.
- //
- // start-time - The time the task started (for example, 2013-09-15T17:15:20.000Z).
- //
- // state - The state of the task (pending | waiting-for-shutdown | bundling
- // | storing | cancelling | complete | failed).
- //
- // update-time - The time of the most recent update for the task.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- }
- // String returns the string representation
- func (s DescribeBundleTasksInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeBundleTasksInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeBundleTasks.
- type DescribeBundleTasksOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more bundle tasks.
- BundleTasks []*BundleTask `locationName:"bundleInstanceTasksSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeBundleTasksOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeBundleTasksOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeClassicLinkInstances.
- type DescribeClassicLinkInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // group-id - The ID of a VPC security group that's associated with the
- // instance.
- //
- // instance-id - The ID of the instance.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // vpc-id - The ID of the VPC that the instance is linked to.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more instance IDs. Must be instances linked to a VPC through ClassicLink.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list"`
- // The maximum number of results to return for the request in a single page.
- // The remaining results of the initial request can be seen by sending another
- // request with the returned NextToken value. This value can be between 5 and
- // 1000; if MaxResults is given a value larger than 1000, only 1000 results
- // are returned. You cannot specify this parameter and the instance IDs parameter
- // in the same request.
- //
- // Constraint: If the value is greater than 1000, we return only 1000 items.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token to retrieve the next page of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeClassicLinkInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeClassicLinkInstancesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeClassicLinkInstances.
- type DescribeClassicLinkInstancesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more linked EC2-Classic instances.
- Instances []*ClassicLinkInstance `locationName:"instancesSet" locationNameList:"item" type:"list"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeClassicLinkInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeClassicLinkInstancesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeConversionTasks.
- type DescribeConversionTasksInput struct {
- _ struct{} `type:"structure"`
- // One or more conversion task IDs.
- ConversionTaskIds []*string `locationName:"conversionTaskId" locationNameList:"item" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- Filters []*Filter `locationName:"filter" locationNameList:"Filter" type:"list"`
- }
- // String returns the string representation
- func (s DescribeConversionTasksInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeConversionTasksInput) GoString() string {
- return s.String()
- }
- // Contains the output for DescribeConversionTasks.
- type DescribeConversionTasksOutput struct {
- _ struct{} `type:"structure"`
- // Information about the conversion tasks.
- ConversionTasks []*ConversionTask `locationName:"conversionTasks" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeConversionTasksOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeConversionTasksOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeCustomerGateways.
- type DescribeCustomerGatewaysInput struct {
- _ struct{} `type:"structure"`
- // One or more customer gateway IDs.
- //
- // Default: Describes all your customer gateways.
- CustomerGatewayIds []*string `locationName:"CustomerGatewayId" locationNameList:"CustomerGatewayId" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // bgp-asn - The customer gateway's Border Gateway Protocol (BGP) Autonomous
- // System Number (ASN).
- //
- // customer-gateway-id - The ID of the customer gateway.
- //
- // ip-address - The IP address of the customer gateway's Internet-routable
- // external interface.
- //
- // state - The state of the customer gateway (pending | available | deleting
- // | deleted).
- //
- // type - The type of customer gateway. Currently, the only supported type
- // is ipsec.1.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- }
- // String returns the string representation
- func (s DescribeCustomerGatewaysInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeCustomerGatewaysInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeCustomerGateways.
- type DescribeCustomerGatewaysOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more customer gateways.
- CustomerGateways []*CustomerGateway `locationName:"customerGatewaySet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeCustomerGatewaysOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeCustomerGatewaysOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeDhcpOptions.
- type DescribeDhcpOptionsInput struct {
- _ struct{} `type:"structure"`
- // The IDs of one or more DHCP options sets.
- //
- // Default: Describes all your DHCP options sets.
- DhcpOptionsIds []*string `locationName:"DhcpOptionsId" locationNameList:"DhcpOptionsId" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // dhcp-options-id - The ID of a set of DHCP options.
- //
- // key - The key for one of the options (for example, domain-name).
- //
- // value - The value for one of the options.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- }
- // String returns the string representation
- func (s DescribeDhcpOptionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeDhcpOptionsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeDhcpOptions.
- type DescribeDhcpOptionsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more DHCP options sets.
- DhcpOptions []*DhcpOptions `locationName:"dhcpOptionsSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeDhcpOptionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeDhcpOptionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeExportTasks.
- type DescribeExportTasksInput struct {
- _ struct{} `type:"structure"`
- // One or more export task IDs.
- ExportTaskIds []*string `locationName:"exportTaskId" locationNameList:"ExportTaskId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeExportTasksInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeExportTasksInput) GoString() string {
- return s.String()
- }
- // Contains the output for DescribeExportTasks.
- type DescribeExportTasksOutput struct {
- _ struct{} `type:"structure"`
- // Information about the export tasks.
- ExportTasks []*ExportTask `locationName:"exportTaskSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeExportTasksOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeExportTasksOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeFlowLogs.
- type DescribeFlowLogsInput struct {
- _ struct{} `type:"structure"`
- // One or more filters.
- //
- // deliver-log-status - The status of the logs delivery (SUCCESS | FAILED).
- //
- // flow-log-id - The ID of the flow log.
- //
- // log-group-name - The name of the log group.
- //
- // resource-id - The ID of the VPC, subnet, or network interface.
- //
- // traffic-type - The type of traffic (ACCEPT | REJECT | ALL)
- Filter []*Filter `locationNameList:"Filter" type:"list"`
- // One or more flow log IDs.
- FlowLogIds []*string `locationName:"FlowLogId" locationNameList:"item" type:"list"`
- // The maximum number of results to return for the request in a single page.
- // The remaining results can be seen by sending another request with the returned
- // NextToken value. This value can be between 5 and 1000; if MaxResults is given
- // a value larger than 1000, only 1000 results are returned. You cannot specify
- // this parameter and the flow log IDs parameter in the same request.
- MaxResults *int64 `type:"integer"`
- // The token to retrieve the next page of results.
- NextToken *string `type:"string"`
- }
- // String returns the string representation
- func (s DescribeFlowLogsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeFlowLogsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeFlowLogs.
- type DescribeFlowLogsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the flow logs.
- FlowLogs []*FlowLog `locationName:"flowLogSet" locationNameList:"item" type:"list"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeFlowLogsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeFlowLogsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeHosts.
- type DescribeHostsInput struct {
- _ struct{} `type:"structure"`
- // One or more filters.
- //
- // instance-type - The instance type size that the Dedicated host is configured
- // to support.
- //
- // auto-placement - Whether auto-placement is enabled or disabled (on |
- // off).
- //
- // host-reservation-id - The ID of the reservation associated with this
- // host.
- //
- // client-token - The idempotency token you provided when you launched the
- // instance
- //
- // state- The allocation state of the Dedicated host (available | under-assessment
- // | permanent-failure | released | released-permanent-failure).
- //
- // availability-zone - The Availability Zone of the host.
- Filter []*Filter `locationName:"filter" locationNameList:"Filter" type:"list"`
- // The IDs of the Dedicated hosts. The IDs are used for targeted instance launches.
- HostIds []*string `locationName:"hostId" locationNameList:"item" type:"list"`
- // The maximum number of results to return for the request in a single page.
- // The remaining results can be seen by sending another request with the returned
- // nextToken value. This value can be between 5 and 500; if maxResults is given
- // a larger value than 500, you will receive an error. You cannot specify this
- // parameter and the host IDs parameter in the same request.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token to retrieve the next page of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeHostsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeHostsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeHosts.
- type DescribeHostsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the Dedicated hosts.
- Hosts []*Host `locationName:"hostSet" locationNameList:"item" type:"list"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeHostsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeHostsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeIdFormat.
- type DescribeIdFormatInput struct {
- _ struct{} `type:"structure"`
- // The type of resource.
- Resource *string `type:"string"`
- }
- // String returns the string representation
- func (s DescribeIdFormatInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeIdFormatInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeIdFormat.
- type DescribeIdFormatOutput struct {
- _ struct{} `type:"structure"`
- // Information about the ID format for the resource.
- Statuses []*IdFormat `locationName:"statusSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeIdFormatOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeIdFormatOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeIdentityIdFormat.
- type DescribeIdentityIdFormatInput struct {
- _ struct{} `type:"structure"`
- // The ARN of the principal, which can be an IAM role, IAM user, or the root
- // user.
- PrincipalArn *string `locationName:"principalArn" type:"string" required:"true"`
- // The type of resource.
- Resource *string `locationName:"resource" type:"string"`
- }
- // String returns the string representation
- func (s DescribeIdentityIdFormatInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeIdentityIdFormatInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeIdentityIdFormatInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeIdentityIdFormatInput"}
- if s.PrincipalArn == nil {
- invalidParams.Add(request.NewErrParamRequired("PrincipalArn"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeIdentityIdFormat.
- type DescribeIdentityIdFormatOutput struct {
- _ struct{} `type:"structure"`
- // Information about the ID format for the resources.
- Statuses []*IdFormat `locationName:"statusSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeIdentityIdFormatOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeIdentityIdFormatOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeImageAttribute.
- type DescribeImageAttributeInput struct {
- _ struct{} `type:"structure"`
- // The AMI attribute.
- //
- // Note: Depending on your account privileges, the blockDeviceMapping attribute
- // may return a Client.AuthFailure error. If this happens, use DescribeImages
- // to get information about the block device mapping for the AMI.
- Attribute *string `type:"string" required:"true" enum:"ImageAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the AMI.
- ImageId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeImageAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImageAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeImageAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeImageAttributeInput"}
- if s.Attribute == nil {
- invalidParams.Add(request.NewErrParamRequired("Attribute"))
- }
- if s.ImageId == nil {
- invalidParams.Add(request.NewErrParamRequired("ImageId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes an image attribute.
- type DescribeImageAttributeOutput struct {
- _ struct{} `type:"structure"`
- // One or more block device mapping entries.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // A description for the AMI.
- Description *AttributeValue `locationName:"description" type:"structure"`
- // The ID of the AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- // The kernel ID.
- KernelId *AttributeValue `locationName:"kernel" type:"structure"`
- // One or more launch permissions.
- LaunchPermissions []*LaunchPermission `locationName:"launchPermission" locationNameList:"item" type:"list"`
- // One or more product codes.
- ProductCodes []*ProductCode `locationName:"productCodes" locationNameList:"item" type:"list"`
- // The RAM disk ID.
- RamdiskId *AttributeValue `locationName:"ramdisk" type:"structure"`
- // Indicates whether enhanced networking with the Intel 82599 Virtual Function
- // interface is enabled.
- SriovNetSupport *AttributeValue `locationName:"sriovNetSupport" type:"structure"`
- }
- // String returns the string representation
- func (s DescribeImageAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImageAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeImages.
- type DescribeImagesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Scopes the images by users with explicit launch permissions. Specify an AWS
- // account ID, self (the sender of the request), or all (public AMIs).
- ExecutableUsers []*string `locationName:"ExecutableBy" locationNameList:"ExecutableBy" type:"list"`
- // One or more filters.
- //
- // architecture - The image architecture (i386 | x86_64).
- //
- // block-device-mapping.delete-on-termination - A Boolean value that indicates
- // whether the Amazon EBS volume is deleted on instance termination.
- //
- // block-device-mapping.device-name - The device name for the EBS volume
- // (for example, /dev/sdh).
- //
- // block-device-mapping.snapshot-id - The ID of the snapshot used for the
- // EBS volume.
- //
- // block-device-mapping.volume-size - The volume size of the EBS volume,
- // in GiB.
- //
- // block-device-mapping.volume-type - The volume type of the EBS volume
- // (gp2 | io1 | st1 | sc1 | standard).
- //
- // description - The description of the image (provided during image creation).
- //
- // hypervisor - The hypervisor type (ovm | xen).
- //
- // image-id - The ID of the image.
- //
- // image-type - The image type (machine | kernel | ramdisk).
- //
- // is-public - A Boolean that indicates whether the image is public.
- //
- // kernel-id - The kernel ID.
- //
- // manifest-location - The location of the image manifest.
- //
- // name - The name of the AMI (provided during image creation).
- //
- // owner-alias - The AWS account alias (for example, amazon).
- //
- // owner-id - The AWS account ID of the image owner.
- //
- // platform - The platform. To only list Windows-based AMIs, use windows.
- //
- // product-code - The product code.
- //
- // product-code.type - The type of the product code (devpay | marketplace).
- //
- // ramdisk-id - The RAM disk ID.
- //
- // root-device-name - The name of the root device volume (for example, /dev/sda1).
- //
- // root-device-type - The type of the root device volume (ebs | instance-store).
- //
- // state - The state of the image (available | pending | failed).
- //
- // state-reason-code - The reason code for the state change.
- //
- // state-reason-message - The message for the state change.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // virtualization-type - The virtualization type (paravirtual | hvm).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more image IDs.
- //
- // Default: Describes all images available to you.
- ImageIds []*string `locationName:"ImageId" locationNameList:"ImageId" type:"list"`
- // Filters the images by the owner. Specify an AWS account ID, amazon (owner
- // is Amazon), aws-marketplace (owner is AWS Marketplace), self (owner is the
- // sender of the request). Omitting this option returns all images for which
- // you have launch permissions, regardless of ownership.
- Owners []*string `locationName:"Owner" locationNameList:"Owner" type:"list"`
- }
- // String returns the string representation
- func (s DescribeImagesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImagesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeImages.
- type DescribeImagesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more images.
- Images []*Image `locationName:"imagesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeImagesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImagesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeImportImageTasks.
- type DescribeImportImageTasksInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // Filter tasks using the task-state filter and one of the following values:
- // active, completed, deleting, deleted.
- Filters []*Filter `locationNameList:"Filter" type:"list"`
- // A list of import image task IDs.
- ImportTaskIds []*string `locationName:"ImportTaskId" locationNameList:"ImportTaskId" type:"list"`
- // The maximum number of results to return in a single call. To retrieve the
- // remaining results, make another call with the returned NextToken value.
- MaxResults *int64 `type:"integer"`
- // A token that indicates the next page of results.
- NextToken *string `type:"string"`
- }
- // String returns the string representation
- func (s DescribeImportImageTasksInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImportImageTasksInput) GoString() string {
- return s.String()
- }
- // Contains the output for DescribeImportImageTasks.
- type DescribeImportImageTasksOutput struct {
- _ struct{} `type:"structure"`
- // A list of zero or more import image tasks that are currently active or were
- // completed or canceled in the previous 7 days.
- ImportImageTasks []*ImportImageTask `locationName:"importImageTaskSet" locationNameList:"item" type:"list"`
- // The token to use to get the next page of results. This value is null when
- // there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeImportImageTasksOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImportImageTasksOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeImportSnapshotTasks.
- type DescribeImportSnapshotTasksInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more filters.
- Filters []*Filter `locationNameList:"Filter" type:"list"`
- // A list of import snapshot task IDs.
- ImportTaskIds []*string `locationName:"ImportTaskId" locationNameList:"ImportTaskId" type:"list"`
- // The maximum number of results to return in a single call. To retrieve the
- // remaining results, make another call with the returned NextToken value.
- MaxResults *int64 `type:"integer"`
- // A token that indicates the next page of results.
- NextToken *string `type:"string"`
- }
- // String returns the string representation
- func (s DescribeImportSnapshotTasksInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImportSnapshotTasksInput) GoString() string {
- return s.String()
- }
- // Contains the output for DescribeImportSnapshotTasks.
- type DescribeImportSnapshotTasksOutput struct {
- _ struct{} `type:"structure"`
- // A list of zero or more import snapshot tasks that are currently active or
- // were completed or canceled in the previous 7 days.
- ImportSnapshotTasks []*ImportSnapshotTask `locationName:"importSnapshotTaskSet" locationNameList:"item" type:"list"`
- // The token to use to get the next page of results. This value is null when
- // there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeImportSnapshotTasksOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeImportSnapshotTasksOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeInstanceAttribute.
- type DescribeInstanceAttributeInput struct {
- _ struct{} `type:"structure"`
- // The instance attribute.
- //
- // Note: The enaSupport attribute is not supported at this time.
- Attribute *string `locationName:"attribute" type:"string" required:"true" enum:"InstanceAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeInstanceAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInstanceAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeInstanceAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeInstanceAttributeInput"}
- if s.Attribute == nil {
- invalidParams.Add(request.NewErrParamRequired("Attribute"))
- }
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes an instance attribute.
- type DescribeInstanceAttributeOutput struct {
- _ struct{} `type:"structure"`
- // The block device mapping of the instance.
- BlockDeviceMappings []*InstanceBlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // If the value is true, you can't terminate the instance through the Amazon
- // EC2 console, CLI, or API; otherwise, you can.
- DisableApiTermination *AttributeBooleanValue `locationName:"disableApiTermination" type:"structure"`
- // Indicates whether the instance is optimized for EBS I/O.
- EbsOptimized *AttributeBooleanValue `locationName:"ebsOptimized" type:"structure"`
- // Indicates whether enhanced networking with ENA is enabled.
- EnaSupport *AttributeBooleanValue `locationName:"enaSupport" type:"structure"`
- // The security groups associated with the instance.
- Groups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // Indicates whether an instance stops or terminates when you initiate shutdown
- // from the instance (using the operating system command for system shutdown).
- InstanceInitiatedShutdownBehavior *AttributeValue `locationName:"instanceInitiatedShutdownBehavior" type:"structure"`
- // The instance type.
- InstanceType *AttributeValue `locationName:"instanceType" type:"structure"`
- // The kernel ID.
- KernelId *AttributeValue `locationName:"kernel" type:"structure"`
- // A list of product codes.
- ProductCodes []*ProductCode `locationName:"productCodes" locationNameList:"item" type:"list"`
- // The RAM disk ID.
- RamdiskId *AttributeValue `locationName:"ramdisk" type:"structure"`
- // The name of the root device (for example, /dev/sda1 or /dev/xvda).
- RootDeviceName *AttributeValue `locationName:"rootDeviceName" type:"structure"`
- // Indicates whether source/destination checking is enabled. A value of true
- // means checking is enabled, and false means checking is disabled. This value
- // must be false for a NAT instance to perform NAT.
- SourceDestCheck *AttributeBooleanValue `locationName:"sourceDestCheck" type:"structure"`
- // Indicates whether enhanced networking with the Intel 82599 Virtual Function
- // interface is enabled.
- SriovNetSupport *AttributeValue `locationName:"sriovNetSupport" type:"structure"`
- // The user data.
- UserData *AttributeValue `locationName:"userData" type:"structure"`
- }
- // String returns the string representation
- func (s DescribeInstanceAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInstanceAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeInstanceStatus.
- type DescribeInstanceStatusInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // availability-zone - The Availability Zone of the instance.
- //
- // event.code - The code for the scheduled event (instance-reboot | system-reboot
- // | system-maintenance | instance-retirement | instance-stop).
- //
- // event.description - A description of the event.
- //
- // event.not-after - The latest end time for the scheduled event (for example,
- // 2014-09-15T17:15:20.000Z).
- //
- // event.not-before - The earliest start time for the scheduled event (for
- // example, 2014-09-15T17:15:20.000Z).
- //
- // instance-state-code - The code for the instance state, as a 16-bit unsigned
- // integer. The high byte is an opaque internal value and should be ignored.
- // The low byte is set based on the state represented. The valid values are
- // 0 (pending), 16 (running), 32 (shutting-down), 48 (terminated), 64 (stopping),
- // and 80 (stopped).
- //
- // instance-state-name - The state of the instance (pending | running |
- // shutting-down | terminated | stopping | stopped).
- //
- // instance-status.reachability - Filters on instance status where the name
- // is reachability (passed | failed | initializing | insufficient-data).
- //
- // instance-status.status - The status of the instance (ok | impaired |
- // initializing | insufficient-data | not-applicable).
- //
- // system-status.reachability - Filters on system status where the name
- // is reachability (passed | failed | initializing | insufficient-data).
- //
- // system-status.status - The system status of the instance (ok | impaired
- // | initializing | insufficient-data | not-applicable).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // When true, includes the health status for all instances. When false, includes
- // the health status for running instances only.
- //
- // Default: false
- IncludeAllInstances *bool `locationName:"includeAllInstances" type:"boolean"`
- // One or more instance IDs.
- //
- // Default: Describes all your instances.
- //
- // Constraints: Maximum 100 explicitly specified instance IDs.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list"`
- // The maximum number of results to return in a single call. To retrieve the
- // remaining results, make another call with the returned NextToken value. This
- // value can be between 5 and 1000. You cannot specify this parameter and the
- // instance IDs parameter in the same call.
- MaxResults *int64 `type:"integer"`
- // The token to retrieve the next page of results.
- NextToken *string `type:"string"`
- }
- // String returns the string representation
- func (s DescribeInstanceStatusInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInstanceStatusInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeInstanceStatus.
- type DescribeInstanceStatusOutput struct {
- _ struct{} `type:"structure"`
- // One or more instance status descriptions.
- InstanceStatuses []*InstanceStatus `locationName:"instanceStatusSet" locationNameList:"item" type:"list"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeInstanceStatusOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInstanceStatusOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeInstances.
- type DescribeInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // affinity - The affinity setting for an instance running on a Dedicated
- // host (default | host).
- //
- // architecture - The instance architecture (i386 | x86_64).
- //
- // availability-zone - The Availability Zone of the instance.
- //
- // block-device-mapping.attach-time - The attach time for an EBS volume
- // mapped to the instance, for example, 2010-09-15T17:15:20.000Z.
- //
- // block-device-mapping.delete-on-termination - A Boolean that indicates
- // whether the EBS volume is deleted on instance termination.
- //
- // block-device-mapping.device-name - The device name for the EBS volume
- // (for example, /dev/sdh or xvdh).
- //
- // block-device-mapping.status - The status for the EBS volume (attaching
- // | attached | detaching | detached).
- //
- // block-device-mapping.volume-id - The volume ID of the EBS volume.
- //
- // client-token - The idempotency token you provided when you launched the
- // instance.
- //
- // dns-name - The public DNS name of the instance.
- //
- // group-id - The ID of the security group for the instance. EC2-Classic
- // only.
- //
- // group-name - The name of the security group for the instance. EC2-Classic
- // only.
- //
- // host-Id - The ID of the Dedicated host on which the instance is running,
- // if applicable.
- //
- // hypervisor - The hypervisor type of the instance (ovm | xen).
- //
- // iam-instance-profile.arn - The instance profile associated with the instance.
- // Specified as an ARN.
- //
- // image-id - The ID of the image used to launch the instance.
- //
- // instance-id - The ID of the instance.
- //
- // instance-lifecycle - Indicates whether this is a Spot Instance or a Scheduled
- // Instance (spot | scheduled).
- //
- // instance-state-code - The state of the instance, as a 16-bit unsigned
- // integer. The high byte is an opaque internal value and should be ignored.
- // The low byte is set based on the state represented. The valid values are:
- // 0 (pending), 16 (running), 32 (shutting-down), 48 (terminated), 64 (stopping),
- // and 80 (stopped).
- //
- // instance-state-name - The state of the instance (pending | running |
- // shutting-down | terminated | stopping | stopped).
- //
- // instance-type - The type of instance (for example, t2.micro).
- //
- // instance.group-id - The ID of the security group for the instance.
- //
- // instance.group-name - The name of the security group for the instance.
- //
- // ip-address - The public IP address of the instance.
- //
- // kernel-id - The kernel ID.
- //
- // key-name - The name of the key pair used when the instance was launched.
- //
- // launch-index - When launching multiple instances, this is the index for
- // the instance in the launch group (for example, 0, 1, 2, and so on).
- //
- // launch-time - The time when the instance was launched.
- //
- // monitoring-state - Indicates whether monitoring is enabled for the instance
- // (disabled | enabled).
- //
- // owner-id - The AWS account ID of the instance owner.
- //
- // placement-group-name - The name of the placement group for the instance.
- //
- // platform - The platform. Use windows if you have Windows instances; otherwise,
- // leave blank.
- //
- // private-dns-name - The private DNS name of the instance.
- //
- // private-ip-address - The private IP address of the instance.
- //
- // product-code - The product code associated with the AMI used to launch
- // the instance.
- //
- // product-code.type - The type of product code (devpay | marketplace).
- //
- // ramdisk-id - The RAM disk ID.
- //
- // reason - The reason for the current state of the instance (for example,
- // shows "User Initiated [date]" when you stop or terminate the instance). Similar
- // to the state-reason-code filter.
- //
- // requester-id - The ID of the entity that launched the instance on your
- // behalf (for example, AWS Management Console, Auto Scaling, and so on).
- //
- // reservation-id - The ID of the instance's reservation. A reservation
- // ID is created any time you launch an instance. A reservation ID has a one-to-one
- // relationship with an instance launch request, but can be associated with
- // more than one instance if you launch multiple instances using the same launch
- // request. For example, if you launch one instance, you'll get one reservation
- // ID. If you launch ten instances using the same launch request, you'll also
- // get one reservation ID.
- //
- // root-device-name - The name of the root device for the instance (for
- // example, /dev/sda1 or /dev/xvda).
- //
- // root-device-type - The type of root device that the instance uses (ebs
- // | instance-store).
- //
- // source-dest-check - Indicates whether the instance performs source/destination
- // checking. A value of true means that checking is enabled, and false means
- // checking is disabled. The value must be false for the instance to perform
- // network address translation (NAT) in your VPC.
- //
- // spot-instance-request-id - The ID of the Spot instance request.
- //
- // state-reason-code - The reason code for the state change.
- //
- // state-reason-message - A message that describes the state change.
- //
- // subnet-id - The ID of the subnet for the instance.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource,
- // where tag:key is the tag's key.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // tenancy - The tenancy of an instance (dedicated | default | host).
- //
- // virtualization-type - The virtualization type of the instance (paravirtual
- // | hvm).
- //
- // vpc-id - The ID of the VPC that the instance is running in.
- //
- // network-interface.description - The description of the network interface.
- //
- // network-interface.subnet-id - The ID of the subnet for the network interface.
- //
- // network-interface.vpc-id - The ID of the VPC for the network interface.
- //
- // network-interface.network-interface-id - The ID of the network interface.
- //
- // network-interface.owner-id - The ID of the owner of the network interface.
- //
- // network-interface.availability-zone - The Availability Zone for the network
- // interface.
- //
- // network-interface.requester-id - The requester ID for the network interface.
- //
- // network-interface.requester-managed - Indicates whether the network interface
- // is being managed by AWS.
- //
- // network-interface.status - The status of the network interface (available)
- // | in-use).
- //
- // network-interface.mac-address - The MAC address of the network interface.
- //
- // network-interface.private-dns-name - The private DNS name of the network
- // interface.
- //
- // network-interface.source-dest-check - Whether the network interface performs
- // source/destination checking. A value of true means checking is enabled, and
- // false means checking is disabled. The value must be false for the network
- // interface to perform network address translation (NAT) in your VPC.
- //
- // network-interface.group-id - The ID of a security group associated with
- // the network interface.
- //
- // network-interface.group-name - The name of a security group associated
- // with the network interface.
- //
- // network-interface.attachment.attachment-id - The ID of the interface
- // attachment.
- //
- // network-interface.attachment.instance-id - The ID of the instance to
- // which the network interface is attached.
- //
- // network-interface.attachment.instance-owner-id - The owner ID of the
- // instance to which the network interface is attached.
- //
- // network-interface.addresses.private-ip-address - The private IP address
- // associated with the network interface.
- //
- // network-interface.attachment.device-index - The device index to which
- // the network interface is attached.
- //
- // network-interface.attachment.status - The status of the attachment (attaching
- // | attached | detaching | detached).
- //
- // network-interface.attachment.attach-time - The time that the network
- // interface was attached to an instance.
- //
- // network-interface.attachment.delete-on-termination - Specifies whether
- // the attachment is deleted when an instance is terminated.
- //
- // network-interface.addresses.primary - Specifies whether the IP address
- // of the network interface is the primary private IP address.
- //
- // network-interface.addresses.association.public-ip - The ID of the association
- // of an Elastic IP address with a network interface.
- //
- // network-interface.addresses.association.ip-owner-id - The owner ID of
- // the private IP address associated with the network interface.
- //
- // association.public-ip - The address of the Elastic IP address bound to
- // the network interface.
- //
- // association.ip-owner-id - The owner of the Elastic IP address associated
- // with the network interface.
- //
- // association.allocation-id - The allocation ID returned when you allocated
- // the Elastic IP address for your network interface.
- //
- // association.association-id - The association ID returned when the network
- // interface was associated with an IP address.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more instance IDs.
- //
- // Default: Describes all your instances.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list"`
- // The maximum number of results to return in a single call. To retrieve the
- // remaining results, make another call with the returned NextToken value. This
- // value can be between 5 and 1000. You cannot specify this parameter and the
- // instance IDs parameter or tag filters in the same call.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token to request the next page of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInstancesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeInstances.
- type DescribeInstancesOutput struct {
- _ struct{} `type:"structure"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Zero or more reservations.
- Reservations []*Reservation `locationName:"reservationSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInstancesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeInternetGateways.
- type DescribeInternetGatewaysInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // attachment.state - The current state of the attachment between the gateway
- // and the VPC (available). Present only if a VPC is attached.
- //
- // attachment.vpc-id - The ID of an attached VPC.
- //
- // internet-gateway-id - The ID of the Internet gateway.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more Internet gateway IDs.
- //
- // Default: Describes all your Internet gateways.
- InternetGatewayIds []*string `locationName:"internetGatewayId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeInternetGatewaysInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInternetGatewaysInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeInternetGateways.
- type DescribeInternetGatewaysOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more Internet gateways.
- InternetGateways []*InternetGateway `locationName:"internetGatewaySet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeInternetGatewaysOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeInternetGatewaysOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeKeyPairs.
- type DescribeKeyPairsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // fingerprint - The fingerprint of the key pair.
- //
- // key-name - The name of the key pair.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more key pair names.
- //
- // Default: Describes all your key pairs.
- KeyNames []*string `locationName:"KeyName" locationNameList:"KeyName" type:"list"`
- }
- // String returns the string representation
- func (s DescribeKeyPairsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeKeyPairsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeKeyPairs.
- type DescribeKeyPairsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more key pairs.
- KeyPairs []*KeyPairInfo `locationName:"keySet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeKeyPairsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeKeyPairsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeMovingAddresses.
- type DescribeMovingAddressesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // moving-status - The status of the Elastic IP address (MovingToVpc | RestoringToClassic).
- Filters []*Filter `locationName:"filter" locationNameList:"Filter" type:"list"`
- // The maximum number of results to return for the request in a single page.
- // The remaining results of the initial request can be seen by sending another
- // request with the returned NextToken value. This value can be between 5 and
- // 1000; if MaxResults is given a value outside of this range, an error is returned.
- //
- // Default: If no value is provided, the default is 1000.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token to use to retrieve the next page of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- // One or more Elastic IP addresses.
- PublicIps []*string `locationName:"publicIp" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeMovingAddressesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeMovingAddressesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeMovingAddresses.
- type DescribeMovingAddressesOutput struct {
- _ struct{} `type:"structure"`
- // The status for each Elastic IP address.
- MovingAddressStatuses []*MovingAddressStatus `locationName:"movingAddressStatusSet" locationNameList:"item" type:"list"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeMovingAddressesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeMovingAddressesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeNatGateways.
- type DescribeNatGatewaysInput struct {
- _ struct{} `type:"structure"`
- // One or more filters.
- //
- // nat-gateway-id - The ID of the NAT gateway.
- //
- // state - The state of the NAT gateway (pending | failed | available |
- // deleting | deleted).
- //
- // subnet-id - The ID of the subnet in which the NAT gateway resides.
- //
- // vpc-id - The ID of the VPC in which the NAT gateway resides.
- Filter []*Filter `locationNameList:"Filter" type:"list"`
- // The maximum number of items to return for this request. The request returns
- // a token that you can specify in a subsequent call to get the next set of
- // results.
- //
- // Constraint: If the value specified is greater than 1000, we return only
- // 1000 items.
- MaxResults *int64 `type:"integer"`
- // One or more NAT gateway IDs.
- NatGatewayIds []*string `locationName:"NatGatewayId" locationNameList:"item" type:"list"`
- // The token to retrieve the next page of results.
- NextToken *string `type:"string"`
- }
- // String returns the string representation
- func (s DescribeNatGatewaysInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNatGatewaysInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeNatGateways.
- type DescribeNatGatewaysOutput struct {
- _ struct{} `type:"structure"`
- // Information about the NAT gateways.
- NatGateways []*NatGateway `locationName:"natGatewaySet" locationNameList:"item" type:"list"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeNatGatewaysOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNatGatewaysOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeNetworkAcls.
- type DescribeNetworkAclsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // association.association-id - The ID of an association ID for the ACL.
- //
- // association.network-acl-id - The ID of the network ACL involved in the
- // association.
- //
- // association.subnet-id - The ID of the subnet involved in the association.
- //
- // default - Indicates whether the ACL is the default network ACL for the
- // VPC.
- //
- // entry.cidr - The CIDR range specified in the entry.
- //
- // entry.egress - Indicates whether the entry applies to egress traffic.
- //
- // entry.icmp.code - The ICMP code specified in the entry, if any.
- //
- // entry.icmp.type - The ICMP type specified in the entry, if any.
- //
- // entry.port-range.from - The start of the port range specified in the
- // entry.
- //
- // entry.port-range.to - The end of the port range specified in the entry.
- //
- // entry.protocol - The protocol specified in the entry (tcp | udp | icmp
- // or a protocol number).
- //
- // entry.rule-action - Allows or denies the matching traffic (allow | deny).
- //
- // entry.rule-number - The number of an entry (in other words, rule) in
- // the ACL's set of entries.
- //
- // network-acl-id - The ID of the network ACL.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // vpc-id - The ID of the VPC for the network ACL.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more network ACL IDs.
- //
- // Default: Describes all your network ACLs.
- NetworkAclIds []*string `locationName:"NetworkAclId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeNetworkAclsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNetworkAclsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeNetworkAcls.
- type DescribeNetworkAclsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more network ACLs.
- NetworkAcls []*NetworkAcl `locationName:"networkAclSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeNetworkAclsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNetworkAclsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeNetworkInterfaceAttribute.
- type DescribeNetworkInterfaceAttributeInput struct {
- _ struct{} `type:"structure"`
- // The attribute of the network interface.
- Attribute *string `locationName:"attribute" type:"string" enum:"NetworkInterfaceAttribute"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeNetworkInterfaceAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNetworkInterfaceAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeNetworkInterfaceAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeNetworkInterfaceAttributeInput"}
- if s.NetworkInterfaceId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkInterfaceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeNetworkInterfaceAttribute.
- type DescribeNetworkInterfaceAttributeOutput struct {
- _ struct{} `type:"structure"`
- // The attachment (if any) of the network interface.
- Attachment *NetworkInterfaceAttachment `locationName:"attachment" type:"structure"`
- // The description of the network interface.
- Description *AttributeValue `locationName:"description" type:"structure"`
- // The security groups associated with the network interface.
- Groups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // Indicates whether source/destination checking is enabled.
- SourceDestCheck *AttributeBooleanValue `locationName:"sourceDestCheck" type:"structure"`
- }
- // String returns the string representation
- func (s DescribeNetworkInterfaceAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNetworkInterfaceAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeNetworkInterfaces.
- type DescribeNetworkInterfacesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // addresses.private-ip-address - The private IP addresses associated with
- // the network interface.
- //
- // addresses.primary - Whether the private IP address is the primary IP
- // address associated with the network interface.
- //
- // addresses.association.public-ip - The association ID returned when the
- // network interface was associated with the Elastic IP address.
- //
- // addresses.association.owner-id - The owner ID of the addresses associated
- // with the network interface.
- //
- // association.association-id - The association ID returned when the network
- // interface was associated with an IP address.
- //
- // association.allocation-id - The allocation ID returned when you allocated
- // the Elastic IP address for your network interface.
- //
- // association.ip-owner-id - The owner of the Elastic IP address associated
- // with the network interface.
- //
- // association.public-ip - The address of the Elastic IP address bound to
- // the network interface.
- //
- // association.public-dns-name - The public DNS name for the network interface.
- //
- // attachment.attachment-id - The ID of the interface attachment.
- //
- // attachment.attach.time - The time that the network interface was attached
- // to an instance.
- //
- // attachment.delete-on-termination - Indicates whether the attachment is
- // deleted when an instance is terminated.
- //
- // attachment.device-index - The device index to which the network interface
- // is attached.
- //
- // attachment.instance-id - The ID of the instance to which the network
- // interface is attached.
- //
- // attachment.instance-owner-id - The owner ID of the instance to which
- // the network interface is attached.
- //
- // attachment.nat-gateway-id - The ID of the NAT gateway to which the network
- // interface is attached.
- //
- // attachment.status - The status of the attachment (attaching | attached
- // | detaching | detached).
- //
- // availability-zone - The Availability Zone of the network interface.
- //
- // description - The description of the network interface.
- //
- // group-id - The ID of a security group associated with the network interface.
- //
- // group-name - The name of a security group associated with the network
- // interface.
- //
- // mac-address - The MAC address of the network interface.
- //
- // network-interface-id - The ID of the network interface.
- //
- // owner-id - The AWS account ID of the network interface owner.
- //
- // private-ip-address - The private IP address or addresses of the network
- // interface.
- //
- // private-dns-name - The private DNS name of the network interface.
- //
- // requester-id - The ID of the entity that launched the instance on your
- // behalf (for example, AWS Management Console, Auto Scaling, and so on).
- //
- // requester-managed - Indicates whether the network interface is being
- // managed by an AWS service (for example, AWS Management Console, Auto Scaling,
- // and so on).
- //
- // source-desk-check - Indicates whether the network interface performs
- // source/destination checking. A value of true means checking is enabled, and
- // false means checking is disabled. The value must be false for the network
- // interface to perform network address translation (NAT) in your VPC.
- //
- // status - The status of the network interface. If the network interface
- // is not attached to an instance, the status is available; if a network interface
- // is attached to an instance the status is in-use.
- //
- // subnet-id - The ID of the subnet for the network interface.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // vpc-id - The ID of the VPC for the network interface.
- Filters []*Filter `locationName:"filter" locationNameList:"Filter" type:"list"`
- // One or more network interface IDs.
- //
- // Default: Describes all your network interfaces.
- NetworkInterfaceIds []*string `locationName:"NetworkInterfaceId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeNetworkInterfacesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNetworkInterfacesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeNetworkInterfaces.
- type DescribeNetworkInterfacesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more network interfaces.
- NetworkInterfaces []*NetworkInterface `locationName:"networkInterfaceSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeNetworkInterfacesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeNetworkInterfacesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribePlacementGroups.
- type DescribePlacementGroupsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // group-name - The name of the placement group.
- //
- // state - The state of the placement group (pending | available | deleting
- // | deleted).
- //
- // strategy - The strategy of the placement group (cluster).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more placement group names.
- //
- // Default: Describes all your placement groups, or only those otherwise specified.
- GroupNames []*string `locationName:"groupName" type:"list"`
- }
- // String returns the string representation
- func (s DescribePlacementGroupsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribePlacementGroupsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribePlacementGroups.
- type DescribePlacementGroupsOutput struct {
- _ struct{} `type:"structure"`
- // One or more placement groups.
- PlacementGroups []*PlacementGroup `locationName:"placementGroupSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribePlacementGroupsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribePlacementGroupsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribePrefixLists.
- type DescribePrefixListsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more filters.
- //
- // prefix-list-id: The ID of a prefix list.
- //
- // prefix-list-name: The name of a prefix list.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The maximum number of items to return for this request. The request returns
- // a token that you can specify in a subsequent call to get the next set of
- // results.
- //
- // Constraint: If the value specified is greater than 1000, we return only
- // 1000 items.
- MaxResults *int64 `type:"integer"`
- // The token for the next set of items to return. (You received this token from
- // a prior call.)
- NextToken *string `type:"string"`
- // One or more prefix list IDs.
- PrefixListIds []*string `locationName:"PrefixListId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribePrefixListsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribePrefixListsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribePrefixLists.
- type DescribePrefixListsOutput struct {
- _ struct{} `type:"structure"`
- // The token to use when requesting the next set of items. If there are no additional
- // items to return, the string is empty.
- NextToken *string `locationName:"nextToken" type:"string"`
- // All available prefix lists.
- PrefixLists []*PrefixList `locationName:"prefixListSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribePrefixListsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribePrefixListsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeRegions.
- type DescribeRegionsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // endpoint - The endpoint of the region (for example, ec2.us-east-1.amazonaws.com).
- //
- // region-name - The name of the region (for example, us-east-1).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The names of one or more regions.
- RegionNames []*string `locationName:"RegionName" locationNameList:"RegionName" type:"list"`
- }
- // String returns the string representation
- func (s DescribeRegionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeRegionsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeRegions.
- type DescribeRegionsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more regions.
- Regions []*Region `locationName:"regionInfo" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeRegionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeRegionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeReservedInstances.
- type DescribeReservedInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // availability-zone - The Availability Zone where the Reserved Instance
- // can be used.
- //
- // duration - The duration of the Reserved Instance (one year or three years),
- // in seconds (31536000 | 94608000).
- //
- // end - The time when the Reserved Instance expires (for example, 2015-08-07T11:54:42.000Z).
- //
- // fixed-price - The purchase price of the Reserved Instance (for example,
- // 9800.0).
- //
- // instance-type - The instance type that is covered by the reservation.
- //
- // product-description - The Reserved Instance product platform description.
- // Instances that include (Amazon VPC) in the product platform description will
- // only be displayed to EC2-Classic account holders and are for use with Amazon
- // VPC (Linux/UNIX | Linux/UNIX (Amazon VPC) | SUSE Linux | SUSE Linux (Amazon
- // VPC) | Red Hat Enterprise Linux | Red Hat Enterprise Linux (Amazon VPC) |
- // Windows | Windows (Amazon VPC) | Windows with SQL Server Standard | Windows
- // with SQL Server Standard (Amazon VPC) | Windows with SQL Server Web | Windows
- // with SQL Server Web (Amazon VPC) | Windows with SQL Server Enterprise | Windows
- // with SQL Server Enterprise (Amazon VPC)).
- //
- // reserved-instances-id - The ID of the Reserved Instance.
- //
- // start - The time at which the Reserved Instance purchase request was
- // placed (for example, 2014-08-07T11:54:42.000Z).
- //
- // state - The state of the Reserved Instance (payment-pending | active
- // | payment-failed | retired).
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // usage-price - The usage price of the Reserved Instance, per hour (for
- // example, 0.84).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The Reserved Instance offering type. If you are using tools that predate
- // the 2011-11-01 API version, you only have access to the Medium Utilization
- // Reserved Instance offering type.
- OfferingType *string `locationName:"offeringType" type:"string" enum:"OfferingTypeValues"`
- // One or more Reserved Instance IDs.
- //
- // Default: Describes all your Reserved Instances, or only those otherwise
- // specified.
- ReservedInstancesIds []*string `locationName:"ReservedInstancesId" locationNameList:"ReservedInstancesId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesInput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeReservedInstancesListings.
- type DescribeReservedInstancesListingsInput struct {
- _ struct{} `type:"structure"`
- // One or more filters.
- //
- // reserved-instances-id - The ID of the Reserved Instances.
- //
- // reserved-instances-listing-id - The ID of the Reserved Instances listing.
- //
- // status - The status of the Reserved Instance listing (pending | active
- // | cancelled | closed).
- //
- // status-message - The reason for the status.
- Filters []*Filter `locationName:"filters" locationNameList:"Filter" type:"list"`
- // One or more Reserved Instance IDs.
- ReservedInstancesId *string `locationName:"reservedInstancesId" type:"string"`
- // One or more Reserved Instance listing IDs.
- ReservedInstancesListingId *string `locationName:"reservedInstancesListingId" type:"string"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesListingsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesListingsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeReservedInstancesListings.
- type DescribeReservedInstancesListingsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the Reserved Instance listing.
- ReservedInstancesListings []*ReservedInstancesListing `locationName:"reservedInstancesListingsSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesListingsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesListingsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeReservedInstancesModifications.
- type DescribeReservedInstancesModificationsInput struct {
- _ struct{} `type:"structure"`
- // One or more filters.
- //
- // client-token - The idempotency token for the modification request.
- //
- // create-date - The time when the modification request was created.
- //
- // effective-date - The time when the modification becomes effective.
- //
- // modification-result.reserved-instances-id - The ID for the Reserved Instances
- // created as part of the modification request. This ID is only available when
- // the status of the modification is fulfilled.
- //
- // modification-result.target-configuration.availability-zone - The Availability
- // Zone for the new Reserved Instances.
- //
- // modification-result.target-configuration.instance-count - The number
- // of new Reserved Instances.
- //
- // modification-result.target-configuration.instance-type - The instance
- // type of the new Reserved Instances.
- //
- // modification-result.target-configuration.platform - The network platform
- // of the new Reserved Instances (EC2-Classic | EC2-VPC).
- //
- // reserved-instances-id - The ID of the Reserved Instances modified.
- //
- // reserved-instances-modification-id - The ID of the modification request.
- //
- // status - The status of the Reserved Instances modification request (processing
- // | fulfilled | failed).
- //
- // status-message - The reason for the status.
- //
- // update-date - The time when the modification request was last updated.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The token to retrieve the next page of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- // IDs for the submitted modification request.
- ReservedInstancesModificationIds []*string `locationName:"ReservedInstancesModificationId" locationNameList:"ReservedInstancesModificationId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesModificationsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesModificationsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeReservedInstancesModifications.
- type DescribeReservedInstancesModificationsOutput struct {
- _ struct{} `type:"structure"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The Reserved Instance modification information.
- ReservedInstancesModifications []*ReservedInstancesModification `locationName:"reservedInstancesModificationsSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesModificationsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesModificationsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeReservedInstancesOfferings.
- type DescribeReservedInstancesOfferingsInput struct {
- _ struct{} `type:"structure"`
- // The Availability Zone in which the Reserved Instance can be used.
- AvailabilityZone *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // availability-zone - The Availability Zone where the Reserved Instance
- // can be used.
- //
- // duration - The duration of the Reserved Instance (for example, one year
- // or three years), in seconds (31536000 | 94608000).
- //
- // fixed-price - The purchase price of the Reserved Instance (for example,
- // 9800.0).
- //
- // instance-type - The instance type that is covered by the reservation.
- //
- // marketplace - Set to true to show only Reserved Instance Marketplace
- // offerings. When this filter is not used, which is the default behavior, all
- // offerings from both AWS and the Reserved Instance Marketplace are listed.
- //
- // product-description - The Reserved Instance product platform description.
- // Instances that include (Amazon VPC) in the product platform description will
- // only be displayed to EC2-Classic account holders and are for use with Amazon
- // VPC. (Linux/UNIX | Linux/UNIX (Amazon VPC) | SUSE Linux | SUSE Linux (Amazon
- // VPC) | Red Hat Enterprise Linux | Red Hat Enterprise Linux (Amazon VPC) |
- // Windows | Windows (Amazon VPC) | Windows with SQL Server Standard | Windows
- // with SQL Server Standard (Amazon VPC) | Windows with SQL Server Web | Windows
- // with SQL Server Web (Amazon VPC) | Windows with SQL Server Enterprise | Windows
- // with SQL Server Enterprise (Amazon VPC))
- //
- // reserved-instances-offering-id - The Reserved Instances offering ID.
- //
- // usage-price - The usage price of the Reserved Instance, per hour (for
- // example, 0.84).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // Include Reserved Instance Marketplace offerings in the response.
- IncludeMarketplace *bool `type:"boolean"`
- // The tenancy of the instances covered by the reservation. A Reserved Instance
- // with a tenancy of dedicated is applied to instances that run in a VPC on
- // single-tenant hardware (i.e., Dedicated Instances).
- //
- // Default: default
- InstanceTenancy *string `locationName:"instanceTenancy" type:"string" enum:"Tenancy"`
- // The instance type that the reservation will cover (for example, m1.small).
- // For more information, see Instance Types (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instance-types.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- InstanceType *string `type:"string" enum:"InstanceType"`
- // The maximum duration (in seconds) to filter when searching for offerings.
- //
- // Default: 94608000 (3 years)
- MaxDuration *int64 `type:"long"`
- // The maximum number of instances to filter when searching for offerings.
- //
- // Default: 20
- MaxInstanceCount *int64 `type:"integer"`
- // The maximum number of results to return for the request in a single page.
- // The remaining results of the initial request can be seen by sending another
- // request with the returned NextToken value. The maximum is 100.
- //
- // Default: 100
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The minimum duration (in seconds) to filter when searching for offerings.
- //
- // Default: 2592000 (1 month)
- MinDuration *int64 `type:"long"`
- // The token to retrieve the next page of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The Reserved Instance offering type. If you are using tools that predate
- // the 2011-11-01 API version, you only have access to the Medium Utilization
- // Reserved Instance offering type.
- OfferingType *string `locationName:"offeringType" type:"string" enum:"OfferingTypeValues"`
- // The Reserved Instance product platform description. Instances that include
- // (Amazon VPC) in the description are for use with Amazon VPC.
- ProductDescription *string `type:"string" enum:"RIProductDescription"`
- // One or more Reserved Instances offering IDs.
- ReservedInstancesOfferingIds []*string `locationName:"ReservedInstancesOfferingId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesOfferingsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesOfferingsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeReservedInstancesOfferings.
- type DescribeReservedInstancesOfferingsOutput struct {
- _ struct{} `type:"structure"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // A list of Reserved Instances offerings.
- ReservedInstancesOfferings []*ReservedInstancesOffering `locationName:"reservedInstancesOfferingsSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesOfferingsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesOfferingsOutput) GoString() string {
- return s.String()
- }
- // Contains the output for DescribeReservedInstances.
- type DescribeReservedInstancesOutput struct {
- _ struct{} `type:"structure"`
- // A list of Reserved Instances.
- ReservedInstances []*ReservedInstances `locationName:"reservedInstancesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeReservedInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeReservedInstancesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeRouteTables.
- type DescribeRouteTablesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // association.route-table-association-id - The ID of an association ID
- // for the route table.
- //
- // association.route-table-id - The ID of the route table involved in the
- // association.
- //
- // association.subnet-id - The ID of the subnet involved in the association.
- //
- // association.main - Indicates whether the route table is the main route
- // table for the VPC (true | false).
- //
- // route-table-id - The ID of the route table.
- //
- // route.destination-cidr-block - The CIDR range specified in a route in
- // the table.
- //
- // route.destination-prefix-list-id - The ID (prefix) of the AWS service
- // specified in a route in the table.
- //
- // route.gateway-id - The ID of a gateway specified in a route in the table.
- //
- // route.instance-id - The ID of an instance specified in a route in the
- // table.
- //
- // route.nat-gateway-id - The ID of a NAT gateway.
- //
- // route.origin - Describes how the route was created. CreateRouteTable
- // indicates that the route was automatically created when the route table was
- // created; CreateRoute indicates that the route was manually added to the route
- // table; EnableVgwRoutePropagation indicates that the route was propagated
- // by route propagation.
- //
- // route.state - The state of a route in the route table (active | blackhole).
- // The blackhole state indicates that the route's target isn't available (for
- // example, the specified gateway isn't attached to the VPC, the specified NAT
- // instance has been terminated, and so on).
- //
- // route.vpc-peering-connection-id - The ID of a VPC peering connection
- // specified in a route in the table.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // vpc-id - The ID of the VPC for the route table.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more route table IDs.
- //
- // Default: Describes all your route tables.
- RouteTableIds []*string `locationName:"RouteTableId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeRouteTablesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeRouteTablesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeRouteTables.
- type DescribeRouteTablesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more route tables.
- RouteTables []*RouteTable `locationName:"routeTableSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeRouteTablesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeRouteTablesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeScheduledInstanceAvailability.
- type DescribeScheduledInstanceAvailabilityInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more filters.
- //
- // availability-zone - The Availability Zone (for example, us-west-2a).
- //
- // instance-type - The instance type (for example, c4.large).
- //
- // network-platform - The network platform (EC2-Classic or EC2-VPC).
- //
- // platform - The platform (Linux/UNIX or Windows).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The time period for the first schedule to start.
- FirstSlotStartTimeRange *SlotDateTimeRangeRequest `type:"structure" required:"true"`
- // The maximum number of results to return in a single call. This value can
- // be between 5 and 300. The default value is 300. To retrieve the remaining
- // results, make another call with the returned NextToken value.
- MaxResults *int64 `type:"integer"`
- // The maximum available duration, in hours. This value must be greater than
- // MinSlotDurationInHours and less than 1,720.
- MaxSlotDurationInHours *int64 `type:"integer"`
- // The minimum available duration, in hours. The minimum required duration is
- // 1,200 hours per year. For example, the minimum daily schedule is 4 hours,
- // the minimum weekly schedule is 24 hours, and the minimum monthly schedule
- // is 100 hours.
- MinSlotDurationInHours *int64 `type:"integer"`
- // The token for the next set of results.
- NextToken *string `type:"string"`
- // The schedule recurrence.
- Recurrence *ScheduledInstanceRecurrenceRequest `type:"structure" required:"true"`
- }
- // String returns the string representation
- func (s DescribeScheduledInstanceAvailabilityInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeScheduledInstanceAvailabilityInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeScheduledInstanceAvailabilityInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeScheduledInstanceAvailabilityInput"}
- if s.FirstSlotStartTimeRange == nil {
- invalidParams.Add(request.NewErrParamRequired("FirstSlotStartTimeRange"))
- }
- if s.Recurrence == nil {
- invalidParams.Add(request.NewErrParamRequired("Recurrence"))
- }
- if s.FirstSlotStartTimeRange != nil {
- if err := s.FirstSlotStartTimeRange.Validate(); err != nil {
- invalidParams.AddNested("FirstSlotStartTimeRange", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeScheduledInstanceAvailability.
- type DescribeScheduledInstanceAvailabilityOutput struct {
- _ struct{} `type:"structure"`
- // The token required to retrieve the next set of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Information about the available Scheduled Instances.
- ScheduledInstanceAvailabilitySet []*ScheduledInstanceAvailability `locationName:"scheduledInstanceAvailabilitySet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeScheduledInstanceAvailabilityOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeScheduledInstanceAvailabilityOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeScheduledInstances.
- type DescribeScheduledInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more filters.
- //
- // availability-zone - The Availability Zone (for example, us-west-2a).
- //
- // instance-type - The instance type (for example, c4.large).
- //
- // network-platform - The network platform (EC2-Classic or EC2-VPC).
- //
- // platform - The platform (Linux/UNIX or Windows).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The maximum number of results to return in a single call. This value can
- // be between 5 and 300. The default value is 100. To retrieve the remaining
- // results, make another call with the returned NextToken value.
- MaxResults *int64 `type:"integer"`
- // The token for the next set of results.
- NextToken *string `type:"string"`
- // One or more Scheduled Instance IDs.
- ScheduledInstanceIds []*string `locationName:"ScheduledInstanceId" locationNameList:"ScheduledInstanceId" type:"list"`
- // The time period for the first schedule to start.
- SlotStartTimeRange *SlotStartTimeRangeRequest `type:"structure"`
- }
- // String returns the string representation
- func (s DescribeScheduledInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeScheduledInstancesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeScheduledInstances.
- type DescribeScheduledInstancesOutput struct {
- _ struct{} `type:"structure"`
- // The token required to retrieve the next set of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Information about the Scheduled Instances.
- ScheduledInstanceSet []*ScheduledInstance `locationName:"scheduledInstanceSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeScheduledInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeScheduledInstancesOutput) GoString() string {
- return s.String()
- }
- type DescribeSecurityGroupReferencesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the operation, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more security group IDs in your account.
- GroupId []*string `locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s DescribeSecurityGroupReferencesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSecurityGroupReferencesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeSecurityGroupReferencesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeSecurityGroupReferencesInput"}
- if s.GroupId == nil {
- invalidParams.Add(request.NewErrParamRequired("GroupId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DescribeSecurityGroupReferencesOutput struct {
- _ struct{} `type:"structure"`
- // Information about the VPCs with the referencing security groups.
- SecurityGroupReferenceSet []*SecurityGroupReference `locationName:"securityGroupReferenceSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSecurityGroupReferencesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSecurityGroupReferencesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSecurityGroups.
- type DescribeSecurityGroupsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters. If using multiple filters for rules, the results include
- // security groups for which any combination of rules - not necessarily a single
- // rule - match all filters.
- //
- // description - The description of the security group.
- //
- // egress.ip-permission.prefix-list-id - The ID (prefix) of the AWS service
- // to which the security group allows access.
- //
- // group-id - The ID of the security group.
- //
- // group-name - The name of the security group.
- //
- // ip-permission.cidr - A CIDR range that has been granted permission.
- //
- // ip-permission.from-port - The start of port range for the TCP and UDP
- // protocols, or an ICMP type number.
- //
- // ip-permission.group-id - The ID of a security group that has been granted
- // permission.
- //
- // ip-permission.group-name - The name of a security group that has been
- // granted permission.
- //
- // ip-permission.protocol - The IP protocol for the permission (tcp | udp
- // | icmp or a protocol number).
- //
- // ip-permission.to-port - The end of port range for the TCP and UDP protocols,
- // or an ICMP code.
- //
- // ip-permission.user-id - The ID of an AWS account that has been granted
- // permission.
- //
- // owner-id - The AWS account ID of the owner of the security group.
- //
- // tag-key - The key of a tag assigned to the security group.
- //
- // tag-value - The value of a tag assigned to the security group.
- //
- // vpc-id - The ID of the VPC specified when the security group was created.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more security group IDs. Required for security groups in a nondefault
- // VPC.
- //
- // Default: Describes all your security groups.
- GroupIds []*string `locationName:"GroupId" locationNameList:"groupId" type:"list"`
- // [EC2-Classic and default VPC only] One or more security group names. You
- // can specify either the security group name or the security group ID. For
- // security groups in a nondefault VPC, use the group-name filter to describe
- // security groups by name.
- //
- // Default: Describes all your security groups.
- GroupNames []*string `locationName:"GroupName" locationNameList:"GroupName" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSecurityGroupsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSecurityGroupsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeSecurityGroups.
- type DescribeSecurityGroupsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more security groups.
- SecurityGroups []*SecurityGroup `locationName:"securityGroupInfo" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSecurityGroupsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSecurityGroupsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSnapshotAttribute.
- type DescribeSnapshotAttributeInput struct {
- _ struct{} `type:"structure"`
- // The snapshot attribute you would like to view.
- Attribute *string `type:"string" required:"true" enum:"SnapshotAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the EBS snapshot.
- SnapshotId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeSnapshotAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSnapshotAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeSnapshotAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeSnapshotAttributeInput"}
- if s.Attribute == nil {
- invalidParams.Add(request.NewErrParamRequired("Attribute"))
- }
- if s.SnapshotId == nil {
- invalidParams.Add(request.NewErrParamRequired("SnapshotId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeSnapshotAttribute.
- type DescribeSnapshotAttributeOutput struct {
- _ struct{} `type:"structure"`
- // A list of permissions for creating volumes from the snapshot.
- CreateVolumePermissions []*CreateVolumePermission `locationName:"createVolumePermission" locationNameList:"item" type:"list"`
- // A list of product codes.
- ProductCodes []*ProductCode `locationName:"productCodes" locationNameList:"item" type:"list"`
- // The ID of the EBS snapshot.
- SnapshotId *string `locationName:"snapshotId" type:"string"`
- }
- // String returns the string representation
- func (s DescribeSnapshotAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSnapshotAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSnapshots.
- type DescribeSnapshotsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // description - A description of the snapshot.
- //
- // owner-alias - The AWS account alias (for example, amazon) that owns the
- // snapshot.
- //
- // owner-id - The ID of the AWS account that owns the snapshot.
- //
- // progress - The progress of the snapshot, as a percentage (for example,
- // 80%).
- //
- // snapshot-id - The snapshot ID.
- //
- // start-time - The time stamp when the snapshot was initiated.
- //
- // status - The status of the snapshot (pending | completed | error).
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // volume-id - The ID of the volume the snapshot is for.
- //
- // volume-size - The size of the volume, in GiB.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The maximum number of snapshot results returned by DescribeSnapshots in paginated
- // output. When this parameter is used, DescribeSnapshots only returns MaxResults
- // results in a single page along with a NextToken response element. The remaining
- // results of the initial request can be seen by sending another DescribeSnapshots
- // request with the returned NextToken value. This value can be between 5 and
- // 1000; if MaxResults is given a value larger than 1000, only 1000 results
- // are returned. If this parameter is not used, then DescribeSnapshots returns
- // all results. You cannot specify this parameter and the snapshot IDs parameter
- // in the same request.
- MaxResults *int64 `type:"integer"`
- // The NextToken value returned from a previous paginated DescribeSnapshots
- // request where MaxResults was used and the results exceeded the value of that
- // parameter. Pagination continues from the end of the previous results that
- // returned the NextToken value. This value is null when there are no more results
- // to return.
- NextToken *string `type:"string"`
- // Returns the snapshots owned by the specified owner. Multiple owners can be
- // specified.
- OwnerIds []*string `locationName:"Owner" locationNameList:"Owner" type:"list"`
- // One or more AWS accounts IDs that can create volumes from the snapshot.
- RestorableByUserIds []*string `locationName:"RestorableBy" type:"list"`
- // One or more snapshot IDs.
- //
- // Default: Describes snapshots for which you have launch permissions.
- SnapshotIds []*string `locationName:"SnapshotId" locationNameList:"SnapshotId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSnapshotsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSnapshotsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeSnapshots.
- type DescribeSnapshotsOutput struct {
- _ struct{} `type:"structure"`
- // The NextToken value to include in a future DescribeSnapshots request. When
- // the results of a DescribeSnapshots request exceed MaxResults, this value
- // can be used to retrieve the next page of results. This value is null when
- // there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Information about the snapshots.
- Snapshots []*Snapshot `locationName:"snapshotSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSnapshotsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSnapshotsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSpotDatafeedSubscription.
- type DescribeSpotDatafeedSubscriptionInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s DescribeSpotDatafeedSubscriptionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotDatafeedSubscriptionInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeSpotDatafeedSubscription.
- type DescribeSpotDatafeedSubscriptionOutput struct {
- _ struct{} `type:"structure"`
- // The Spot instance data feed subscription.
- SpotDatafeedSubscription *SpotDatafeedSubscription `locationName:"spotDatafeedSubscription" type:"structure"`
- }
- // String returns the string representation
- func (s DescribeSpotDatafeedSubscriptionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotDatafeedSubscriptionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSpotFleetInstances.
- type DescribeSpotFleetInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The maximum number of results to return in a single call. Specify a value
- // between 1 and 1000. The default value is 1000. To retrieve the remaining
- // results, make another call with the returned NextToken value.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token for the next set of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeSpotFleetInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotFleetInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeSpotFleetInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeSpotFleetInstancesInput"}
- if s.SpotFleetRequestId == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotFleetRequestId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeSpotFleetInstances.
- type DescribeSpotFleetInstancesOutput struct {
- _ struct{} `type:"structure"`
- // The running instances. Note that this list is refreshed periodically and
- // might be out of date.
- ActiveInstances []*ActiveInstance `locationName:"activeInstanceSet" locationNameList:"item" type:"list" required:"true"`
- // The token required to retrieve the next set of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeSpotFleetInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotFleetInstancesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSpotFleetRequestHistory.
- type DescribeSpotFleetRequestHistoryInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The type of events to describe. By default, all events are described.
- EventType *string `locationName:"eventType" type:"string" enum:"EventType"`
- // The maximum number of results to return in a single call. Specify a value
- // between 1 and 1000. The default value is 1000. To retrieve the remaining
- // results, make another call with the returned NextToken value.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token for the next set of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- // The starting date and time for the events, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- StartTime *time.Time `locationName:"startTime" type:"timestamp" timestampFormat:"iso8601" required:"true"`
- }
- // String returns the string representation
- func (s DescribeSpotFleetRequestHistoryInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotFleetRequestHistoryInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeSpotFleetRequestHistoryInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeSpotFleetRequestHistoryInput"}
- if s.SpotFleetRequestId == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotFleetRequestId"))
- }
- if s.StartTime == nil {
- invalidParams.Add(request.NewErrParamRequired("StartTime"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeSpotFleetRequestHistory.
- type DescribeSpotFleetRequestHistoryOutput struct {
- _ struct{} `type:"structure"`
- // Information about the events in the history of the Spot fleet request.
- HistoryRecords []*HistoryRecord `locationName:"historyRecordSet" locationNameList:"item" type:"list" required:"true"`
- // The last date and time for the events, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- // All records up to this time were retrieved.
- //
- // If nextToken indicates that there are more results, this value is not present.
- LastEvaluatedTime *time.Time `locationName:"lastEvaluatedTime" type:"timestamp" timestampFormat:"iso8601" required:"true"`
- // The token required to retrieve the next set of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- // The starting date and time for the events, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- StartTime *time.Time `locationName:"startTime" type:"timestamp" timestampFormat:"iso8601" required:"true"`
- }
- // String returns the string representation
- func (s DescribeSpotFleetRequestHistoryOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotFleetRequestHistoryOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSpotFleetRequests.
- type DescribeSpotFleetRequestsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The maximum number of results to return in a single call. Specify a value
- // between 1 and 1000. The default value is 1000. To retrieve the remaining
- // results, make another call with the returned NextToken value.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token for the next set of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The IDs of the Spot fleet requests.
- SpotFleetRequestIds []*string `locationName:"spotFleetRequestId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSpotFleetRequestsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotFleetRequestsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeSpotFleetRequests.
- type DescribeSpotFleetRequestsOutput struct {
- _ struct{} `type:"structure"`
- // The token required to retrieve the next set of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Information about the configuration of your Spot fleet.
- SpotFleetRequestConfigs []*SpotFleetRequestConfig `locationName:"spotFleetRequestConfigSet" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s DescribeSpotFleetRequestsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotFleetRequestsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSpotInstanceRequests.
- type DescribeSpotInstanceRequestsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // availability-zone-group - The Availability Zone group.
- //
- // create-time - The time stamp when the Spot instance request was created.
- //
- // fault-code - The fault code related to the request.
- //
- // fault-message - The fault message related to the request.
- //
- // instance-id - The ID of the instance that fulfilled the request.
- //
- // launch-group - The Spot instance launch group.
- //
- // launch.block-device-mapping.delete-on-termination - Indicates whether
- // the Amazon EBS volume is deleted on instance termination.
- //
- // launch.block-device-mapping.device-name - The device name for the Amazon
- // EBS volume (for example, /dev/sdh).
- //
- // launch.block-device-mapping.snapshot-id - The ID of the snapshot used
- // for the Amazon EBS volume.
- //
- // launch.block-device-mapping.volume-size - The size of the Amazon EBS
- // volume, in GiB.
- //
- // launch.block-device-mapping.volume-type - The type of the Amazon EBS
- // volume: gp2 for General Purpose SSD, io1 for Provisioned IOPS SSD, st1 for
- // Throughput Optimized HDD, sc1for Cold HDD, or standard for Magnetic.
- //
- // launch.group-id - The security group for the instance.
- //
- // launch.image-id - The ID of the AMI.
- //
- // launch.instance-type - The type of instance (for example, m3.medium).
- //
- // launch.kernel-id - The kernel ID.
- //
- // launch.key-name - The name of the key pair the instance launched with.
- //
- // launch.monitoring-enabled - Whether monitoring is enabled for the Spot
- // instance.
- //
- // launch.ramdisk-id - The RAM disk ID.
- //
- // network-interface.network-interface-id - The ID of the network interface.
- //
- // network-interface.device-index - The index of the device for the network
- // interface attachment on the instance.
- //
- // network-interface.subnet-id - The ID of the subnet for the instance.
- //
- // network-interface.description - A description of the network interface.
- //
- // network-interface.private-ip-address - The primary private IP address
- // of the network interface.
- //
- // network-interface.delete-on-termination - Indicates whether the network
- // interface is deleted when the instance is terminated.
- //
- // network-interface.group-id - The ID of the security group associated
- // with the network interface.
- //
- // network-interface.group-name - The name of the security group associated
- // with the network interface.
- //
- // network-interface.addresses.primary - Indicates whether the IP address
- // is the primary private IP address.
- //
- // product-description - The product description associated with the instance
- // (Linux/UNIX | Windows).
- //
- // spot-instance-request-id - The Spot instance request ID.
- //
- // spot-price - The maximum hourly price for any Spot instance launched
- // to fulfill the request.
- //
- // state - The state of the Spot instance request (open | active | closed
- // | cancelled | failed). Spot bid status information can help you track your
- // Amazon EC2 Spot instance requests. For more information, see Spot Bid Status
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-bid-status.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // status-code - The short code describing the most recent evaluation of
- // your Spot instance request.
- //
- // status-message - The message explaining the status of the Spot instance
- // request.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // type - The type of Spot instance request (one-time | persistent).
- //
- // launched-availability-zone - The Availability Zone in which the bid is
- // launched.
- //
- // valid-from - The start date of the request.
- //
- // valid-until - The end date of the request.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more Spot instance request IDs.
- SpotInstanceRequestIds []*string `locationName:"SpotInstanceRequestId" locationNameList:"SpotInstanceRequestId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSpotInstanceRequestsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotInstanceRequestsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeSpotInstanceRequests.
- type DescribeSpotInstanceRequestsOutput struct {
- _ struct{} `type:"structure"`
- // One or more Spot instance requests.
- SpotInstanceRequests []*SpotInstanceRequest `locationName:"spotInstanceRequestSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSpotInstanceRequestsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotInstanceRequestsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSpotPriceHistory.
- type DescribeSpotPriceHistoryInput struct {
- _ struct{} `type:"structure"`
- // Filters the results by the specified Availability Zone.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The date and time, up to the current date, from which to stop retrieving
- // the price history data, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- EndTime *time.Time `locationName:"endTime" type:"timestamp" timestampFormat:"iso8601"`
- // One or more filters.
- //
- // availability-zone - The Availability Zone for which prices should be
- // returned.
- //
- // instance-type - The type of instance (for example, m3.medium).
- //
- // product-description - The product description for the Spot price (Linux/UNIX
- // | SUSE Linux | Windows | Linux/UNIX (Amazon VPC) | SUSE Linux (Amazon VPC)
- // | Windows (Amazon VPC)).
- //
- // spot-price - The Spot price. The value must match exactly (or use wildcards;
- // greater than or less than comparison is not supported).
- //
- // timestamp - The timestamp of the Spot price history, in UTC format (for
- // example, YYYY-MM-DDTHH:MM:SSZ). You can use wildcards (* and ?). Greater
- // than or less than comparison is not supported.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // Filters the results by the specified instance types.
- InstanceTypes []*string `locationName:"InstanceType" type:"list"`
- // The maximum number of results to return in a single call. Specify a value
- // between 1 and 1000. The default value is 1000. To retrieve the remaining
- // results, make another call with the returned NextToken value.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token for the next set of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Filters the results by the specified basic product descriptions.
- ProductDescriptions []*string `locationName:"ProductDescription" type:"list"`
- // The date and time, up to the past 90 days, from which to start retrieving
- // the price history data, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- StartTime *time.Time `locationName:"startTime" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s DescribeSpotPriceHistoryInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotPriceHistoryInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeSpotPriceHistory.
- type DescribeSpotPriceHistoryOutput struct {
- _ struct{} `type:"structure"`
- // The token required to retrieve the next set of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // The historical Spot prices.
- SpotPriceHistory []*SpotPrice `locationName:"spotPriceHistorySet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSpotPriceHistoryOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSpotPriceHistoryOutput) GoString() string {
- return s.String()
- }
- type DescribeStaleSecurityGroupsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the operation, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The maximum number of items to return for this request. The request returns
- // a token that you can specify in a subsequent call to get the next set of
- // results.
- MaxResults *int64 `min:"5" type:"integer"`
- // The token for the next set of items to return. (You received this token from
- // a prior call.)
- NextToken *string `min:"1" type:"string"`
- // The ID of the VPC.
- VpcId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeStaleSecurityGroupsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeStaleSecurityGroupsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeStaleSecurityGroupsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeStaleSecurityGroupsInput"}
- if s.MaxResults != nil && *s.MaxResults < 5 {
- invalidParams.Add(request.NewErrParamMinValue("MaxResults", 5))
- }
- if s.NextToken != nil && len(*s.NextToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextToken", 1))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DescribeStaleSecurityGroupsOutput struct {
- _ struct{} `type:"structure"`
- // The token to use when requesting the next set of items. If there are no additional
- // items to return, the string is empty.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Information about the stale security groups.
- StaleSecurityGroupSet []*StaleSecurityGroup `locationName:"staleSecurityGroupSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeStaleSecurityGroupsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeStaleSecurityGroupsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeSubnets.
- type DescribeSubnetsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // availabilityZone - The Availability Zone for the subnet. You can also
- // use availability-zone as the filter name.
- //
- // available-ip-address-count - The number of IP addresses in the subnet
- // that are available.
- //
- // cidrBlock - The CIDR block of the subnet. The CIDR block you specify
- // must exactly match the subnet's CIDR block for information to be returned
- // for the subnet. You can also use cidr or cidr-block as the filter names.
- //
- // defaultForAz - Indicates whether this is the default subnet for the Availability
- // Zone. You can also use default-for-az as the filter name.
- //
- // state - The state of the subnet (pending | available).
- //
- // subnet-id - The ID of the subnet.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // vpc-id - The ID of the VPC for the subnet.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more subnet IDs.
- //
- // Default: Describes all your subnets.
- SubnetIds []*string `locationName:"SubnetId" locationNameList:"SubnetId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSubnetsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSubnetsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeSubnets.
- type DescribeSubnetsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more subnets.
- Subnets []*Subnet `locationName:"subnetSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeSubnetsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeSubnetsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeTags.
- type DescribeTagsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // key - The tag key.
- //
- // resource-id - The resource ID.
- //
- // resource-type - The resource type (customer-gateway | dhcp-options |
- // image | instance | internet-gateway | network-acl | network-interface | reserved-instances
- // | route-table | security-group | snapshot | spot-instances-request | subnet
- // | volume | vpc | vpn-connection | vpn-gateway).
- //
- // value - The tag value.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The maximum number of results to return in a single call. This value can
- // be between 5 and 1000. To retrieve the remaining results, make another call
- // with the returned NextToken value.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The token to retrieve the next page of results.
- NextToken *string `locationName:"nextToken" type:"string"`
- }
- // String returns the string representation
- func (s DescribeTagsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeTagsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeTags.
- type DescribeTagsOutput struct {
- _ struct{} `type:"structure"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return..
- NextToken *string `locationName:"nextToken" type:"string"`
- // A list of tags.
- Tags []*TagDescription `locationName:"tagSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeTagsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeTagsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVolumeAttribute.
- type DescribeVolumeAttributeInput struct {
- _ struct{} `type:"structure"`
- // The instance attribute.
- Attribute *string `type:"string" enum:"VolumeAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the volume.
- VolumeId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeVolumeAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVolumeAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeVolumeAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeVolumeAttributeInput"}
- if s.VolumeId == nil {
- invalidParams.Add(request.NewErrParamRequired("VolumeId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeVolumeAttribute.
- type DescribeVolumeAttributeOutput struct {
- _ struct{} `type:"structure"`
- // The state of autoEnableIO attribute.
- AutoEnableIO *AttributeBooleanValue `locationName:"autoEnableIO" type:"structure"`
- // A list of product codes.
- ProductCodes []*ProductCode `locationName:"productCodes" locationNameList:"item" type:"list"`
- // The ID of the volume.
- VolumeId *string `locationName:"volumeId" type:"string"`
- }
- // String returns the string representation
- func (s DescribeVolumeAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVolumeAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVolumeStatus.
- type DescribeVolumeStatusInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // action.code - The action code for the event (for example, enable-volume-io).
- //
- // action.description - A description of the action.
- //
- // action.event-id - The event ID associated with the action.
- //
- // availability-zone - The Availability Zone of the instance.
- //
- // event.description - A description of the event.
- //
- // event.event-id - The event ID.
- //
- // event.event-type - The event type (for io-enabled: passed | failed; for
- // io-performance: io-performance:degraded | io-performance:severely-degraded
- // | io-performance:stalled).
- //
- // event.not-after - The latest end time for the event.
- //
- // event.not-before - The earliest start time for the event.
- //
- // volume-status.details-name - The cause for volume-status.status (io-enabled
- // | io-performance).
- //
- // volume-status.details-status - The status of volume-status.details-name
- // (for io-enabled: passed | failed; for io-performance: normal | degraded |
- // severely-degraded | stalled).
- //
- // volume-status.status - The status of the volume (ok | impaired | warning
- // | insufficient-data).
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The maximum number of volume results returned by DescribeVolumeStatus in
- // paginated output. When this parameter is used, the request only returns MaxResults
- // results in a single page along with a NextToken response element. The remaining
- // results of the initial request can be seen by sending another request with
- // the returned NextToken value. This value can be between 5 and 1000; if MaxResults
- // is given a value larger than 1000, only 1000 results are returned. If this
- // parameter is not used, then DescribeVolumeStatus returns all results. You
- // cannot specify this parameter and the volume IDs parameter in the same request.
- MaxResults *int64 `type:"integer"`
- // The NextToken value to include in a future DescribeVolumeStatus request.
- // When the results of the request exceed MaxResults, this value can be used
- // to retrieve the next page of results. This value is null when there are no
- // more results to return.
- NextToken *string `type:"string"`
- // One or more volume IDs.
- //
- // Default: Describes all your volumes.
- VolumeIds []*string `locationName:"VolumeId" locationNameList:"VolumeId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVolumeStatusInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVolumeStatusInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVolumeStatus.
- type DescribeVolumeStatusOutput struct {
- _ struct{} `type:"structure"`
- // The token to use to retrieve the next page of results. This value is null
- // when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // A list of volumes.
- VolumeStatuses []*VolumeStatusItem `locationName:"volumeStatusSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVolumeStatusOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVolumeStatusOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVolumes.
- type DescribeVolumesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // attachment.attach-time - The time stamp when the attachment initiated.
- //
- // attachment.delete-on-termination - Whether the volume is deleted on instance
- // termination.
- //
- // attachment.device - The device name that is exposed to the instance (for
- // example, /dev/sda1).
- //
- // attachment.instance-id - The ID of the instance the volume is attached
- // to.
- //
- // attachment.status - The attachment state (attaching | attached | detaching
- // | detached).
- //
- // availability-zone - The Availability Zone in which the volume was created.
- //
- // create-time - The time stamp when the volume was created.
- //
- // encrypted - The encryption status of the volume.
- //
- // size - The size of the volume, in GiB.
- //
- // snapshot-id - The snapshot from which the volume was created.
- //
- // status - The status of the volume (creating | available | in-use | deleting
- // | deleted | error).
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // volume-id - The volume ID.
- //
- // volume-type - The Amazon EBS volume type. This can be gp2 for General
- // Purpose SSD, io1 for Provisioned IOPS SSD, st1 for Throughput Optimized HDD,
- // sc1 for Cold HDD, or standard for Magnetic volumes.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The maximum number of volume results returned by DescribeVolumes in paginated
- // output. When this parameter is used, DescribeVolumes only returns MaxResults
- // results in a single page along with a NextToken response element. The remaining
- // results of the initial request can be seen by sending another DescribeVolumes
- // request with the returned NextToken value. This value can be between 5 and
- // 1000; if MaxResults is given a value larger than 1000, only 1000 results
- // are returned. If this parameter is not used, then DescribeVolumes returns
- // all results. You cannot specify this parameter and the volume IDs parameter
- // in the same request.
- MaxResults *int64 `locationName:"maxResults" type:"integer"`
- // The NextToken value returned from a previous paginated DescribeVolumes request
- // where MaxResults was used and the results exceeded the value of that parameter.
- // Pagination continues from the end of the previous results that returned the
- // NextToken value. This value is null when there are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // One or more volume IDs.
- VolumeIds []*string `locationName:"VolumeId" locationNameList:"VolumeId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVolumesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVolumesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVolumes.
- type DescribeVolumesOutput struct {
- _ struct{} `type:"structure"`
- // The NextToken value to include in a future DescribeVolumes request. When
- // the results of a DescribeVolumes request exceed MaxResults, this value can
- // be used to retrieve the next page of results. This value is null when there
- // are no more results to return.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Information about the volumes.
- Volumes []*Volume `locationName:"volumeSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVolumesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVolumesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpcAttribute.
- type DescribeVpcAttributeInput struct {
- _ struct{} `type:"structure"`
- // The VPC attribute.
- Attribute *string `type:"string" required:"true" enum:"VpcAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DescribeVpcAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeVpcAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeVpcAttributeInput"}
- if s.Attribute == nil {
- invalidParams.Add(request.NewErrParamRequired("Attribute"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeVpcAttribute.
- type DescribeVpcAttributeOutput struct {
- _ struct{} `type:"structure"`
- // Indicates whether the instances launched in the VPC get DNS hostnames. If
- // this attribute is true, instances in the VPC get DNS hostnames; otherwise,
- // they do not.
- EnableDnsHostnames *AttributeBooleanValue `locationName:"enableDnsHostnames" type:"structure"`
- // Indicates whether DNS resolution is enabled for the VPC. If this attribute
- // is true, the Amazon DNS server resolves DNS hostnames for your instances
- // to their corresponding IP addresses; otherwise, it does not.
- EnableDnsSupport *AttributeBooleanValue `locationName:"enableDnsSupport" type:"structure"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s DescribeVpcAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpcClassicLinkDnsSupport.
- type DescribeVpcClassicLinkDnsSupportInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of items to return for this request. The request returns
- // a token that you can specify in a subsequent call to get the next set of
- // results.
- MaxResults *int64 `locationName:"maxResults" min:"5" type:"integer"`
- // The token for the next set of items to return. (You received this token from
- // a prior call.)
- NextToken *string `locationName:"nextToken" min:"1" type:"string"`
- // One or more VPC IDs.
- VpcIds []*string `locationNameList:"VpcId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcClassicLinkDnsSupportInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcClassicLinkDnsSupportInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeVpcClassicLinkDnsSupportInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeVpcClassicLinkDnsSupportInput"}
- if s.MaxResults != nil && *s.MaxResults < 5 {
- invalidParams.Add(request.NewErrParamMinValue("MaxResults", 5))
- }
- if s.NextToken != nil && len(*s.NextToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextToken", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DescribeVpcClassicLinkDnsSupport.
- type DescribeVpcClassicLinkDnsSupportOutput struct {
- _ struct{} `type:"structure"`
- // The token to use when requesting the next set of items.
- NextToken *string `locationName:"nextToken" min:"1" type:"string"`
- // Information about the ClassicLink DNS support status of the VPCs.
- Vpcs []*ClassicLinkDnsSupport `locationName:"vpcs" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcClassicLinkDnsSupportOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcClassicLinkDnsSupportOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpcClassicLink.
- type DescribeVpcClassicLinkInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // is-classic-link-enabled - Whether the VPC is enabled for ClassicLink
- // (true | false).
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more VPCs for which you want to describe the ClassicLink status.
- VpcIds []*string `locationName:"VpcId" locationNameList:"VpcId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcClassicLinkInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcClassicLinkInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVpcClassicLink.
- type DescribeVpcClassicLinkOutput struct {
- _ struct{} `type:"structure"`
- // The ClassicLink status of one or more VPCs.
- Vpcs []*VpcClassicLink `locationName:"vpcSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcClassicLinkOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcClassicLinkOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpcEndpointServices.
- type DescribeVpcEndpointServicesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The maximum number of items to return for this request. The request returns
- // a token that you can specify in a subsequent call to get the next set of
- // results.
- //
- // Constraint: If the value is greater than 1000, we return only 1000 items.
- MaxResults *int64 `type:"integer"`
- // The token for the next set of items to return. (You received this token from
- // a prior call.)
- NextToken *string `type:"string"`
- }
- // String returns the string representation
- func (s DescribeVpcEndpointServicesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcEndpointServicesInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVpcEndpointServices.
- type DescribeVpcEndpointServicesOutput struct {
- _ struct{} `type:"structure"`
- // The token to use when requesting the next set of items. If there are no additional
- // items to return, the string is empty.
- NextToken *string `locationName:"nextToken" type:"string"`
- // A list of supported AWS services.
- ServiceNames []*string `locationName:"serviceNameSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcEndpointServicesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcEndpointServicesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpcEndpoints.
- type DescribeVpcEndpointsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more filters.
- //
- // service-name: The name of the AWS service.
- //
- // vpc-id: The ID of the VPC in which the endpoint resides.
- //
- // vpc-endpoint-id: The ID of the endpoint.
- //
- // vpc-endpoint-state: The state of the endpoint. (pending | available |
- // deleting | deleted)
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // The maximum number of items to return for this request. The request returns
- // a token that you can specify in a subsequent call to get the next set of
- // results.
- //
- // Constraint: If the value is greater than 1000, we return only 1000 items.
- MaxResults *int64 `type:"integer"`
- // The token for the next set of items to return. (You received this token from
- // a prior call.)
- NextToken *string `type:"string"`
- // One or more endpoint IDs.
- VpcEndpointIds []*string `locationName:"VpcEndpointId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcEndpointsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcEndpointsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVpcEndpoints.
- type DescribeVpcEndpointsOutput struct {
- _ struct{} `type:"structure"`
- // The token to use when requesting the next set of items. If there are no additional
- // items to return, the string is empty.
- NextToken *string `locationName:"nextToken" type:"string"`
- // Information about the endpoints.
- VpcEndpoints []*VpcEndpoint `locationName:"vpcEndpointSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcEndpointsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcEndpointsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpcPeeringConnections.
- type DescribeVpcPeeringConnectionsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // accepter-vpc-info.cidr-block - The CIDR block of the peer VPC.
- //
- // accepter-vpc-info.owner-id - The AWS account ID of the owner of the peer
- // VPC.
- //
- // accepter-vpc-info.vpc-id - The ID of the peer VPC.
- //
- // expiration-time - The expiration date and time for the VPC peering connection.
- //
- // requester-vpc-info.cidr-block - The CIDR block of the requester's VPC.
- //
- // requester-vpc-info.owner-id - The AWS account ID of the owner of the
- // requester VPC.
- //
- // requester-vpc-info.vpc-id - The ID of the requester VPC.
- //
- // status-code - The status of the VPC peering connection (pending-acceptance
- // | failed | expired | provisioning | active | deleted | rejected).
- //
- // status-message - A message that provides more information about the status
- // of the VPC peering connection, if applicable.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // vpc-peering-connection-id - The ID of the VPC peering connection.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more VPC peering connection IDs.
- //
- // Default: Describes all your VPC peering connections.
- VpcPeeringConnectionIds []*string `locationName:"VpcPeeringConnectionId" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcPeeringConnectionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcPeeringConnectionsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVpcPeeringConnections.
- type DescribeVpcPeeringConnectionsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the VPC peering connections.
- VpcPeeringConnections []*VpcPeeringConnection `locationName:"vpcPeeringConnectionSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcPeeringConnectionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcPeeringConnectionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpcs.
- type DescribeVpcsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // cidr - The CIDR block of the VPC. The CIDR block you specify must exactly
- // match the VPC's CIDR block for information to be returned for the VPC. Must
- // contain the slash followed by one or two digits (for example, /28).
- //
- // dhcp-options-id - The ID of a set of DHCP options.
- //
- // isDefault - Indicates whether the VPC is the default VPC.
- //
- // state - The state of the VPC (pending | available).
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // vpc-id - The ID of the VPC.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more VPC IDs.
- //
- // Default: Describes all your VPCs.
- VpcIds []*string `locationName:"VpcId" locationNameList:"VpcId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVpcs.
- type DescribeVpcsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more VPCs.
- Vpcs []*Vpc `locationName:"vpcSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpcsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpcsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpnConnections.
- type DescribeVpnConnectionsInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // customer-gateway-configuration - The configuration information for the
- // customer gateway.
- //
- // customer-gateway-id - The ID of a customer gateway associated with the
- // VPN connection.
- //
- // state - The state of the VPN connection (pending | available | deleting
- // | deleted).
- //
- // option.static-routes-only - Indicates whether the connection has static
- // routes only. Used for devices that do not support Border Gateway Protocol
- // (BGP).
- //
- // route.destination-cidr-block - The destination CIDR block. This corresponds
- // to the subnet used in a customer data center.
- //
- // bgp-asn - The BGP Autonomous System Number (ASN) associated with a BGP
- // device.
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // type - The type of VPN connection. Currently the only supported type
- // is ipsec.1.
- //
- // vpn-connection-id - The ID of the VPN connection.
- //
- // vpn-gateway-id - The ID of a virtual private gateway associated with
- // the VPN connection.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more VPN connection IDs.
- //
- // Default: Describes your VPN connections.
- VpnConnectionIds []*string `locationName:"VpnConnectionId" locationNameList:"VpnConnectionId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpnConnectionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpnConnectionsInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVpnConnections.
- type DescribeVpnConnectionsOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more VPN connections.
- VpnConnections []*VpnConnection `locationName:"vpnConnectionSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpnConnectionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpnConnectionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DescribeVpnGateways.
- type DescribeVpnGatewaysInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more filters.
- //
- // attachment.state - The current state of the attachment between the gateway
- // and the VPC (attaching | attached | detaching | detached).
- //
- // attachment.vpc-id - The ID of an attached VPC.
- //
- // availability-zone - The Availability Zone for the virtual private gateway
- // (if applicable).
- //
- // state - The state of the virtual private gateway (pending | available
- // | deleting | deleted).
- //
- // tag:key=value - The key/value combination of a tag assigned to the resource.
- //
- // tag-key - The key of a tag assigned to the resource. This filter is independent
- // of the tag-value filter. For example, if you use both the filter "tag-key=Purpose"
- // and the filter "tag-value=X", you get any resources assigned both the tag
- // key Purpose (regardless of what the tag's value is), and the tag value X
- // (regardless of what the tag's key is). If you want to list only resources
- // where Purpose is X, see the tag:key=value filter.
- //
- // tag-value - The value of a tag assigned to the resource. This filter
- // is independent of the tag-key filter.
- //
- // type - The type of virtual private gateway. Currently the only supported
- // type is ipsec.1.
- //
- // vpn-gateway-id - The ID of the virtual private gateway.
- Filters []*Filter `locationName:"Filter" locationNameList:"Filter" type:"list"`
- // One or more virtual private gateway IDs.
- //
- // Default: Describes all your virtual private gateways.
- VpnGatewayIds []*string `locationName:"VpnGatewayId" locationNameList:"VpnGatewayId" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpnGatewaysInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpnGatewaysInput) GoString() string {
- return s.String()
- }
- // Contains the output of DescribeVpnGateways.
- type DescribeVpnGatewaysOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more virtual private gateways.
- VpnGateways []*VpnGateway `locationName:"vpnGatewaySet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DescribeVpnGatewaysOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DescribeVpnGatewaysOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DetachClassicLinkVpc.
- type DetachClassicLinkVpcInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance to unlink from the VPC.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- // The ID of the VPC to which the instance is linked.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DetachClassicLinkVpcInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachClassicLinkVpcInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DetachClassicLinkVpcInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DetachClassicLinkVpcInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DetachClassicLinkVpc.
- type DetachClassicLinkVpcOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s DetachClassicLinkVpcOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachClassicLinkVpcOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DetachInternetGateway.
- type DetachInternetGatewayInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the Internet gateway.
- InternetGatewayId *string `locationName:"internetGatewayId" type:"string" required:"true"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DetachInternetGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachInternetGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DetachInternetGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DetachInternetGatewayInput"}
- if s.InternetGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("InternetGatewayId"))
- }
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DetachInternetGatewayOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DetachInternetGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachInternetGatewayOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DetachNetworkInterface.
- type DetachNetworkInterfaceInput struct {
- _ struct{} `type:"structure"`
- // The ID of the attachment.
- AttachmentId *string `locationName:"attachmentId" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Specifies whether to force a detachment.
- Force *bool `locationName:"force" type:"boolean"`
- }
- // String returns the string representation
- func (s DetachNetworkInterfaceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachNetworkInterfaceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DetachNetworkInterfaceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DetachNetworkInterfaceInput"}
- if s.AttachmentId == nil {
- invalidParams.Add(request.NewErrParamRequired("AttachmentId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DetachNetworkInterfaceOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DetachNetworkInterfaceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachNetworkInterfaceOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DetachVolume.
- type DetachVolumeInput struct {
- _ struct{} `type:"structure"`
- // The device name.
- Device *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Forces detachment if the previous detachment attempt did not occur cleanly
- // (for example, logging into an instance, unmounting the volume, and detaching
- // normally). This option can lead to data loss or a corrupted file system.
- // Use this option only as a last resort to detach a volume from a failed instance.
- // The instance won't have an opportunity to flush file system caches or file
- // system metadata. If you use this option, you must perform file system check
- // and repair procedures.
- Force *bool `type:"boolean"`
- // The ID of the instance.
- InstanceId *string `type:"string"`
- // The ID of the volume.
- VolumeId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DetachVolumeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachVolumeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DetachVolumeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DetachVolumeInput"}
- if s.VolumeId == nil {
- invalidParams.Add(request.NewErrParamRequired("VolumeId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the parameters for DetachVpnGateway.
- type DetachVpnGatewayInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `type:"string" required:"true"`
- // The ID of the virtual private gateway.
- VpnGatewayId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DetachVpnGatewayInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachVpnGatewayInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DetachVpnGatewayInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DetachVpnGatewayInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if s.VpnGatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpnGatewayId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DetachVpnGatewayOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DetachVpnGatewayOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DetachVpnGatewayOutput) GoString() string {
- return s.String()
- }
- // Describes a DHCP configuration option.
- type DhcpConfiguration struct {
- _ struct{} `type:"structure"`
- // The name of a DHCP option.
- Key *string `locationName:"key" type:"string"`
- // One or more values for the DHCP option.
- Values []*AttributeValue `locationName:"valueSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DhcpConfiguration) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DhcpConfiguration) GoString() string {
- return s.String()
- }
- // Describes a set of DHCP options.
- type DhcpOptions struct {
- _ struct{} `type:"structure"`
- // One or more DHCP options in the set.
- DhcpConfigurations []*DhcpConfiguration `locationName:"dhcpConfigurationSet" locationNameList:"item" type:"list"`
- // The ID of the set of DHCP options.
- DhcpOptionsId *string `locationName:"dhcpOptionsId" type:"string"`
- // Any tags assigned to the DHCP options set.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s DhcpOptions) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DhcpOptions) GoString() string {
- return s.String()
- }
- // Contains the parameters for DisableVgwRoutePropagation.
- type DisableVgwRoutePropagationInput struct {
- _ struct{} `type:"structure"`
- // The ID of the virtual private gateway.
- GatewayId *string `type:"string" required:"true"`
- // The ID of the route table.
- RouteTableId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DisableVgwRoutePropagationInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisableVgwRoutePropagationInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DisableVgwRoutePropagationInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DisableVgwRoutePropagationInput"}
- if s.GatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("GatewayId"))
- }
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DisableVgwRoutePropagationOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DisableVgwRoutePropagationOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisableVgwRoutePropagationOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DisableVpcClassicLinkDnsSupport.
- type DisableVpcClassicLinkDnsSupportInput struct {
- _ struct{} `type:"structure"`
- // The ID of the VPC.
- VpcId *string `type:"string"`
- }
- // String returns the string representation
- func (s DisableVpcClassicLinkDnsSupportInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisableVpcClassicLinkDnsSupportInput) GoString() string {
- return s.String()
- }
- // Contains the output of DisableVpcClassicLinkDnsSupport.
- type DisableVpcClassicLinkDnsSupportOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s DisableVpcClassicLinkDnsSupportOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisableVpcClassicLinkDnsSupportOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DisableVpcClassicLink.
- type DisableVpcClassicLinkInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DisableVpcClassicLinkInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisableVpcClassicLinkInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DisableVpcClassicLinkInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DisableVpcClassicLinkInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of DisableVpcClassicLink.
- type DisableVpcClassicLinkOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s DisableVpcClassicLinkOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisableVpcClassicLinkOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DisassociateAddress.
- type DisassociateAddressInput struct {
- _ struct{} `type:"structure"`
- // [EC2-VPC] The association ID. Required for EC2-VPC.
- AssociationId *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // [EC2-Classic] The Elastic IP address. Required for EC2-Classic.
- PublicIp *string `type:"string"`
- }
- // String returns the string representation
- func (s DisassociateAddressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisassociateAddressInput) GoString() string {
- return s.String()
- }
- type DisassociateAddressOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DisassociateAddressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisassociateAddressOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for DisassociateRouteTable.
- type DisassociateRouteTableInput struct {
- _ struct{} `type:"structure"`
- // The association ID representing the current association between the route
- // table and subnet.
- AssociationId *string `locationName:"associationId" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- }
- // String returns the string representation
- func (s DisassociateRouteTableInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisassociateRouteTableInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DisassociateRouteTableInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DisassociateRouteTableInput"}
- if s.AssociationId == nil {
- invalidParams.Add(request.NewErrParamRequired("AssociationId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type DisassociateRouteTableOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s DisassociateRouteTableOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DisassociateRouteTableOutput) GoString() string {
- return s.String()
- }
- // Describes a disk image.
- type DiskImage struct {
- _ struct{} `type:"structure"`
- // A description of the disk image.
- Description *string `type:"string"`
- // Information about the disk image.
- Image *DiskImageDetail `type:"structure"`
- // Information about the volume.
- Volume *VolumeDetail `type:"structure"`
- }
- // String returns the string representation
- func (s DiskImage) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DiskImage) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DiskImage) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DiskImage"}
- if s.Image != nil {
- if err := s.Image.Validate(); err != nil {
- invalidParams.AddNested("Image", err.(request.ErrInvalidParams))
- }
- }
- if s.Volume != nil {
- if err := s.Volume.Validate(); err != nil {
- invalidParams.AddNested("Volume", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a disk image.
- type DiskImageDescription struct {
- _ struct{} `type:"structure"`
- // The checksum computed for the disk image.
- Checksum *string `locationName:"checksum" type:"string"`
- // The disk image format.
- Format *string `locationName:"format" type:"string" required:"true" enum:"DiskImageFormat"`
- // A presigned URL for the import manifest stored in Amazon S3. For information
- // about creating a presigned URL for an Amazon S3 object, read the "Query String
- // Request Authentication Alternative" section of the Authenticating REST Requests
- // (http://docs.aws.amazon.com/AmazonS3/latest/dev/RESTAuthentication.html)
- // topic in the Amazon Simple Storage Service Developer Guide.
- //
- // For information about the import manifest referenced by this API action,
- // see VM Import Manifest (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/manifest.html).
- ImportManifestUrl *string `locationName:"importManifestUrl" type:"string" required:"true"`
- // The size of the disk image, in GiB.
- Size *int64 `locationName:"size" type:"long" required:"true"`
- }
- // String returns the string representation
- func (s DiskImageDescription) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DiskImageDescription) GoString() string {
- return s.String()
- }
- // Describes a disk image.
- type DiskImageDetail struct {
- _ struct{} `type:"structure"`
- // The size of the disk image, in GiB.
- Bytes *int64 `locationName:"bytes" type:"long" required:"true"`
- // The disk image format.
- Format *string `locationName:"format" type:"string" required:"true" enum:"DiskImageFormat"`
- // A presigned URL for the import manifest stored in Amazon S3 and presented
- // here as an Amazon S3 presigned URL. For information about creating a presigned
- // URL for an Amazon S3 object, read the "Query String Request Authentication
- // Alternative" section of the Authenticating REST Requests (http://docs.aws.amazon.com/AmazonS3/latest/dev/RESTAuthentication.html)
- // topic in the Amazon Simple Storage Service Developer Guide.
- //
- // For information about the import manifest referenced by this API action,
- // see VM Import Manifest (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/manifest.html).
- ImportManifestUrl *string `locationName:"importManifestUrl" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s DiskImageDetail) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DiskImageDetail) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DiskImageDetail) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DiskImageDetail"}
- if s.Bytes == nil {
- invalidParams.Add(request.NewErrParamRequired("Bytes"))
- }
- if s.Format == nil {
- invalidParams.Add(request.NewErrParamRequired("Format"))
- }
- if s.ImportManifestUrl == nil {
- invalidParams.Add(request.NewErrParamRequired("ImportManifestUrl"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a disk image volume.
- type DiskImageVolumeDescription struct {
- _ struct{} `type:"structure"`
- // The volume identifier.
- Id *string `locationName:"id" type:"string" required:"true"`
- // The size of the volume, in GiB.
- Size *int64 `locationName:"size" type:"long"`
- }
- // String returns the string representation
- func (s DiskImageVolumeDescription) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s DiskImageVolumeDescription) GoString() string {
- return s.String()
- }
- // Describes a block device for an EBS volume.
- type EbsBlockDevice struct {
- _ struct{} `type:"structure"`
- // Indicates whether the EBS volume is deleted on instance termination.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- // Indicates whether the EBS volume is encrypted. Encrypted Amazon EBS volumes
- // may only be attached to instances that support Amazon EBS encryption.
- Encrypted *bool `locationName:"encrypted" type:"boolean"`
- // The number of I/O operations per second (IOPS) that the volume supports.
- // For io1, this represents the number of IOPS that are provisioned for the
- // volume. For gp2, this represents the baseline performance of the volume and
- // the rate at which the volume accumulates I/O credits for bursting. For more
- // information about General Purpose SSD baseline performance, I/O credits,
- // and bursting, see Amazon EBS Volume Types (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSVolumeTypes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Constraint: Range is 100-20000 IOPS for io1 volumes and 100-10000 IOPS for
- // gp2 volumes.
- //
- // Condition: This parameter is required for requests to create io1 volumes;
- // it is not used in requests to create gp2, st1, sc1, or standard volumes.
- Iops *int64 `locationName:"iops" type:"integer"`
- // The ID of the snapshot.
- SnapshotId *string `locationName:"snapshotId" type:"string"`
- // The size of the volume, in GiB.
- //
- // Constraints: 1-16384 for General Purpose SSD (gp2), 4-16384 for Provisioned
- // IOPS SSD (io1), 500-16384 for Throughput Optimized HDD (st1), 500-16384 for
- // Cold HDD (sc1), and 1-1024 for Magnetic (standard) volumes. If you specify
- // a snapshot, the volume size must be equal to or larger than the snapshot
- // size.
- //
- // Default: If you're creating the volume from a snapshot and don't specify
- // a volume size, the default is the snapshot size.
- VolumeSize *int64 `locationName:"volumeSize" type:"integer"`
- // The volume type: gp2, io1, st1, sc1, or standard.
- //
- // Default: standard
- VolumeType *string `locationName:"volumeType" type:"string" enum:"VolumeType"`
- }
- // String returns the string representation
- func (s EbsBlockDevice) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EbsBlockDevice) GoString() string {
- return s.String()
- }
- // Describes a parameter used to set up an EBS volume in a block device mapping.
- type EbsInstanceBlockDevice struct {
- _ struct{} `type:"structure"`
- // The time stamp when the attachment initiated.
- AttachTime *time.Time `locationName:"attachTime" type:"timestamp" timestampFormat:"iso8601"`
- // Indicates whether the volume is deleted on instance termination.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- // The attachment state.
- Status *string `locationName:"status" type:"string" enum:"AttachmentStatus"`
- // The ID of the EBS volume.
- VolumeId *string `locationName:"volumeId" type:"string"`
- }
- // String returns the string representation
- func (s EbsInstanceBlockDevice) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EbsInstanceBlockDevice) GoString() string {
- return s.String()
- }
- // Describes information used to set up an EBS volume specified in a block device
- // mapping.
- type EbsInstanceBlockDeviceSpecification struct {
- _ struct{} `type:"structure"`
- // Indicates whether the volume is deleted on instance termination.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- // The ID of the EBS volume.
- VolumeId *string `locationName:"volumeId" type:"string"`
- }
- // String returns the string representation
- func (s EbsInstanceBlockDeviceSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EbsInstanceBlockDeviceSpecification) GoString() string {
- return s.String()
- }
- // Contains the parameters for EnableVgwRoutePropagation.
- type EnableVgwRoutePropagationInput struct {
- _ struct{} `type:"structure"`
- // The ID of the virtual private gateway.
- GatewayId *string `type:"string" required:"true"`
- // The ID of the route table.
- RouteTableId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s EnableVgwRoutePropagationInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVgwRoutePropagationInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *EnableVgwRoutePropagationInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "EnableVgwRoutePropagationInput"}
- if s.GatewayId == nil {
- invalidParams.Add(request.NewErrParamRequired("GatewayId"))
- }
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type EnableVgwRoutePropagationOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s EnableVgwRoutePropagationOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVgwRoutePropagationOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for EnableVolumeIO.
- type EnableVolumeIOInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the volume.
- VolumeId *string `locationName:"volumeId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s EnableVolumeIOInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVolumeIOInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *EnableVolumeIOInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "EnableVolumeIOInput"}
- if s.VolumeId == nil {
- invalidParams.Add(request.NewErrParamRequired("VolumeId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type EnableVolumeIOOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s EnableVolumeIOOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVolumeIOOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for EnableVpcClassicLinkDnsSupport.
- type EnableVpcClassicLinkDnsSupportInput struct {
- _ struct{} `type:"structure"`
- // The ID of the VPC.
- VpcId *string `type:"string"`
- }
- // String returns the string representation
- func (s EnableVpcClassicLinkDnsSupportInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVpcClassicLinkDnsSupportInput) GoString() string {
- return s.String()
- }
- // Contains the output of EnableVpcClassicLinkDnsSupport.
- type EnableVpcClassicLinkDnsSupportOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s EnableVpcClassicLinkDnsSupportOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVpcClassicLinkDnsSupportOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for EnableVpcClassicLink.
- type EnableVpcClassicLinkInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s EnableVpcClassicLinkInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVpcClassicLinkInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *EnableVpcClassicLinkInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "EnableVpcClassicLinkInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of EnableVpcClassicLink.
- type EnableVpcClassicLinkOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s EnableVpcClassicLinkOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EnableVpcClassicLinkOutput) GoString() string {
- return s.String()
- }
- // Describes a Spot fleet event.
- type EventInformation struct {
- _ struct{} `type:"structure"`
- // The description of the event.
- EventDescription *string `locationName:"eventDescription" type:"string"`
- // The event.
- //
- // The following are the error events.
- //
- // iamFleetRoleInvalid - The Spot fleet did not have the required permissions
- // either to launch or terminate an instance.
- //
- // launchSpecTemporarilyBlacklisted - The configuration is not valid and
- // several attempts to launch instances have failed. For more information, see
- // the description of the event.
- //
- // spotFleetRequestConfigurationInvalid - The configuration is not valid.
- // For more information, see the description of the event.
- //
- // spotInstanceCountLimitExceeded - You've reached the limit on the number
- // of Spot instances that you can launch.
- //
- // The following are the fleetRequestChange events.
- //
- // active - The Spot fleet has been validated and Amazon EC2 is attempting
- // to maintain the target number of running Spot instances.
- //
- // cancelled - The Spot fleet is canceled and has no running Spot instances.
- // The Spot fleet will be deleted two days after its instances were terminated.
- //
- // cancelled_running - The Spot fleet is canceled and will not launch additional
- // Spot instances, but its existing Spot instances continue to run until they
- // are interrupted or terminated.
- //
- // cancelled_terminating - The Spot fleet is canceled and its Spot instances
- // are terminating.
- //
- // expired - The Spot fleet request has expired. A subsequent event indicates
- // that the instances were terminated, if the request was created with TerminateInstancesWithExpiration
- // set.
- //
- // modify_in_progress - A request to modify the Spot fleet request was accepted
- // and is in progress.
- //
- // modify_successful - The Spot fleet request was modified.
- //
- // price_update - The bid price for a launch configuration was adjusted
- // because it was too high. This change is permanent.
- //
- // submitted - The Spot fleet request is being evaluated and Amazon EC2
- // is preparing to launch the target number of Spot instances.
- //
- // The following are the instanceChange events.
- //
- // launched - A bid was fulfilled and a new instance was launched.
- //
- // terminated - An instance was terminated by the user.
- EventSubType *string `locationName:"eventSubType" type:"string"`
- // The ID of the instance. This information is available only for instanceChange
- // events.
- InstanceId *string `locationName:"instanceId" type:"string"`
- }
- // String returns the string representation
- func (s EventInformation) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s EventInformation) GoString() string {
- return s.String()
- }
- // Describes an instance export task.
- type ExportTask struct {
- _ struct{} `type:"structure"`
- // A description of the resource being exported.
- Description *string `locationName:"description" type:"string"`
- // The ID of the export task.
- ExportTaskId *string `locationName:"exportTaskId" type:"string"`
- // Information about the export task.
- ExportToS3Task *ExportToS3Task `locationName:"exportToS3" type:"structure"`
- // Information about the instance to export.
- InstanceExportDetails *InstanceExportDetails `locationName:"instanceExport" type:"structure"`
- // The state of the export task.
- State *string `locationName:"state" type:"string" enum:"ExportTaskState"`
- // The status message related to the export task.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- }
- // String returns the string representation
- func (s ExportTask) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ExportTask) GoString() string {
- return s.String()
- }
- // Describes the format and location for an instance export task.
- type ExportToS3Task struct {
- _ struct{} `type:"structure"`
- // The container format used to combine disk images with metadata (such as OVF).
- // If absent, only the disk image is exported.
- ContainerFormat *string `locationName:"containerFormat" type:"string" enum:"ContainerFormat"`
- // The format for the exported image.
- DiskImageFormat *string `locationName:"diskImageFormat" type:"string" enum:"DiskImageFormat"`
- // The S3 bucket for the destination image. The destination bucket must exist
- // and grant WRITE and READ_ACP permissions to the AWS account vm-import-export@amazon.com.
- S3Bucket *string `locationName:"s3Bucket" type:"string"`
- // The encryption key for your S3 bucket.
- S3Key *string `locationName:"s3Key" type:"string"`
- }
- // String returns the string representation
- func (s ExportToS3Task) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ExportToS3Task) GoString() string {
- return s.String()
- }
- // Describes an instance export task.
- type ExportToS3TaskSpecification struct {
- _ struct{} `type:"structure"`
- // The container format used to combine disk images with metadata (such as OVF).
- // If absent, only the disk image is exported.
- ContainerFormat *string `locationName:"containerFormat" type:"string" enum:"ContainerFormat"`
- // The format for the exported image.
- DiskImageFormat *string `locationName:"diskImageFormat" type:"string" enum:"DiskImageFormat"`
- // The S3 bucket for the destination image. The destination bucket must exist
- // and grant WRITE and READ_ACP permissions to the AWS account vm-import-export@amazon.com.
- S3Bucket *string `locationName:"s3Bucket" type:"string"`
- // The image is written to a single object in the S3 bucket at the S3 key s3prefix
- // + exportTaskId + '.' + diskImageFormat.
- S3Prefix *string `locationName:"s3Prefix" type:"string"`
- }
- // String returns the string representation
- func (s ExportToS3TaskSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ExportToS3TaskSpecification) GoString() string {
- return s.String()
- }
- // A filter name and value pair that is used to return a more specific list
- // of results. Filters can be used to match a set of resources by various criteria,
- // such as tags, attributes, or IDs.
- type Filter struct {
- _ struct{} `type:"structure"`
- // The name of the filter. Filter names are case-sensitive.
- Name *string `type:"string"`
- // One or more filter values. Filter values are case-sensitive.
- Values []*string `locationName:"Value" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s Filter) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Filter) GoString() string {
- return s.String()
- }
- // Describes a flow log.
- type FlowLog struct {
- _ struct{} `type:"structure"`
- // The date and time the flow log was created.
- CreationTime *time.Time `locationName:"creationTime" type:"timestamp" timestampFormat:"iso8601"`
- // Information about the error that occurred. Rate limited indicates that CloudWatch
- // logs throttling has been applied for one or more network interfaces, or that
- // you've reached the limit on the number of CloudWatch Logs log groups that
- // you can create. Access error indicates that the IAM role associated with
- // the flow log does not have sufficient permissions to publish to CloudWatch
- // Logs. Unknown error indicates an internal error.
- DeliverLogsErrorMessage *string `locationName:"deliverLogsErrorMessage" type:"string"`
- // The ARN of the IAM role that posts logs to CloudWatch Logs.
- DeliverLogsPermissionArn *string `locationName:"deliverLogsPermissionArn" type:"string"`
- // The status of the logs delivery (SUCCESS | FAILED).
- DeliverLogsStatus *string `locationName:"deliverLogsStatus" type:"string"`
- // The flow log ID.
- FlowLogId *string `locationName:"flowLogId" type:"string"`
- // The status of the flow log (ACTIVE).
- FlowLogStatus *string `locationName:"flowLogStatus" type:"string"`
- // The name of the flow log group.
- LogGroupName *string `locationName:"logGroupName" type:"string"`
- // The ID of the resource on which the flow log was created.
- ResourceId *string `locationName:"resourceId" type:"string"`
- // The type of traffic captured for the flow log.
- TrafficType *string `locationName:"trafficType" type:"string" enum:"TrafficType"`
- }
- // String returns the string representation
- func (s FlowLog) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s FlowLog) GoString() string {
- return s.String()
- }
- // Contains the parameters for GetConsoleOutput.
- type GetConsoleOutputInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance.
- InstanceId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s GetConsoleOutputInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s GetConsoleOutputInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetConsoleOutputInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetConsoleOutputInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of GetConsoleOutput.
- type GetConsoleOutputOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The console output, Base64-encoded. If using a command line tool, the tool
- // decodes the output for you.
- Output *string `locationName:"output" type:"string"`
- // The time the output was last updated.
- Timestamp *time.Time `locationName:"timestamp" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s GetConsoleOutputOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s GetConsoleOutputOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for the request.
- type GetConsoleScreenshotInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The ID of the instance.
- InstanceId *string `type:"string" required:"true"`
- // When set to true, acts as keystroke input and wakes up an instance that's
- // in standby or "sleep" mode.
- WakeUp *bool `type:"boolean"`
- }
- // String returns the string representation
- func (s GetConsoleScreenshotInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s GetConsoleScreenshotInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetConsoleScreenshotInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetConsoleScreenshotInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of the request.
- type GetConsoleScreenshotOutput struct {
- _ struct{} `type:"structure"`
- // The data that comprises the image.
- ImageData *string `locationName:"imageData" type:"string"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- }
- // String returns the string representation
- func (s GetConsoleScreenshotOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s GetConsoleScreenshotOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for GetPasswordData.
- type GetPasswordDataInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the Windows instance.
- InstanceId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s GetPasswordDataInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s GetPasswordDataInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetPasswordDataInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetPasswordDataInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of GetPasswordData.
- type GetPasswordDataOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the Windows instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The password of the instance.
- PasswordData *string `locationName:"passwordData" type:"string"`
- // The time the data was last updated.
- Timestamp *time.Time `locationName:"timestamp" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s GetPasswordDataOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s GetPasswordDataOutput) GoString() string {
- return s.String()
- }
- // Describes a security group.
- type GroupIdentifier struct {
- _ struct{} `type:"structure"`
- // The ID of the security group.
- GroupId *string `locationName:"groupId" type:"string"`
- // The name of the security group.
- GroupName *string `locationName:"groupName" type:"string"`
- }
- // String returns the string representation
- func (s GroupIdentifier) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s GroupIdentifier) GoString() string {
- return s.String()
- }
- // Describes an event in the history of the Spot fleet request.
- type HistoryRecord struct {
- _ struct{} `type:"structure"`
- // Information about the event.
- EventInformation *EventInformation `locationName:"eventInformation" type:"structure" required:"true"`
- // The event type.
- //
- // error - Indicates an error with the Spot fleet request.
- //
- // fleetRequestChange - Indicates a change in the status or configuration
- // of the Spot fleet request.
- //
- // instanceChange - Indicates that an instance was launched or terminated.
- EventType *string `locationName:"eventType" type:"string" required:"true" enum:"EventType"`
- // The date and time of the event, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- Timestamp *time.Time `locationName:"timestamp" type:"timestamp" timestampFormat:"iso8601" required:"true"`
- }
- // String returns the string representation
- func (s HistoryRecord) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s HistoryRecord) GoString() string {
- return s.String()
- }
- // Describes the properties of the Dedicated host.
- type Host struct {
- _ struct{} `type:"structure"`
- // Whether auto-placement is on or off.
- AutoPlacement *string `locationName:"autoPlacement" type:"string" enum:"AutoPlacement"`
- // The Availability Zone of the Dedicated host.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The number of new instances that can be launched onto the Dedicated host.
- AvailableCapacity *AvailableCapacity `locationName:"availableCapacity" type:"structure"`
- // Unique, case-sensitive identifier you provide to ensure idempotency of the
- // request. For more information, see How to Ensure Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- ClientToken *string `locationName:"clientToken" type:"string"`
- // The ID of the Dedicated host.
- HostId *string `locationName:"hostId" type:"string"`
- // The hardware specifications of the Dedicated host.
- HostProperties *HostProperties `locationName:"hostProperties" type:"structure"`
- // The reservation ID of the Dedicated host. This returns a null response if
- // the Dedicated host doesn't have an associated reservation.
- HostReservationId *string `locationName:"hostReservationId" type:"string"`
- // The IDs and instance type that are currently running on the Dedicated host.
- Instances []*HostInstance `locationName:"instances" locationNameList:"item" type:"list"`
- // The Dedicated host's state.
- State *string `locationName:"state" type:"string" enum:"AllocationState"`
- }
- // String returns the string representation
- func (s Host) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Host) GoString() string {
- return s.String()
- }
- // Describes an instance running on a Dedicated host.
- type HostInstance struct {
- _ struct{} `type:"structure"`
- // the IDs of instances that are running on the Dedicated host.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The instance type size (for example, m3.medium) of the running instance.
- InstanceType *string `locationName:"instanceType" type:"string"`
- }
- // String returns the string representation
- func (s HostInstance) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s HostInstance) GoString() string {
- return s.String()
- }
- // Describes properties of a Dedicated host.
- type HostProperties struct {
- _ struct{} `type:"structure"`
- // The number of cores on the Dedicated host.
- Cores *int64 `locationName:"cores" type:"integer"`
- // The instance type size that the Dedicated host supports (for example, m3.medium).
- InstanceType *string `locationName:"instanceType" type:"string"`
- // The number of sockets on the Dedicated host.
- Sockets *int64 `locationName:"sockets" type:"integer"`
- // The number of vCPUs on the Dedicated host.
- TotalVCpus *int64 `locationName:"totalVCpus" type:"integer"`
- }
- // String returns the string representation
- func (s HostProperties) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s HostProperties) GoString() string {
- return s.String()
- }
- // Describes an IAM instance profile.
- type IamInstanceProfile struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the instance profile.
- Arn *string `locationName:"arn" type:"string"`
- // The ID of the instance profile.
- Id *string `locationName:"id" type:"string"`
- }
- // String returns the string representation
- func (s IamInstanceProfile) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s IamInstanceProfile) GoString() string {
- return s.String()
- }
- // Describes an IAM instance profile.
- type IamInstanceProfileSpecification struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the instance profile.
- Arn *string `locationName:"arn" type:"string"`
- // The name of the instance profile.
- Name *string `locationName:"name" type:"string"`
- }
- // String returns the string representation
- func (s IamInstanceProfileSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s IamInstanceProfileSpecification) GoString() string {
- return s.String()
- }
- // Describes the ICMP type and code.
- type IcmpTypeCode struct {
- _ struct{} `type:"structure"`
- // The ICMP type. A value of -1 means all types.
- Code *int64 `locationName:"code" type:"integer"`
- // The ICMP code. A value of -1 means all codes for the specified ICMP type.
- Type *int64 `locationName:"type" type:"integer"`
- }
- // String returns the string representation
- func (s IcmpTypeCode) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s IcmpTypeCode) GoString() string {
- return s.String()
- }
- // Describes the ID format for a resource.
- type IdFormat struct {
- _ struct{} `type:"structure"`
- // The date in UTC at which you are permanently switched over to using longer
- // IDs. If a deadline is not yet available for this resource type, this field
- // is not returned.
- Deadline *time.Time `locationName:"deadline" type:"timestamp" timestampFormat:"iso8601"`
- // The type of resource.
- Resource *string `locationName:"resource" type:"string"`
- // Indicates whether longer IDs (17-character IDs) are enabled for the resource.
- UseLongIds *bool `locationName:"useLongIds" type:"boolean"`
- }
- // String returns the string representation
- func (s IdFormat) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s IdFormat) GoString() string {
- return s.String()
- }
- // Describes an image.
- type Image struct {
- _ struct{} `type:"structure"`
- // The architecture of the image.
- Architecture *string `locationName:"architecture" type:"string" enum:"ArchitectureValues"`
- // Any block device mapping entries.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // The date and time the image was created.
- CreationDate *string `locationName:"creationDate" type:"string"`
- // The description of the AMI that was provided during image creation.
- Description *string `locationName:"description" type:"string"`
- // Specifies whether enhanced networking with ENA is enabled.
- EnaSupport *bool `locationName:"enaSupport" type:"boolean"`
- // The hypervisor type of the image.
- Hypervisor *string `locationName:"hypervisor" type:"string" enum:"HypervisorType"`
- // The ID of the AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- // The location of the AMI.
- ImageLocation *string `locationName:"imageLocation" type:"string"`
- // The AWS account alias (for example, amazon, self) or the AWS account ID of
- // the AMI owner.
- ImageOwnerAlias *string `locationName:"imageOwnerAlias" type:"string"`
- // The type of image.
- ImageType *string `locationName:"imageType" type:"string" enum:"ImageTypeValues"`
- // The kernel associated with the image, if any. Only applicable for machine
- // images.
- KernelId *string `locationName:"kernelId" type:"string"`
- // The name of the AMI that was provided during image creation.
- Name *string `locationName:"name" type:"string"`
- // The AWS account ID of the image owner.
- OwnerId *string `locationName:"imageOwnerId" type:"string"`
- // The value is Windows for Windows AMIs; otherwise blank.
- Platform *string `locationName:"platform" type:"string" enum:"PlatformValues"`
- // Any product codes associated with the AMI.
- ProductCodes []*ProductCode `locationName:"productCodes" locationNameList:"item" type:"list"`
- // Indicates whether the image has public launch permissions. The value is true
- // if this image has public launch permissions or false if it has only implicit
- // and explicit launch permissions.
- Public *bool `locationName:"isPublic" type:"boolean"`
- // The RAM disk associated with the image, if any. Only applicable for machine
- // images.
- RamdiskId *string `locationName:"ramdiskId" type:"string"`
- // The device name of the root device (for example, /dev/sda1 or /dev/xvda).
- RootDeviceName *string `locationName:"rootDeviceName" type:"string"`
- // The type of root device used by the AMI. The AMI can use an EBS volume or
- // an instance store volume.
- RootDeviceType *string `locationName:"rootDeviceType" type:"string" enum:"DeviceType"`
- // Specifies whether enhanced networking with the Intel 82599 Virtual Function
- // interface is enabled.
- SriovNetSupport *string `locationName:"sriovNetSupport" type:"string"`
- // The current state of the AMI. If the state is available, the image is successfully
- // registered and can be used to launch an instance.
- State *string `locationName:"imageState" type:"string" enum:"ImageState"`
- // The reason for the state change.
- StateReason *StateReason `locationName:"stateReason" type:"structure"`
- // Any tags assigned to the image.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The type of virtualization of the AMI.
- VirtualizationType *string `locationName:"virtualizationType" type:"string" enum:"VirtualizationType"`
- }
- // String returns the string representation
- func (s Image) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Image) GoString() string {
- return s.String()
- }
- // Describes the disk container object for an import image task.
- type ImageDiskContainer struct {
- _ struct{} `type:"structure"`
- // The description of the disk image.
- Description *string `type:"string"`
- // The block device mapping for the disk.
- DeviceName *string `type:"string"`
- // The format of the disk image being imported.
- //
- // Valid values: RAW | VHD | VMDK | OVA
- Format *string `type:"string"`
- // The ID of the EBS snapshot to be used for importing the snapshot.
- SnapshotId *string `type:"string"`
- // The URL to the Amazon S3-based disk image being imported. The URL can either
- // be a https URL (https://..) or an Amazon S3 URL (s3://..)
- Url *string `type:"string"`
- // The S3 bucket for the disk image.
- UserBucket *UserBucket `type:"structure"`
- }
- // String returns the string representation
- func (s ImageDiskContainer) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImageDiskContainer) GoString() string {
- return s.String()
- }
- // Contains the parameters for ImportImage.
- type ImportImageInput struct {
- _ struct{} `type:"structure"`
- // The architecture of the virtual machine.
- //
- // Valid values: i386 | x86_64
- Architecture *string `type:"string"`
- // The client-specific data.
- ClientData *ClientData `type:"structure"`
- // The token to enable idempotency for VM import requests.
- ClientToken *string `type:"string"`
- // A description string for the import image task.
- Description *string `type:"string"`
- // Information about the disk containers.
- DiskContainers []*ImageDiskContainer `locationName:"DiskContainer" locationNameList:"item" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The target hypervisor platform.
- //
- // Valid values: xen
- Hypervisor *string `type:"string"`
- // The license type to be used for the Amazon Machine Image (AMI) after importing.
- //
- // Note: You may only use BYOL if you have existing licenses with rights to
- // use these licenses in a third party cloud like AWS. For more information,
- // see VM Import/Export Prerequisites (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/VMImportPrerequisites.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Valid values: AWS | BYOL
- LicenseType *string `type:"string"`
- // The operating system of the virtual machine.
- //
- // Valid values: Windows | Linux
- Platform *string `type:"string"`
- // The name of the role to use when not using the default role, 'vmimport'.
- RoleName *string `type:"string"`
- }
- // String returns the string representation
- func (s ImportImageInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportImageInput) GoString() string {
- return s.String()
- }
- // Contains the output for ImportImage.
- type ImportImageOutput struct {
- _ struct{} `type:"structure"`
- // The architecture of the virtual machine.
- Architecture *string `locationName:"architecture" type:"string"`
- // A description of the import task.
- Description *string `locationName:"description" type:"string"`
- // The target hypervisor of the import task.
- Hypervisor *string `locationName:"hypervisor" type:"string"`
- // The ID of the Amazon Machine Image (AMI) created by the import task.
- ImageId *string `locationName:"imageId" type:"string"`
- // The task ID of the import image task.
- ImportTaskId *string `locationName:"importTaskId" type:"string"`
- // The license type of the virtual machine.
- LicenseType *string `locationName:"licenseType" type:"string"`
- // The operating system of the virtual machine.
- Platform *string `locationName:"platform" type:"string"`
- // The progress of the task.
- Progress *string `locationName:"progress" type:"string"`
- // Information about the snapshots.
- SnapshotDetails []*SnapshotDetail `locationName:"snapshotDetailSet" locationNameList:"item" type:"list"`
- // A brief status of the task.
- Status *string `locationName:"status" type:"string"`
- // A detailed status message of the import task.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- }
- // String returns the string representation
- func (s ImportImageOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportImageOutput) GoString() string {
- return s.String()
- }
- // Describes an import image task.
- type ImportImageTask struct {
- _ struct{} `type:"structure"`
- // The architecture of the virtual machine.
- //
- // Valid values: i386 | x86_64
- Architecture *string `locationName:"architecture" type:"string"`
- // A description of the import task.
- Description *string `locationName:"description" type:"string"`
- // The target hypervisor for the import task.
- //
- // Valid values: xen
- Hypervisor *string `locationName:"hypervisor" type:"string"`
- // The ID of the Amazon Machine Image (AMI) of the imported virtual machine.
- ImageId *string `locationName:"imageId" type:"string"`
- // The ID of the import image task.
- ImportTaskId *string `locationName:"importTaskId" type:"string"`
- // The license type of the virtual machine.
- LicenseType *string `locationName:"licenseType" type:"string"`
- // The description string for the import image task.
- Platform *string `locationName:"platform" type:"string"`
- // The percentage of progress of the import image task.
- Progress *string `locationName:"progress" type:"string"`
- // Information about the snapshots.
- SnapshotDetails []*SnapshotDetail `locationName:"snapshotDetailSet" locationNameList:"item" type:"list"`
- // A brief status for the import image task.
- Status *string `locationName:"status" type:"string"`
- // A descriptive status message for the import image task.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- }
- // String returns the string representation
- func (s ImportImageTask) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportImageTask) GoString() string {
- return s.String()
- }
- // Contains the parameters for ImportInstance.
- type ImportInstanceInput struct {
- _ struct{} `type:"structure"`
- // A description for the instance being imported.
- Description *string `locationName:"description" type:"string"`
- // The disk image.
- DiskImages []*DiskImage `locationName:"diskImage" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The launch specification.
- LaunchSpecification *ImportInstanceLaunchSpecification `locationName:"launchSpecification" type:"structure"`
- // The instance operating system.
- Platform *string `locationName:"platform" type:"string" required:"true" enum:"PlatformValues"`
- }
- // String returns the string representation
- func (s ImportInstanceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportInstanceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ImportInstanceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ImportInstanceInput"}
- if s.Platform == nil {
- invalidParams.Add(request.NewErrParamRequired("Platform"))
- }
- if s.DiskImages != nil {
- for i, v := range s.DiskImages {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "DiskImages", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes the launch specification for VM import.
- type ImportInstanceLaunchSpecification struct {
- _ struct{} `type:"structure"`
- // Reserved.
- AdditionalInfo *string `locationName:"additionalInfo" type:"string"`
- // The architecture of the instance.
- Architecture *string `locationName:"architecture" type:"string" enum:"ArchitectureValues"`
- // One or more security group IDs.
- GroupIds []*string `locationName:"GroupId" locationNameList:"SecurityGroupId" type:"list"`
- // One or more security group names.
- GroupNames []*string `locationName:"GroupName" locationNameList:"SecurityGroup" type:"list"`
- // Indicates whether an instance stops or terminates when you initiate shutdown
- // from the instance (using the operating system command for system shutdown).
- InstanceInitiatedShutdownBehavior *string `locationName:"instanceInitiatedShutdownBehavior" type:"string" enum:"ShutdownBehavior"`
- // The instance type. For more information about the instance types that you
- // can import, see Before You Get Started (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/VMImportPrerequisites.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // Indicates whether monitoring is enabled.
- Monitoring *bool `locationName:"monitoring" type:"boolean"`
- // The placement information for the instance.
- Placement *Placement `locationName:"placement" type:"structure"`
- // [EC2-VPC] An available IP address from the IP address range of the subnet.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // [EC2-VPC] The ID of the subnet in which to launch the instance.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // The user data to make available to the instance. If you are using an AWS
- // SDK or command line tool, Base64-encoding is performed for you, and you can
- // load the text from a file. Otherwise, you must provide Base64-encoded text.
- UserData *UserData `locationName:"userData" type:"structure"`
- }
- // String returns the string representation
- func (s ImportInstanceLaunchSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportInstanceLaunchSpecification) GoString() string {
- return s.String()
- }
- // Contains the output for ImportInstance.
- type ImportInstanceOutput struct {
- _ struct{} `type:"structure"`
- // Information about the conversion task.
- ConversionTask *ConversionTask `locationName:"conversionTask" type:"structure"`
- }
- // String returns the string representation
- func (s ImportInstanceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportInstanceOutput) GoString() string {
- return s.String()
- }
- // Describes an import instance task.
- type ImportInstanceTaskDetails struct {
- _ struct{} `type:"structure"`
- // A description of the task.
- Description *string `locationName:"description" type:"string"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The instance operating system.
- Platform *string `locationName:"platform" type:"string" enum:"PlatformValues"`
- // One or more volumes.
- Volumes []*ImportInstanceVolumeDetailItem `locationName:"volumes" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s ImportInstanceTaskDetails) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportInstanceTaskDetails) GoString() string {
- return s.String()
- }
- // Describes an import volume task.
- type ImportInstanceVolumeDetailItem struct {
- _ struct{} `type:"structure"`
- // The Availability Zone where the resulting instance will reside.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string" required:"true"`
- // The number of bytes converted so far.
- BytesConverted *int64 `locationName:"bytesConverted" type:"long" required:"true"`
- // A description of the task.
- Description *string `locationName:"description" type:"string"`
- // The image.
- Image *DiskImageDescription `locationName:"image" type:"structure" required:"true"`
- // The status of the import of this particular disk image.
- Status *string `locationName:"status" type:"string" required:"true"`
- // The status information or errors related to the disk image.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- // The volume.
- Volume *DiskImageVolumeDescription `locationName:"volume" type:"structure" required:"true"`
- }
- // String returns the string representation
- func (s ImportInstanceVolumeDetailItem) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportInstanceVolumeDetailItem) GoString() string {
- return s.String()
- }
- // Contains the parameters for ImportKeyPair.
- type ImportKeyPairInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // A unique name for the key pair.
- KeyName *string `locationName:"keyName" type:"string" required:"true"`
- // The public key. For API calls, the text must be base64-encoded. For command
- // line tools, base64 encoding is performed for you.
- //
- // PublicKeyMaterial is automatically base64 encoded/decoded by the SDK.
- PublicKeyMaterial []byte `locationName:"publicKeyMaterial" type:"blob" required:"true"`
- }
- // String returns the string representation
- func (s ImportKeyPairInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportKeyPairInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ImportKeyPairInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ImportKeyPairInput"}
- if s.KeyName == nil {
- invalidParams.Add(request.NewErrParamRequired("KeyName"))
- }
- if s.PublicKeyMaterial == nil {
- invalidParams.Add(request.NewErrParamRequired("PublicKeyMaterial"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ImportKeyPair.
- type ImportKeyPairOutput struct {
- _ struct{} `type:"structure"`
- // The MD5 public key fingerprint as specified in section 4 of RFC 4716.
- KeyFingerprint *string `locationName:"keyFingerprint" type:"string"`
- // The key pair name you provided.
- KeyName *string `locationName:"keyName" type:"string"`
- }
- // String returns the string representation
- func (s ImportKeyPairOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportKeyPairOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ImportSnapshot.
- type ImportSnapshotInput struct {
- _ struct{} `type:"structure"`
- // The client-specific data.
- ClientData *ClientData `type:"structure"`
- // Token to enable idempotency for VM import requests.
- ClientToken *string `type:"string"`
- // The description string for the import snapshot task.
- Description *string `type:"string"`
- // Information about the disk container.
- DiskContainer *SnapshotDiskContainer `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The name of the role to use when not using the default role, 'vmimport'.
- RoleName *string `type:"string"`
- }
- // String returns the string representation
- func (s ImportSnapshotInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportSnapshotInput) GoString() string {
- return s.String()
- }
- // Contains the output for ImportSnapshot.
- type ImportSnapshotOutput struct {
- _ struct{} `type:"structure"`
- // A description of the import snapshot task.
- Description *string `locationName:"description" type:"string"`
- // The ID of the import snapshot task.
- ImportTaskId *string `locationName:"importTaskId" type:"string"`
- // Information about the import snapshot task.
- SnapshotTaskDetail *SnapshotTaskDetail `locationName:"snapshotTaskDetail" type:"structure"`
- }
- // String returns the string representation
- func (s ImportSnapshotOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportSnapshotOutput) GoString() string {
- return s.String()
- }
- // Describes an import snapshot task.
- type ImportSnapshotTask struct {
- _ struct{} `type:"structure"`
- // A description of the import snapshot task.
- Description *string `locationName:"description" type:"string"`
- // The ID of the import snapshot task.
- ImportTaskId *string `locationName:"importTaskId" type:"string"`
- // Describes an import snapshot task.
- SnapshotTaskDetail *SnapshotTaskDetail `locationName:"snapshotTaskDetail" type:"structure"`
- }
- // String returns the string representation
- func (s ImportSnapshotTask) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportSnapshotTask) GoString() string {
- return s.String()
- }
- // Contains the parameters for ImportVolume.
- type ImportVolumeInput struct {
- _ struct{} `type:"structure"`
- // The Availability Zone for the resulting EBS volume.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string" required:"true"`
- // A description of the volume.
- Description *string `locationName:"description" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The disk image.
- Image *DiskImageDetail `locationName:"image" type:"structure" required:"true"`
- // The volume size.
- Volume *VolumeDetail `locationName:"volume" type:"structure" required:"true"`
- }
- // String returns the string representation
- func (s ImportVolumeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportVolumeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ImportVolumeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ImportVolumeInput"}
- if s.AvailabilityZone == nil {
- invalidParams.Add(request.NewErrParamRequired("AvailabilityZone"))
- }
- if s.Image == nil {
- invalidParams.Add(request.NewErrParamRequired("Image"))
- }
- if s.Volume == nil {
- invalidParams.Add(request.NewErrParamRequired("Volume"))
- }
- if s.Image != nil {
- if err := s.Image.Validate(); err != nil {
- invalidParams.AddNested("Image", err.(request.ErrInvalidParams))
- }
- }
- if s.Volume != nil {
- if err := s.Volume.Validate(); err != nil {
- invalidParams.AddNested("Volume", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output for ImportVolume.
- type ImportVolumeOutput struct {
- _ struct{} `type:"structure"`
- // Information about the conversion task.
- ConversionTask *ConversionTask `locationName:"conversionTask" type:"structure"`
- }
- // String returns the string representation
- func (s ImportVolumeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportVolumeOutput) GoString() string {
- return s.String()
- }
- // Describes an import volume task.
- type ImportVolumeTaskDetails struct {
- _ struct{} `type:"structure"`
- // The Availability Zone where the resulting volume will reside.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string" required:"true"`
- // The number of bytes converted so far.
- BytesConverted *int64 `locationName:"bytesConverted" type:"long" required:"true"`
- // The description you provided when starting the import volume task.
- Description *string `locationName:"description" type:"string"`
- // The image.
- Image *DiskImageDescription `locationName:"image" type:"structure" required:"true"`
- // The volume.
- Volume *DiskImageVolumeDescription `locationName:"volume" type:"structure" required:"true"`
- }
- // String returns the string representation
- func (s ImportVolumeTaskDetails) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ImportVolumeTaskDetails) GoString() string {
- return s.String()
- }
- // Describes an instance.
- type Instance struct {
- _ struct{} `type:"structure"`
- // The AMI launch index, which can be used to find this instance in the launch
- // group.
- AmiLaunchIndex *int64 `locationName:"amiLaunchIndex" type:"integer"`
- // The architecture of the image.
- Architecture *string `locationName:"architecture" type:"string" enum:"ArchitectureValues"`
- // Any block device mapping entries for the instance.
- BlockDeviceMappings []*InstanceBlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // The idempotency token you provided when you launched the instance, if applicable.
- ClientToken *string `locationName:"clientToken" type:"string"`
- // Indicates whether the instance is optimized for EBS I/O. This optimization
- // provides dedicated throughput to Amazon EBS and an optimized configuration
- // stack to provide optimal I/O performance. This optimization isn't available
- // with all instance types. Additional usage charges apply when using an EBS
- // Optimized instance.
- EbsOptimized *bool `locationName:"ebsOptimized" type:"boolean"`
- // Specifies whether enhanced networking with ENA is enabled.
- EnaSupport *bool `locationName:"enaSupport" type:"boolean"`
- // The hypervisor type of the instance.
- Hypervisor *string `locationName:"hypervisor" type:"string" enum:"HypervisorType"`
- // The IAM instance profile associated with the instance, if applicable.
- IamInstanceProfile *IamInstanceProfile `locationName:"iamInstanceProfile" type:"structure"`
- // The ID of the AMI used to launch the instance.
- ImageId *string `locationName:"imageId" type:"string"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // Indicates whether this is a Spot instance or a Scheduled Instance.
- InstanceLifecycle *string `locationName:"instanceLifecycle" type:"string" enum:"InstanceLifecycleType"`
- // The instance type.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // The kernel associated with this instance, if applicable.
- KernelId *string `locationName:"kernelId" type:"string"`
- // The name of the key pair, if this instance was launched with an associated
- // key pair.
- KeyName *string `locationName:"keyName" type:"string"`
- // The time the instance was launched.
- LaunchTime *time.Time `locationName:"launchTime" type:"timestamp" timestampFormat:"iso8601"`
- // The monitoring information for the instance.
- Monitoring *Monitoring `locationName:"monitoring" type:"structure"`
- // [EC2-VPC] One or more network interfaces for the instance.
- NetworkInterfaces []*InstanceNetworkInterface `locationName:"networkInterfaceSet" locationNameList:"item" type:"list"`
- // The location where the instance launched, if applicable.
- Placement *Placement `locationName:"placement" type:"structure"`
- // The value is Windows for Windows instances; otherwise blank.
- Platform *string `locationName:"platform" type:"string" enum:"PlatformValues"`
- // The private DNS name assigned to the instance. This DNS name can only be
- // used inside the Amazon EC2 network. This name is not available until the
- // instance enters the running state. For EC2-VPC, this name is only available
- // if you've enabled DNS hostnames for your VPC.
- PrivateDnsName *string `locationName:"privateDnsName" type:"string"`
- // The private IP address assigned to the instance.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // The product codes attached to this instance, if applicable.
- ProductCodes []*ProductCode `locationName:"productCodes" locationNameList:"item" type:"list"`
- // The public DNS name assigned to the instance. This name is not available
- // until the instance enters the running state. For EC2-VPC, this name is only
- // available if you've enabled DNS hostnames for your VPC.
- PublicDnsName *string `locationName:"dnsName" type:"string"`
- // The public IP address assigned to the instance, if applicable.
- PublicIpAddress *string `locationName:"ipAddress" type:"string"`
- // The RAM disk associated with this instance, if applicable.
- RamdiskId *string `locationName:"ramdiskId" type:"string"`
- // The root device name (for example, /dev/sda1 or /dev/xvda).
- RootDeviceName *string `locationName:"rootDeviceName" type:"string"`
- // The root device type used by the AMI. The AMI can use an EBS volume or an
- // instance store volume.
- RootDeviceType *string `locationName:"rootDeviceType" type:"string" enum:"DeviceType"`
- // One or more security groups for the instance.
- SecurityGroups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // Specifies whether to enable an instance launched in a VPC to perform NAT.
- // This controls whether source/destination checking is enabled on the instance.
- // A value of true means checking is enabled, and false means checking is disabled.
- // The value must be false for the instance to perform NAT. For more information,
- // see NAT Instances (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_NAT_Instance.html)
- // in the Amazon Virtual Private Cloud User Guide.
- SourceDestCheck *bool `locationName:"sourceDestCheck" type:"boolean"`
- // If the request is a Spot instance request, the ID of the request.
- SpotInstanceRequestId *string `locationName:"spotInstanceRequestId" type:"string"`
- // Specifies whether enhanced networking with the Intel 82599 Virtual Function
- // interface is enabled.
- SriovNetSupport *string `locationName:"sriovNetSupport" type:"string"`
- // The current state of the instance.
- State *InstanceState `locationName:"instanceState" type:"structure"`
- // The reason for the most recent state transition.
- StateReason *StateReason `locationName:"stateReason" type:"structure"`
- // The reason for the most recent state transition. This might be an empty string.
- StateTransitionReason *string `locationName:"reason" type:"string"`
- // [EC2-VPC] The ID of the subnet in which the instance is running.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // Any tags assigned to the instance.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The virtualization type of the instance.
- VirtualizationType *string `locationName:"virtualizationType" type:"string" enum:"VirtualizationType"`
- // [EC2-VPC] The ID of the VPC in which the instance is running.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s Instance) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Instance) GoString() string {
- return s.String()
- }
- // Describes a block device mapping.
- type InstanceBlockDeviceMapping struct {
- _ struct{} `type:"structure"`
- // The device name exposed to the instance (for example, /dev/sdh or xvdh).
- DeviceName *string `locationName:"deviceName" type:"string"`
- // Parameters used to automatically set up EBS volumes when the instance is
- // launched.
- Ebs *EbsInstanceBlockDevice `locationName:"ebs" type:"structure"`
- }
- // String returns the string representation
- func (s InstanceBlockDeviceMapping) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceBlockDeviceMapping) GoString() string {
- return s.String()
- }
- // Describes a block device mapping entry.
- type InstanceBlockDeviceMappingSpecification struct {
- _ struct{} `type:"structure"`
- // The device name exposed to the instance (for example, /dev/sdh or xvdh).
- DeviceName *string `locationName:"deviceName" type:"string"`
- // Parameters used to automatically set up EBS volumes when the instance is
- // launched.
- Ebs *EbsInstanceBlockDeviceSpecification `locationName:"ebs" type:"structure"`
- // suppress the specified device included in the block device mapping.
- NoDevice *string `locationName:"noDevice" type:"string"`
- // The virtual device name.
- VirtualName *string `locationName:"virtualName" type:"string"`
- }
- // String returns the string representation
- func (s InstanceBlockDeviceMappingSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceBlockDeviceMappingSpecification) GoString() string {
- return s.String()
- }
- // Information about the instance type that the Dedicated host supports.
- type InstanceCapacity struct {
- _ struct{} `type:"structure"`
- // The number of instances that can still be launched onto the Dedicated host.
- AvailableCapacity *int64 `locationName:"availableCapacity" type:"integer"`
- // The instance type size supported by the Dedicated host.
- InstanceType *string `locationName:"instanceType" type:"string"`
- // The total number of instances that can be launched onto the Dedicated host.
- TotalCapacity *int64 `locationName:"totalCapacity" type:"integer"`
- }
- // String returns the string representation
- func (s InstanceCapacity) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceCapacity) GoString() string {
- return s.String()
- }
- // Describes a Reserved Instance listing state.
- type InstanceCount struct {
- _ struct{} `type:"structure"`
- // The number of listed Reserved Instances in the state specified by the state.
- InstanceCount *int64 `locationName:"instanceCount" type:"integer"`
- // The states of the listed Reserved Instances.
- State *string `locationName:"state" type:"string" enum:"ListingState"`
- }
- // String returns the string representation
- func (s InstanceCount) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceCount) GoString() string {
- return s.String()
- }
- // Describes an instance to export.
- type InstanceExportDetails struct {
- _ struct{} `type:"structure"`
- // The ID of the resource being exported.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The target virtualization environment.
- TargetEnvironment *string `locationName:"targetEnvironment" type:"string" enum:"ExportEnvironment"`
- }
- // String returns the string representation
- func (s InstanceExportDetails) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceExportDetails) GoString() string {
- return s.String()
- }
- // Describes the monitoring information of the instance.
- type InstanceMonitoring struct {
- _ struct{} `type:"structure"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The monitoring information.
- Monitoring *Monitoring `locationName:"monitoring" type:"structure"`
- }
- // String returns the string representation
- func (s InstanceMonitoring) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceMonitoring) GoString() string {
- return s.String()
- }
- // Describes a network interface.
- type InstanceNetworkInterface struct {
- _ struct{} `type:"structure"`
- // The association information for an Elastic IP associated with the network
- // interface.
- Association *InstanceNetworkInterfaceAssociation `locationName:"association" type:"structure"`
- // The network interface attachment.
- Attachment *InstanceNetworkInterfaceAttachment `locationName:"attachment" type:"structure"`
- // The description.
- Description *string `locationName:"description" type:"string"`
- // One or more security groups.
- Groups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // The MAC address.
- MacAddress *string `locationName:"macAddress" type:"string"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // The ID of the AWS account that created the network interface.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // The private DNS name.
- PrivateDnsName *string `locationName:"privateDnsName" type:"string"`
- // The IP address of the network interface within the subnet.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // The private IP addresses associated with the network interface.
- PrivateIpAddresses []*InstancePrivateIpAddress `locationName:"privateIpAddressesSet" locationNameList:"item" type:"list"`
- // Indicates whether to validate network traffic to or from this network interface.
- SourceDestCheck *bool `locationName:"sourceDestCheck" type:"boolean"`
- // The status of the network interface.
- Status *string `locationName:"status" type:"string" enum:"NetworkInterfaceStatus"`
- // The ID of the subnet.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s InstanceNetworkInterface) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceNetworkInterface) GoString() string {
- return s.String()
- }
- // Describes association information for an Elastic IP address.
- type InstanceNetworkInterfaceAssociation struct {
- _ struct{} `type:"structure"`
- // The ID of the owner of the Elastic IP address.
- IpOwnerId *string `locationName:"ipOwnerId" type:"string"`
- // The public DNS name.
- PublicDnsName *string `locationName:"publicDnsName" type:"string"`
- // The public IP address or Elastic IP address bound to the network interface.
- PublicIp *string `locationName:"publicIp" type:"string"`
- }
- // String returns the string representation
- func (s InstanceNetworkInterfaceAssociation) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceNetworkInterfaceAssociation) GoString() string {
- return s.String()
- }
- // Describes a network interface attachment.
- type InstanceNetworkInterfaceAttachment struct {
- _ struct{} `type:"structure"`
- // The time stamp when the attachment initiated.
- AttachTime *time.Time `locationName:"attachTime" type:"timestamp" timestampFormat:"iso8601"`
- // The ID of the network interface attachment.
- AttachmentId *string `locationName:"attachmentId" type:"string"`
- // Indicates whether the network interface is deleted when the instance is terminated.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- // The index of the device on the instance for the network interface attachment.
- DeviceIndex *int64 `locationName:"deviceIndex" type:"integer"`
- // The attachment state.
- Status *string `locationName:"status" type:"string" enum:"AttachmentStatus"`
- }
- // String returns the string representation
- func (s InstanceNetworkInterfaceAttachment) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceNetworkInterfaceAttachment) GoString() string {
- return s.String()
- }
- // Describes a network interface.
- type InstanceNetworkInterfaceSpecification struct {
- _ struct{} `type:"structure"`
- // Indicates whether to assign a public IP address to an instance you launch
- // in a VPC. The public IP address can only be assigned to a network interface
- // for eth0, and can only be assigned to a new network interface, not an existing
- // one. You cannot specify more than one network interface in the request. If
- // launching into a default subnet, the default value is true.
- AssociatePublicIpAddress *bool `locationName:"associatePublicIpAddress" type:"boolean"`
- // If set to true, the interface is deleted when the instance is terminated.
- // You can specify true only if creating a new network interface when launching
- // an instance.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- // The description of the network interface. Applies only if creating a network
- // interface when launching an instance.
- Description *string `locationName:"description" type:"string"`
- // The index of the device on the instance for the network interface attachment.
- // If you are specifying a network interface in a RunInstances request, you
- // must provide the device index.
- DeviceIndex *int64 `locationName:"deviceIndex" type:"integer"`
- // The IDs of the security groups for the network interface. Applies only if
- // creating a network interface when launching an instance.
- Groups []*string `locationName:"SecurityGroupId" locationNameList:"SecurityGroupId" type:"list"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // The private IP address of the network interface. Applies only if creating
- // a network interface when launching an instance.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // One or more private IP addresses to assign to the network interface. Only
- // one private IP address can be designated as primary.
- PrivateIpAddresses []*PrivateIpAddressSpecification `locationName:"privateIpAddressesSet" queryName:"PrivateIpAddresses" locationNameList:"item" type:"list"`
- // The number of secondary private IP addresses. You can't specify this option
- // and specify more than one private IP address using the private IP addresses
- // option.
- SecondaryPrivateIpAddressCount *int64 `locationName:"secondaryPrivateIpAddressCount" type:"integer"`
- // The ID of the subnet associated with the network string. Applies only if
- // creating a network interface when launching an instance.
- SubnetId *string `locationName:"subnetId" type:"string"`
- }
- // String returns the string representation
- func (s InstanceNetworkInterfaceSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceNetworkInterfaceSpecification) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *InstanceNetworkInterfaceSpecification) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "InstanceNetworkInterfaceSpecification"}
- if s.PrivateIpAddresses != nil {
- for i, v := range s.PrivateIpAddresses {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "PrivateIpAddresses", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a private IP address.
- type InstancePrivateIpAddress struct {
- _ struct{} `type:"structure"`
- // The association information for an Elastic IP address for the network interface.
- Association *InstanceNetworkInterfaceAssociation `locationName:"association" type:"structure"`
- // Indicates whether this IP address is the primary private IP address of the
- // network interface.
- Primary *bool `locationName:"primary" type:"boolean"`
- // The private DNS name.
- PrivateDnsName *string `locationName:"privateDnsName" type:"string"`
- // The private IP address of the network interface.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- }
- // String returns the string representation
- func (s InstancePrivateIpAddress) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstancePrivateIpAddress) GoString() string {
- return s.String()
- }
- // Describes the current state of the instance.
- type InstanceState struct {
- _ struct{} `type:"structure"`
- // The low byte represents the state. The high byte is an opaque internal value
- // and should be ignored.
- //
- // 0 : pending
- //
- // 16 : running
- //
- // 32 : shutting-down
- //
- // 48 : terminated
- //
- // 64 : stopping
- //
- // 80 : stopped
- Code *int64 `locationName:"code" type:"integer"`
- // The current state of the instance.
- Name *string `locationName:"name" type:"string" enum:"InstanceStateName"`
- }
- // String returns the string representation
- func (s InstanceState) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceState) GoString() string {
- return s.String()
- }
- // Describes an instance state change.
- type InstanceStateChange struct {
- _ struct{} `type:"structure"`
- // The current state of the instance.
- CurrentState *InstanceState `locationName:"currentState" type:"structure"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The previous state of the instance.
- PreviousState *InstanceState `locationName:"previousState" type:"structure"`
- }
- // String returns the string representation
- func (s InstanceStateChange) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceStateChange) GoString() string {
- return s.String()
- }
- // Describes the status of an instance.
- type InstanceStatus struct {
- _ struct{} `type:"structure"`
- // The Availability Zone of the instance.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // Any scheduled events associated with the instance.
- Events []*InstanceStatusEvent `locationName:"eventsSet" locationNameList:"item" type:"list"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The intended state of the instance. DescribeInstanceStatus requires that
- // an instance be in the running state.
- InstanceState *InstanceState `locationName:"instanceState" type:"structure"`
- // Reports impaired functionality that stems from issues internal to the instance,
- // such as impaired reachability.
- InstanceStatus *InstanceStatusSummary `locationName:"instanceStatus" type:"structure"`
- // Reports impaired functionality that stems from issues related to the systems
- // that support an instance, such as hardware failures and network connectivity
- // problems.
- SystemStatus *InstanceStatusSummary `locationName:"systemStatus" type:"structure"`
- }
- // String returns the string representation
- func (s InstanceStatus) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceStatus) GoString() string {
- return s.String()
- }
- // Describes the instance status.
- type InstanceStatusDetails struct {
- _ struct{} `type:"structure"`
- // The time when a status check failed. For an instance that was launched and
- // impaired, this is the time when the instance was launched.
- ImpairedSince *time.Time `locationName:"impairedSince" type:"timestamp" timestampFormat:"iso8601"`
- // The type of instance status.
- Name *string `locationName:"name" type:"string" enum:"StatusName"`
- // The status.
- Status *string `locationName:"status" type:"string" enum:"StatusType"`
- }
- // String returns the string representation
- func (s InstanceStatusDetails) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceStatusDetails) GoString() string {
- return s.String()
- }
- // Describes a scheduled event for an instance.
- type InstanceStatusEvent struct {
- _ struct{} `type:"structure"`
- // The event code.
- Code *string `locationName:"code" type:"string" enum:"EventCode"`
- // A description of the event.
- //
- // After a scheduled event is completed, it can still be described for up to
- // a week. If the event has been completed, this description starts with the
- // following text: [Completed].
- Description *string `locationName:"description" type:"string"`
- // The latest scheduled end time for the event.
- NotAfter *time.Time `locationName:"notAfter" type:"timestamp" timestampFormat:"iso8601"`
- // The earliest scheduled start time for the event.
- NotBefore *time.Time `locationName:"notBefore" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s InstanceStatusEvent) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceStatusEvent) GoString() string {
- return s.String()
- }
- // Describes the status of an instance.
- type InstanceStatusSummary struct {
- _ struct{} `type:"structure"`
- // The system instance health or application instance health.
- Details []*InstanceStatusDetails `locationName:"details" locationNameList:"item" type:"list"`
- // The status.
- Status *string `locationName:"status" type:"string" enum:"SummaryStatus"`
- }
- // String returns the string representation
- func (s InstanceStatusSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InstanceStatusSummary) GoString() string {
- return s.String()
- }
- // Describes an Internet gateway.
- type InternetGateway struct {
- _ struct{} `type:"structure"`
- // Any VPCs attached to the Internet gateway.
- Attachments []*InternetGatewayAttachment `locationName:"attachmentSet" locationNameList:"item" type:"list"`
- // The ID of the Internet gateway.
- InternetGatewayId *string `locationName:"internetGatewayId" type:"string"`
- // Any tags assigned to the Internet gateway.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s InternetGateway) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InternetGateway) GoString() string {
- return s.String()
- }
- // Describes the attachment of a VPC to an Internet gateway.
- type InternetGatewayAttachment struct {
- _ struct{} `type:"structure"`
- // The current state of the attachment.
- State *string `locationName:"state" type:"string" enum:"AttachmentStatus"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s InternetGatewayAttachment) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s InternetGatewayAttachment) GoString() string {
- return s.String()
- }
- // Describes a security group rule.
- type IpPermission struct {
- _ struct{} `type:"structure"`
- // The start of port range for the TCP and UDP protocols, or an ICMP type number.
- // A value of -1 indicates all ICMP types.
- FromPort *int64 `locationName:"fromPort" type:"integer"`
- // The IP protocol name (for tcp, udp, and icmp) or number (see Protocol Numbers
- // (http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xhtml)).
- //
- // [EC2-VPC only] When you authorize or revoke security group rules, you can
- // use -1 to specify all.
- IpProtocol *string `locationName:"ipProtocol" type:"string"`
- // One or more IP ranges.
- IpRanges []*IpRange `locationName:"ipRanges" locationNameList:"item" type:"list"`
- // (Valid for AuthorizeSecurityGroupEgress, RevokeSecurityGroupEgress and DescribeSecurityGroups
- // only) One or more prefix list IDs for an AWS service. In an AuthorizeSecurityGroupEgress
- // request, this is the AWS service that you want to access through a VPC endpoint
- // from instances associated with the security group.
- PrefixListIds []*PrefixListId `locationName:"prefixListIds" locationNameList:"item" type:"list"`
- // The end of port range for the TCP and UDP protocols, or an ICMP code. A value
- // of -1 indicates all ICMP codes for the specified ICMP type.
- ToPort *int64 `locationName:"toPort" type:"integer"`
- // One or more security group and AWS account ID pairs.
- UserIdGroupPairs []*UserIdGroupPair `locationName:"groups" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s IpPermission) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s IpPermission) GoString() string {
- return s.String()
- }
- // Describes an IP range.
- type IpRange struct {
- _ struct{} `type:"structure"`
- // The CIDR range. You can either specify a CIDR range or a source security
- // group, not both.
- CidrIp *string `locationName:"cidrIp" type:"string"`
- }
- // String returns the string representation
- func (s IpRange) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s IpRange) GoString() string {
- return s.String()
- }
- // Describes a key pair.
- type KeyPairInfo struct {
- _ struct{} `type:"structure"`
- // If you used CreateKeyPair to create the key pair, this is the SHA-1 digest
- // of the DER encoded private key. If you used ImportKeyPair to provide AWS
- // the public key, this is the MD5 public key fingerprint as specified in section
- // 4 of RFC4716.
- KeyFingerprint *string `locationName:"keyFingerprint" type:"string"`
- // The name of the key pair.
- KeyName *string `locationName:"keyName" type:"string"`
- }
- // String returns the string representation
- func (s KeyPairInfo) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s KeyPairInfo) GoString() string {
- return s.String()
- }
- // Describes a launch permission.
- type LaunchPermission struct {
- _ struct{} `type:"structure"`
- // The name of the group.
- Group *string `locationName:"group" type:"string" enum:"PermissionGroup"`
- // The AWS account ID.
- UserId *string `locationName:"userId" type:"string"`
- }
- // String returns the string representation
- func (s LaunchPermission) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s LaunchPermission) GoString() string {
- return s.String()
- }
- // Describes a launch permission modification.
- type LaunchPermissionModifications struct {
- _ struct{} `type:"structure"`
- // The AWS account ID to add to the list of launch permissions for the AMI.
- Add []*LaunchPermission `locationNameList:"item" type:"list"`
- // The AWS account ID to remove from the list of launch permissions for the
- // AMI.
- Remove []*LaunchPermission `locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s LaunchPermissionModifications) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s LaunchPermissionModifications) GoString() string {
- return s.String()
- }
- // Describes the launch specification for an instance.
- type LaunchSpecification struct {
- _ struct{} `type:"structure"`
- // Deprecated.
- AddressingType *string `locationName:"addressingType" type:"string"`
- // One or more block device mapping entries.
- //
- // Although you can specify encrypted EBS volumes in this block device mapping
- // for your Spot Instances, these volumes are not encrypted.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // Indicates whether the instance is optimized for EBS I/O. This optimization
- // provides dedicated throughput to Amazon EBS and an optimized configuration
- // stack to provide optimal EBS I/O performance. This optimization isn't available
- // with all instance types. Additional usage charges apply when using an EBS
- // Optimized instance.
- //
- // Default: false
- EbsOptimized *bool `locationName:"ebsOptimized" type:"boolean"`
- // The IAM instance profile.
- IamInstanceProfile *IamInstanceProfileSpecification `locationName:"iamInstanceProfile" type:"structure"`
- // The ID of the AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- // The instance type.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // The ID of the kernel.
- KernelId *string `locationName:"kernelId" type:"string"`
- // The name of the key pair.
- KeyName *string `locationName:"keyName" type:"string"`
- // Describes the monitoring for the instance.
- Monitoring *RunInstancesMonitoringEnabled `locationName:"monitoring" type:"structure"`
- // One or more network interfaces.
- NetworkInterfaces []*InstanceNetworkInterfaceSpecification `locationName:"networkInterfaceSet" locationNameList:"item" type:"list"`
- // The placement information for the instance.
- Placement *SpotPlacement `locationName:"placement" type:"structure"`
- // The ID of the RAM disk.
- RamdiskId *string `locationName:"ramdiskId" type:"string"`
- // One or more security groups. When requesting instances in a VPC, you must
- // specify the IDs of the security groups. When requesting instances in EC2-Classic,
- // you can specify the names or the IDs of the security groups.
- SecurityGroups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // The ID of the subnet in which to launch the instance.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // The user data to make available to the instances. If you are using an AWS
- // SDK or command line tool, Base64-encoding is performed for you, and you can
- // load the text from a file. Otherwise, you must provide Base64-encoded text.
- UserData *string `locationName:"userData" type:"string"`
- }
- // String returns the string representation
- func (s LaunchSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s LaunchSpecification) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyHosts.
- type ModifyHostsInput struct {
- _ struct{} `type:"structure"`
- // Specify whether to enable or disable auto-placement.
- AutoPlacement *string `locationName:"autoPlacement" type:"string" required:"true" enum:"AutoPlacement"`
- // The host IDs of the Dedicated hosts you want to modify.
- HostIds []*string `locationName:"hostId" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s ModifyHostsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyHostsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyHostsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyHostsInput"}
- if s.AutoPlacement == nil {
- invalidParams.Add(request.NewErrParamRequired("AutoPlacement"))
- }
- if s.HostIds == nil {
- invalidParams.Add(request.NewErrParamRequired("HostIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ModifyHosts.
- type ModifyHostsOutput struct {
- _ struct{} `type:"structure"`
- // The IDs of the Dedicated hosts that were successfully modified.
- Successful []*string `locationName:"successful" locationNameList:"item" type:"list"`
- // The IDs of the Dedicated hosts that could not be modified. Check whether
- // the setting you requested can be used.
- Unsuccessful []*UnsuccessfulItem `locationName:"unsuccessful" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s ModifyHostsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyHostsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters of ModifyIdFormat.
- type ModifyIdFormatInput struct {
- _ struct{} `type:"structure"`
- // The type of resource.
- Resource *string `type:"string" required:"true"`
- // Indicate whether the resource should use longer IDs (17-character IDs).
- UseLongIds *bool `type:"boolean" required:"true"`
- }
- // String returns the string representation
- func (s ModifyIdFormatInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyIdFormatInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyIdFormatInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyIdFormatInput"}
- if s.Resource == nil {
- invalidParams.Add(request.NewErrParamRequired("Resource"))
- }
- if s.UseLongIds == nil {
- invalidParams.Add(request.NewErrParamRequired("UseLongIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyIdFormatOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifyIdFormatOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyIdFormatOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters of ModifyIdentityIdFormat.
- type ModifyIdentityIdFormatInput struct {
- _ struct{} `type:"structure"`
- // The ARN of the principal, which can be an IAM user, IAM role, or the root
- // user.
- PrincipalArn *string `locationName:"principalArn" type:"string" required:"true"`
- // The type of resource.
- Resource *string `locationName:"resource" type:"string" required:"true"`
- // Indicates whether the resource should use longer IDs (17-character IDs)
- UseLongIds *bool `locationName:"useLongIds" type:"boolean" required:"true"`
- }
- // String returns the string representation
- func (s ModifyIdentityIdFormatInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyIdentityIdFormatInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyIdentityIdFormatInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyIdentityIdFormatInput"}
- if s.PrincipalArn == nil {
- invalidParams.Add(request.NewErrParamRequired("PrincipalArn"))
- }
- if s.Resource == nil {
- invalidParams.Add(request.NewErrParamRequired("Resource"))
- }
- if s.UseLongIds == nil {
- invalidParams.Add(request.NewErrParamRequired("UseLongIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyIdentityIdFormatOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifyIdentityIdFormatOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyIdentityIdFormatOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyImageAttribute.
- type ModifyImageAttributeInput struct {
- _ struct{} `type:"structure"`
- // The name of the attribute to modify.
- Attribute *string `type:"string"`
- // A description for the AMI.
- Description *AttributeValue `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the AMI.
- ImageId *string `type:"string" required:"true"`
- // A launch permission modification.
- LaunchPermission *LaunchPermissionModifications `type:"structure"`
- // The operation type.
- OperationType *string `type:"string" enum:"OperationType"`
- // One or more product codes. After you add a product code to an AMI, it can't
- // be removed. This is only valid when modifying the productCodes attribute.
- ProductCodes []*string `locationName:"ProductCode" locationNameList:"ProductCode" type:"list"`
- // One or more user groups. This is only valid when modifying the launchPermission
- // attribute.
- UserGroups []*string `locationName:"UserGroup" locationNameList:"UserGroup" type:"list"`
- // One or more AWS account IDs. This is only valid when modifying the launchPermission
- // attribute.
- UserIds []*string `locationName:"UserId" locationNameList:"UserId" type:"list"`
- // The value of the attribute being modified. This is only valid when modifying
- // the description attribute.
- Value *string `type:"string"`
- }
- // String returns the string representation
- func (s ModifyImageAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyImageAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyImageAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyImageAttributeInput"}
- if s.ImageId == nil {
- invalidParams.Add(request.NewErrParamRequired("ImageId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyImageAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifyImageAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyImageAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyInstanceAttribute.
- type ModifyInstanceAttributeInput struct {
- _ struct{} `type:"structure"`
- // The name of the attribute.
- Attribute *string `locationName:"attribute" type:"string" enum:"InstanceAttributeName"`
- // Modifies the DeleteOnTermination attribute for volumes that are currently
- // attached. The volume must be owned by the caller. If no value is specified
- // for DeleteOnTermination, the default is true and the volume is deleted when
- // the instance is terminated.
- //
- // To add instance store volumes to an Amazon EBS-backed instance, you must
- // add them when you launch the instance. For more information, see Updating
- // the Block Device Mapping when Launching an Instance (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/block-device-mapping-concepts.html#Using_OverridingAMIBDM)
- // in the Amazon Elastic Compute Cloud User Guide.
- BlockDeviceMappings []*InstanceBlockDeviceMappingSpecification `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // If the value is true, you can't terminate the instance using the Amazon EC2
- // console, CLI, or API; otherwise, you can. You cannot use this paramater for
- // Spot Instances.
- DisableApiTermination *AttributeBooleanValue `locationName:"disableApiTermination" type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Specifies whether the instance is optimized for EBS I/O. This optimization
- // provides dedicated throughput to Amazon EBS and an optimized configuration
- // stack to provide optimal EBS I/O performance. This optimization isn't available
- // with all instance types. Additional usage charges apply when using an EBS
- // Optimized instance.
- EbsOptimized *AttributeBooleanValue `locationName:"ebsOptimized" type:"structure"`
- // Set to true to enable enhanced networking with ENA for the instance.
- //
- // This option is supported only for HVM instances. Specifying this option
- // with a PV instance can make it unreachable.
- EnaSupport *AttributeBooleanValue `locationName:"enaSupport" type:"structure"`
- // [EC2-VPC] Changes the security groups of the instance. You must specify at
- // least one security group, even if it's just the default security group for
- // the VPC. You must specify the security group ID, not the security group name.
- Groups []*string `locationName:"GroupId" locationNameList:"groupId" type:"list"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- // Specifies whether an instance stops or terminates when you initiate shutdown
- // from the instance (using the operating system command for system shutdown).
- InstanceInitiatedShutdownBehavior *AttributeValue `locationName:"instanceInitiatedShutdownBehavior" type:"structure"`
- // Changes the instance type to the specified value. For more information, see
- // Instance Types (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instance-types.html).
- // If the instance type is not valid, the error returned is InvalidInstanceAttributeValue.
- InstanceType *AttributeValue `locationName:"instanceType" type:"structure"`
- // Changes the instance's kernel to the specified value. We recommend that you
- // use PV-GRUB instead of kernels and RAM disks. For more information, see PV-GRUB
- // (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UserProvidedKernels.html).
- Kernel *AttributeValue `locationName:"kernel" type:"structure"`
- // Changes the instance's RAM disk to the specified value. We recommend that
- // you use PV-GRUB instead of kernels and RAM disks. For more information, see
- // PV-GRUB (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UserProvidedKernels.html).
- Ramdisk *AttributeValue `locationName:"ramdisk" type:"structure"`
- // Specifies whether source/destination checking is enabled. A value of true
- // means that checking is enabled, and false means checking is disabled. This
- // value must be false for a NAT instance to perform NAT.
- SourceDestCheck *AttributeBooleanValue `type:"structure"`
- // Set to simple to enable enhanced networking with the Intel 82599 Virtual
- // Function interface for the instance.
- //
- // There is no way to disable enhanced networking with the Intel 82599 Virtual
- // Function interface at this time.
- //
- // This option is supported only for HVM instances. Specifying this option
- // with a PV instance can make it unreachable.
- SriovNetSupport *AttributeValue `locationName:"sriovNetSupport" type:"structure"`
- // Changes the instance's user data to the specified value. If you are using
- // an AWS SDK or command line tool, Base64-encoding is performed for you, and
- // you can load the text from a file. Otherwise, you must provide Base64-encoded
- // text.
- UserData *BlobAttributeValue `locationName:"userData" type:"structure"`
- // A new value for the attribute. Use only with the kernel, ramdisk, userData,
- // disableApiTermination, or instanceInitiatedShutdownBehavior attribute.
- Value *string `locationName:"value" type:"string"`
- }
- // String returns the string representation
- func (s ModifyInstanceAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyInstanceAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyInstanceAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyInstanceAttributeInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyInstanceAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifyInstanceAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyInstanceAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyInstancePlacement.
- type ModifyInstancePlacementInput struct {
- _ struct{} `type:"structure"`
- // The new affinity setting for the instance.
- Affinity *string `locationName:"affinity" type:"string" enum:"Affinity"`
- // The ID of the Dedicated host that the instance will have affinity with.
- HostId *string `locationName:"hostId" type:"string"`
- // The ID of the instance that you are modifying.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- // The tenancy of the instance that you are modifying.
- Tenancy *string `locationName:"tenancy" type:"string" enum:"HostTenancy"`
- }
- // String returns the string representation
- func (s ModifyInstancePlacementInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyInstancePlacementInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyInstancePlacementInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyInstancePlacementInput"}
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ModifyInstancePlacement.
- type ModifyInstancePlacementOutput struct {
- _ struct{} `type:"structure"`
- // Is true if the request succeeds, and an error otherwise.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s ModifyInstancePlacementOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyInstancePlacementOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyNetworkInterfaceAttribute.
- type ModifyNetworkInterfaceAttributeInput struct {
- _ struct{} `type:"structure"`
- // Information about the interface attachment. If modifying the 'delete on termination'
- // attribute, you must specify the ID of the interface attachment.
- Attachment *NetworkInterfaceAttachmentChanges `locationName:"attachment" type:"structure"`
- // A description for the network interface.
- Description *AttributeValue `locationName:"description" type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Changes the security groups for the network interface. The new set of groups
- // you specify replaces the current set. You must specify at least one group,
- // even if it's just the default security group in the VPC. You must specify
- // the ID of the security group, not the name.
- Groups []*string `locationName:"SecurityGroupId" locationNameList:"SecurityGroupId" type:"list"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string" required:"true"`
- // Indicates whether source/destination checking is enabled. A value of true
- // means checking is enabled, and false means checking is disabled. This value
- // must be false for a NAT instance to perform NAT. For more information, see
- // NAT Instances (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_NAT_Instance.html)
- // in the Amazon Virtual Private Cloud User Guide.
- SourceDestCheck *AttributeBooleanValue `locationName:"sourceDestCheck" type:"structure"`
- }
- // String returns the string representation
- func (s ModifyNetworkInterfaceAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyNetworkInterfaceAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyNetworkInterfaceAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyNetworkInterfaceAttributeInput"}
- if s.NetworkInterfaceId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkInterfaceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyNetworkInterfaceAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifyNetworkInterfaceAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyNetworkInterfaceAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyReservedInstances.
- type ModifyReservedInstancesInput struct {
- _ struct{} `type:"structure"`
- // A unique, case-sensitive token you provide to ensure idempotency of your
- // modification request. For more information, see Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `locationName:"clientToken" type:"string"`
- // The IDs of the Reserved Instances to modify.
- ReservedInstancesIds []*string `locationName:"ReservedInstancesId" locationNameList:"ReservedInstancesId" type:"list" required:"true"`
- // The configuration settings for the Reserved Instances to modify.
- TargetConfigurations []*ReservedInstancesConfiguration `locationName:"ReservedInstancesConfigurationSetItemType" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s ModifyReservedInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyReservedInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyReservedInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyReservedInstancesInput"}
- if s.ReservedInstancesIds == nil {
- invalidParams.Add(request.NewErrParamRequired("ReservedInstancesIds"))
- }
- if s.TargetConfigurations == nil {
- invalidParams.Add(request.NewErrParamRequired("TargetConfigurations"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ModifyReservedInstances.
- type ModifyReservedInstancesOutput struct {
- _ struct{} `type:"structure"`
- // The ID for the modification.
- ReservedInstancesModificationId *string `locationName:"reservedInstancesModificationId" type:"string"`
- }
- // String returns the string representation
- func (s ModifyReservedInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyReservedInstancesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifySnapshotAttribute.
- type ModifySnapshotAttributeInput struct {
- _ struct{} `type:"structure"`
- // The snapshot attribute to modify.
- //
- // Only volume creation permissions may be modified at the customer level.
- Attribute *string `type:"string" enum:"SnapshotAttributeName"`
- // A JSON representation of the snapshot attribute modification.
- CreateVolumePermission *CreateVolumePermissionModifications `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The group to modify for the snapshot.
- GroupNames []*string `locationName:"UserGroup" locationNameList:"GroupName" type:"list"`
- // The type of operation to perform to the attribute.
- OperationType *string `type:"string" enum:"OperationType"`
- // The ID of the snapshot.
- SnapshotId *string `type:"string" required:"true"`
- // The account ID to modify for the snapshot.
- UserIds []*string `locationName:"UserId" locationNameList:"UserId" type:"list"`
- }
- // String returns the string representation
- func (s ModifySnapshotAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifySnapshotAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifySnapshotAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifySnapshotAttributeInput"}
- if s.SnapshotId == nil {
- invalidParams.Add(request.NewErrParamRequired("SnapshotId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifySnapshotAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifySnapshotAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifySnapshotAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifySpotFleetRequest.
- type ModifySpotFleetRequestInput struct {
- _ struct{} `type:"structure"`
- // Indicates whether running Spot instances should be terminated if the target
- // capacity of the Spot fleet request is decreased below the current size of
- // the Spot fleet.
- ExcessCapacityTerminationPolicy *string `locationName:"excessCapacityTerminationPolicy" type:"string" enum:"ExcessCapacityTerminationPolicy"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- // The size of the fleet.
- TargetCapacity *int64 `locationName:"targetCapacity" type:"integer"`
- }
- // String returns the string representation
- func (s ModifySpotFleetRequestInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifySpotFleetRequestInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifySpotFleetRequestInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifySpotFleetRequestInput"}
- if s.SpotFleetRequestId == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotFleetRequestId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ModifySpotFleetRequest.
- type ModifySpotFleetRequestOutput struct {
- _ struct{} `type:"structure"`
- // Is true if the request succeeds, and an error otherwise.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s ModifySpotFleetRequestOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifySpotFleetRequestOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifySubnetAttribute.
- type ModifySubnetAttributeInput struct {
- _ struct{} `type:"structure"`
- // Specify true to indicate that instances launched into the specified subnet
- // should be assigned public IP address.
- MapPublicIpOnLaunch *AttributeBooleanValue `type:"structure"`
- // The ID of the subnet.
- SubnetId *string `locationName:"subnetId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ModifySubnetAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifySubnetAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifySubnetAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifySubnetAttributeInput"}
- if s.SubnetId == nil {
- invalidParams.Add(request.NewErrParamRequired("SubnetId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifySubnetAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifySubnetAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifySubnetAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyVolumeAttribute.
- type ModifyVolumeAttributeInput struct {
- _ struct{} `type:"structure"`
- // Indicates whether the volume should be auto-enabled for I/O operations.
- AutoEnableIO *AttributeBooleanValue `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the volume.
- VolumeId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ModifyVolumeAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVolumeAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyVolumeAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyVolumeAttributeInput"}
- if s.VolumeId == nil {
- invalidParams.Add(request.NewErrParamRequired("VolumeId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyVolumeAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifyVolumeAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVolumeAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyVpcAttribute.
- type ModifyVpcAttributeInput struct {
- _ struct{} `type:"structure"`
- // Indicates whether the instances launched in the VPC get DNS hostnames. If
- // enabled, instances in the VPC get DNS hostnames; otherwise, they do not.
- //
- // You cannot modify the DNS resolution and DNS hostnames attributes in the
- // same request. Use separate requests for each attribute. You can only enable
- // DNS hostnames if you've enabled DNS support.
- EnableDnsHostnames *AttributeBooleanValue `type:"structure"`
- // Indicates whether the DNS resolution is supported for the VPC. If enabled,
- // queries to the Amazon provided DNS server at the 169.254.169.253 IP address,
- // or the reserved IP address at the base of the VPC network range "plus two"
- // will succeed. If disabled, the Amazon provided DNS service in the VPC that
- // resolves public DNS hostnames to IP addresses is not enabled.
- //
- // You cannot modify the DNS resolution and DNS hostnames attributes in the
- // same request. Use separate requests for each attribute.
- EnableDnsSupport *AttributeBooleanValue `type:"structure"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ModifyVpcAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVpcAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyVpcAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyVpcAttributeInput"}
- if s.VpcId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyVpcAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ModifyVpcAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVpcAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ModifyVpcEndpoint.
- type ModifyVpcEndpointInput struct {
- _ struct{} `type:"structure"`
- // One or more route tables IDs to associate with the endpoint.
- AddRouteTableIds []*string `locationName:"AddRouteTableId" locationNameList:"item" type:"list"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // A policy document to attach to the endpoint. The policy must be in valid
- // JSON format.
- PolicyDocument *string `type:"string"`
- // One or more route table IDs to disassociate from the endpoint.
- RemoveRouteTableIds []*string `locationName:"RemoveRouteTableId" locationNameList:"item" type:"list"`
- // Specify true to reset the policy document to the default policy. The default
- // policy allows access to the service.
- ResetPolicy *bool `type:"boolean"`
- // The ID of the endpoint.
- VpcEndpointId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ModifyVpcEndpointInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVpcEndpointInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyVpcEndpointInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyVpcEndpointInput"}
- if s.VpcEndpointId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcEndpointId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ModifyVpcEndpoint.
- type ModifyVpcEndpointOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s ModifyVpcEndpointOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVpcEndpointOutput) GoString() string {
- return s.String()
- }
- type ModifyVpcPeeringConnectionOptionsInput struct {
- _ struct{} `type:"structure"`
- // The VPC peering connection options for the accepter VPC.
- AccepterPeeringConnectionOptions *PeeringConnectionOptionsRequest `type:"structure"`
- // Checks whether you have the required permissions for the operation, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The VPC peering connection options for the requester VPC.
- RequesterPeeringConnectionOptions *PeeringConnectionOptionsRequest `type:"structure"`
- // The ID of the VPC peering connection.
- VpcPeeringConnectionId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ModifyVpcPeeringConnectionOptionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVpcPeeringConnectionOptionsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ModifyVpcPeeringConnectionOptionsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ModifyVpcPeeringConnectionOptionsInput"}
- if s.VpcPeeringConnectionId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcPeeringConnectionId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ModifyVpcPeeringConnectionOptionsOutput struct {
- _ struct{} `type:"structure"`
- // Information about the VPC peering connection options for the accepter VPC.
- AccepterPeeringConnectionOptions *PeeringConnectionOptions `locationName:"accepterPeeringConnectionOptions" type:"structure"`
- // Information about the VPC peering connection options for the requester VPC.
- RequesterPeeringConnectionOptions *PeeringConnectionOptions `locationName:"requesterPeeringConnectionOptions" type:"structure"`
- }
- // String returns the string representation
- func (s ModifyVpcPeeringConnectionOptionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ModifyVpcPeeringConnectionOptionsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for MonitorInstances.
- type MonitorInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more instance IDs.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s MonitorInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s MonitorInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *MonitorInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "MonitorInstancesInput"}
- if s.InstanceIds == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of MonitorInstances.
- type MonitorInstancesOutput struct {
- _ struct{} `type:"structure"`
- // Monitoring information for one or more instances.
- InstanceMonitorings []*InstanceMonitoring `locationName:"instancesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s MonitorInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s MonitorInstancesOutput) GoString() string {
- return s.String()
- }
- // Describes the monitoring for the instance.
- type Monitoring struct {
- _ struct{} `type:"structure"`
- // Indicates whether monitoring is enabled for the instance.
- State *string `locationName:"state" type:"string" enum:"MonitoringState"`
- }
- // String returns the string representation
- func (s Monitoring) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Monitoring) GoString() string {
- return s.String()
- }
- // Contains the parameters for MoveAddressToVpc.
- type MoveAddressToVpcInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The Elastic IP address.
- PublicIp *string `locationName:"publicIp" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s MoveAddressToVpcInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s MoveAddressToVpcInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *MoveAddressToVpcInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "MoveAddressToVpcInput"}
- if s.PublicIp == nil {
- invalidParams.Add(request.NewErrParamRequired("PublicIp"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of MoveAddressToVpc.
- type MoveAddressToVpcOutput struct {
- _ struct{} `type:"structure"`
- // The allocation ID for the Elastic IP address.
- AllocationId *string `locationName:"allocationId" type:"string"`
- // The status of the move of the IP address.
- Status *string `locationName:"status" type:"string" enum:"Status"`
- }
- // String returns the string representation
- func (s MoveAddressToVpcOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s MoveAddressToVpcOutput) GoString() string {
- return s.String()
- }
- // Describes the status of a moving Elastic IP address.
- type MovingAddressStatus struct {
- _ struct{} `type:"structure"`
- // The status of the Elastic IP address that's being moved to the EC2-VPC platform,
- // or restored to the EC2-Classic platform.
- MoveStatus *string `locationName:"moveStatus" type:"string" enum:"MoveStatus"`
- // The Elastic IP address.
- PublicIp *string `locationName:"publicIp" type:"string"`
- }
- // String returns the string representation
- func (s MovingAddressStatus) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s MovingAddressStatus) GoString() string {
- return s.String()
- }
- // Describes a NAT gateway.
- type NatGateway struct {
- _ struct{} `type:"structure"`
- // The date and time the NAT gateway was created.
- CreateTime *time.Time `locationName:"createTime" type:"timestamp" timestampFormat:"iso8601"`
- // The date and time the NAT gateway was deleted, if applicable.
- DeleteTime *time.Time `locationName:"deleteTime" type:"timestamp" timestampFormat:"iso8601"`
- // If the NAT gateway could not be created, specifies the error code for the
- // failure. (InsufficientFreeAddressesInSubnet | Gateway.NotAttached | InvalidAllocationID.NotFound
- // | Resource.AlreadyAssociated | InternalError | InvalidSubnetID.NotFound)
- FailureCode *string `locationName:"failureCode" type:"string"`
- // If the NAT gateway could not be created, specifies the error message for
- // the failure, that corresponds to the error code.
- //
- // For InsufficientFreeAddressesInSubnet: "Subnet has insufficient free addresses
- // to create this NAT gateway"
- //
- // For Gateway.NotAttached: "Network vpc-xxxxxxxx has no Internet gateway
- // attached"
- //
- // For InvalidAllocationID.NotFound: "Elastic IP address eipalloc-xxxxxxxx
- // could not be associated with this NAT gateway"
- //
- // For Resource.AlreadyAssociated: "Elastic IP address eipalloc-xxxxxxxx
- // is already associated"
- //
- // For InternalError: "Network interface eni-xxxxxxxx, created and used internally
- // by this NAT gateway is in an invalid state. Please try again."
- //
- // For InvalidSubnetID.NotFound: "The specified subnet subnet-xxxxxxxx does
- // not exist or could not be found."
- FailureMessage *string `locationName:"failureMessage" type:"string"`
- // Information about the IP addresses and network interface associated with
- // the NAT gateway.
- NatGatewayAddresses []*NatGatewayAddress `locationName:"natGatewayAddressSet" locationNameList:"item" type:"list"`
- // The ID of the NAT gateway.
- NatGatewayId *string `locationName:"natGatewayId" type:"string"`
- // Reserved. If you need to sustain traffic greater than the documented limits
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html),
- // contact us through the Support Center (https://console.aws.amazon.com/support/home?).
- ProvisionedBandwidth *ProvisionedBandwidth `locationName:"provisionedBandwidth" type:"structure"`
- // The state of the NAT gateway.
- //
- // pending: The NAT gateway is being created and is not ready to process
- // traffic.
- //
- // failed: The NAT gateway could not be created. Check the failureCode and
- // failureMessage fields for the reason.
- //
- // available: The NAT gateway is able to process traffic. This status remains
- // until you delete the NAT gateway, and does not indicate the health of the
- // NAT gateway.
- //
- // deleting: The NAT gateway is in the process of being terminated and may
- // still be processing traffic.
- //
- // deleted: The NAT gateway has been terminated and is no longer processing
- // traffic.
- State *string `locationName:"state" type:"string" enum:"NatGatewayState"`
- // The ID of the subnet in which the NAT gateway is located.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // The ID of the VPC in which the NAT gateway is located.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s NatGateway) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NatGateway) GoString() string {
- return s.String()
- }
- // Describes the IP addresses and network interface associated with a NAT gateway.
- type NatGatewayAddress struct {
- _ struct{} `type:"structure"`
- // The allocation ID of the Elastic IP address that's associated with the NAT
- // gateway.
- AllocationId *string `locationName:"allocationId" type:"string"`
- // The ID of the network interface associated with the NAT gateway.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // The private IP address associated with the Elastic IP address.
- PrivateIp *string `locationName:"privateIp" type:"string"`
- // The Elastic IP address associated with the NAT gateway.
- PublicIp *string `locationName:"publicIp" type:"string"`
- }
- // String returns the string representation
- func (s NatGatewayAddress) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NatGatewayAddress) GoString() string {
- return s.String()
- }
- // Describes a network ACL.
- type NetworkAcl struct {
- _ struct{} `type:"structure"`
- // Any associations between the network ACL and one or more subnets
- Associations []*NetworkAclAssociation `locationName:"associationSet" locationNameList:"item" type:"list"`
- // One or more entries (rules) in the network ACL.
- Entries []*NetworkAclEntry `locationName:"entrySet" locationNameList:"item" type:"list"`
- // Indicates whether this is the default network ACL for the VPC.
- IsDefault *bool `locationName:"default" type:"boolean"`
- // The ID of the network ACL.
- NetworkAclId *string `locationName:"networkAclId" type:"string"`
- // Any tags assigned to the network ACL.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC for the network ACL.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s NetworkAcl) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkAcl) GoString() string {
- return s.String()
- }
- // Describes an association between a network ACL and a subnet.
- type NetworkAclAssociation struct {
- _ struct{} `type:"structure"`
- // The ID of the association between a network ACL and a subnet.
- NetworkAclAssociationId *string `locationName:"networkAclAssociationId" type:"string"`
- // The ID of the network ACL.
- NetworkAclId *string `locationName:"networkAclId" type:"string"`
- // The ID of the subnet.
- SubnetId *string `locationName:"subnetId" type:"string"`
- }
- // String returns the string representation
- func (s NetworkAclAssociation) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkAclAssociation) GoString() string {
- return s.String()
- }
- // Describes an entry in a network ACL.
- type NetworkAclEntry struct {
- _ struct{} `type:"structure"`
- // The network range to allow or deny, in CIDR notation.
- CidrBlock *string `locationName:"cidrBlock" type:"string"`
- // Indicates whether the rule is an egress rule (applied to traffic leaving
- // the subnet).
- Egress *bool `locationName:"egress" type:"boolean"`
- // ICMP protocol: The ICMP type and code.
- IcmpTypeCode *IcmpTypeCode `locationName:"icmpTypeCode" type:"structure"`
- // TCP or UDP protocols: The range of ports the rule applies to.
- PortRange *PortRange `locationName:"portRange" type:"structure"`
- // The protocol. A value of -1 means all protocols.
- Protocol *string `locationName:"protocol" type:"string"`
- // Indicates whether to allow or deny the traffic that matches the rule.
- RuleAction *string `locationName:"ruleAction" type:"string" enum:"RuleAction"`
- // The rule number for the entry. ACL entries are processed in ascending order
- // by rule number.
- RuleNumber *int64 `locationName:"ruleNumber" type:"integer"`
- }
- // String returns the string representation
- func (s NetworkAclEntry) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkAclEntry) GoString() string {
- return s.String()
- }
- // Describes a network interface.
- type NetworkInterface struct {
- _ struct{} `type:"structure"`
- // The association information for an Elastic IP associated with the network
- // interface.
- Association *NetworkInterfaceAssociation `locationName:"association" type:"structure"`
- // The network interface attachment.
- Attachment *NetworkInterfaceAttachment `locationName:"attachment" type:"structure"`
- // The Availability Zone.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // A description.
- Description *string `locationName:"description" type:"string"`
- // Any security groups for the network interface.
- Groups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // The type of interface.
- InterfaceType *string `locationName:"interfaceType" type:"string" enum:"NetworkInterfaceType"`
- // The MAC address.
- MacAddress *string `locationName:"macAddress" type:"string"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // The AWS account ID of the owner of the network interface.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // The private DNS name.
- PrivateDnsName *string `locationName:"privateDnsName" type:"string"`
- // The IP address of the network interface within the subnet.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // The private IP addresses associated with the network interface.
- PrivateIpAddresses []*NetworkInterfacePrivateIpAddress `locationName:"privateIpAddressesSet" locationNameList:"item" type:"list"`
- // The ID of the entity that launched the instance on your behalf (for example,
- // AWS Management Console or Auto Scaling).
- RequesterId *string `locationName:"requesterId" type:"string"`
- // Indicates whether the network interface is being managed by AWS.
- RequesterManaged *bool `locationName:"requesterManaged" type:"boolean"`
- // Indicates whether traffic to or from the instance is validated.
- SourceDestCheck *bool `locationName:"sourceDestCheck" type:"boolean"`
- // The status of the network interface.
- Status *string `locationName:"status" type:"string" enum:"NetworkInterfaceStatus"`
- // The ID of the subnet.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // Any tags assigned to the network interface.
- TagSet []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s NetworkInterface) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkInterface) GoString() string {
- return s.String()
- }
- // Describes association information for an Elastic IP address.
- type NetworkInterfaceAssociation struct {
- _ struct{} `type:"structure"`
- // The allocation ID.
- AllocationId *string `locationName:"allocationId" type:"string"`
- // The association ID.
- AssociationId *string `locationName:"associationId" type:"string"`
- // The ID of the Elastic IP address owner.
- IpOwnerId *string `locationName:"ipOwnerId" type:"string"`
- // The public DNS name.
- PublicDnsName *string `locationName:"publicDnsName" type:"string"`
- // The address of the Elastic IP address bound to the network interface.
- PublicIp *string `locationName:"publicIp" type:"string"`
- }
- // String returns the string representation
- func (s NetworkInterfaceAssociation) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkInterfaceAssociation) GoString() string {
- return s.String()
- }
- // Describes a network interface attachment.
- type NetworkInterfaceAttachment struct {
- _ struct{} `type:"structure"`
- // The timestamp indicating when the attachment initiated.
- AttachTime *time.Time `locationName:"attachTime" type:"timestamp" timestampFormat:"iso8601"`
- // The ID of the network interface attachment.
- AttachmentId *string `locationName:"attachmentId" type:"string"`
- // Indicates whether the network interface is deleted when the instance is terminated.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- // The device index of the network interface attachment on the instance.
- DeviceIndex *int64 `locationName:"deviceIndex" type:"integer"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The AWS account ID of the owner of the instance.
- InstanceOwnerId *string `locationName:"instanceOwnerId" type:"string"`
- // The attachment state.
- Status *string `locationName:"status" type:"string" enum:"AttachmentStatus"`
- }
- // String returns the string representation
- func (s NetworkInterfaceAttachment) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkInterfaceAttachment) GoString() string {
- return s.String()
- }
- // Describes an attachment change.
- type NetworkInterfaceAttachmentChanges struct {
- _ struct{} `type:"structure"`
- // The ID of the network interface attachment.
- AttachmentId *string `locationName:"attachmentId" type:"string"`
- // Indicates whether the network interface is deleted when the instance is terminated.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- }
- // String returns the string representation
- func (s NetworkInterfaceAttachmentChanges) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkInterfaceAttachmentChanges) GoString() string {
- return s.String()
- }
- // Describes the private IP address of a network interface.
- type NetworkInterfacePrivateIpAddress struct {
- _ struct{} `type:"structure"`
- // The association information for an Elastic IP address associated with the
- // network interface.
- Association *NetworkInterfaceAssociation `locationName:"association" type:"structure"`
- // Indicates whether this IP address is the primary private IP address of the
- // network interface.
- Primary *bool `locationName:"primary" type:"boolean"`
- // The private DNS name.
- PrivateDnsName *string `locationName:"privateDnsName" type:"string"`
- // The private IP address.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- }
- // String returns the string representation
- func (s NetworkInterfacePrivateIpAddress) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NetworkInterfacePrivateIpAddress) GoString() string {
- return s.String()
- }
- type NewDhcpConfiguration struct {
- _ struct{} `type:"structure"`
- Key *string `locationName:"key" type:"string"`
- Values []*string `locationName:"Value" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s NewDhcpConfiguration) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s NewDhcpConfiguration) GoString() string {
- return s.String()
- }
- // Describes the VPC peering connection options.
- type PeeringConnectionOptions struct {
- _ struct{} `type:"structure"`
- // If true, enables a local VPC to resolve public DNS hostnames to private IP
- // addresses when queried from instances in the peer VPC.
- AllowDnsResolutionFromRemoteVpc *bool `locationName:"allowDnsResolutionFromRemoteVpc" type:"boolean"`
- // If true, enables outbound communication from an EC2-Classic instance that's
- // linked to a local VPC via ClassicLink to instances in a peer VPC.
- AllowEgressFromLocalClassicLinkToRemoteVpc *bool `locationName:"allowEgressFromLocalClassicLinkToRemoteVpc" type:"boolean"`
- // If true, enables outbound communication from instances in a local VPC to
- // an EC2-Classic instance that's linked to a peer VPC via ClassicLink.
- AllowEgressFromLocalVpcToRemoteClassicLink *bool `locationName:"allowEgressFromLocalVpcToRemoteClassicLink" type:"boolean"`
- }
- // String returns the string representation
- func (s PeeringConnectionOptions) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PeeringConnectionOptions) GoString() string {
- return s.String()
- }
- // The VPC peering connection options.
- type PeeringConnectionOptionsRequest struct {
- _ struct{} `type:"structure"`
- // If true, enables a local VPC to resolve public DNS hostnames to private IP
- // addresses when queried from instances in the peer VPC.
- AllowDnsResolutionFromRemoteVpc *bool `type:"boolean"`
- // If true, enables outbound communication from an EC2-Classic instance that's
- // linked to a local VPC via ClassicLink to instances in a peer VPC.
- AllowEgressFromLocalClassicLinkToRemoteVpc *bool `type:"boolean"`
- // If true, enables outbound communication from instances in a local VPC to
- // an EC2-Classic instance that's linked to a peer VPC via ClassicLink.
- AllowEgressFromLocalVpcToRemoteClassicLink *bool `type:"boolean"`
- }
- // String returns the string representation
- func (s PeeringConnectionOptionsRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PeeringConnectionOptionsRequest) GoString() string {
- return s.String()
- }
- // Describes the placement for the instance.
- type Placement struct {
- _ struct{} `type:"structure"`
- // The affinity setting for the instance on the Dedicated host. This parameter
- // is not supported for the ImportInstance command.
- Affinity *string `locationName:"affinity" type:"string"`
- // The Availability Zone of the instance.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The name of the placement group the instance is in (for cluster compute instances).
- GroupName *string `locationName:"groupName" type:"string"`
- // The ID of the Dedicted host on which the instance resides. This parameter
- // is not support for the ImportInstance command.
- HostId *string `locationName:"hostId" type:"string"`
- // The tenancy of the instance (if the instance is running in a VPC). An instance
- // with a tenancy of dedicated runs on single-tenant hardware. The host tenancy
- // is not supported for the ImportInstance command.
- Tenancy *string `locationName:"tenancy" type:"string" enum:"Tenancy"`
- }
- // String returns the string representation
- func (s Placement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Placement) GoString() string {
- return s.String()
- }
- // Describes a placement group.
- type PlacementGroup struct {
- _ struct{} `type:"structure"`
- // The name of the placement group.
- GroupName *string `locationName:"groupName" type:"string"`
- // The state of the placement group.
- State *string `locationName:"state" type:"string" enum:"PlacementGroupState"`
- // The placement strategy.
- Strategy *string `locationName:"strategy" type:"string" enum:"PlacementStrategy"`
- }
- // String returns the string representation
- func (s PlacementGroup) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PlacementGroup) GoString() string {
- return s.String()
- }
- // Describes a range of ports.
- type PortRange struct {
- _ struct{} `type:"structure"`
- // The first port in the range.
- From *int64 `locationName:"from" type:"integer"`
- // The last port in the range.
- To *int64 `locationName:"to" type:"integer"`
- }
- // String returns the string representation
- func (s PortRange) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PortRange) GoString() string {
- return s.String()
- }
- // Describes prefixes for AWS services.
- type PrefixList struct {
- _ struct{} `type:"structure"`
- // The IP address range of the AWS service.
- Cidrs []*string `locationName:"cidrSet" locationNameList:"item" type:"list"`
- // The ID of the prefix.
- PrefixListId *string `locationName:"prefixListId" type:"string"`
- // The name of the prefix.
- PrefixListName *string `locationName:"prefixListName" type:"string"`
- }
- // String returns the string representation
- func (s PrefixList) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PrefixList) GoString() string {
- return s.String()
- }
- // The ID of the prefix.
- type PrefixListId struct {
- _ struct{} `type:"structure"`
- // The ID of the prefix.
- PrefixListId *string `locationName:"prefixListId" type:"string"`
- }
- // String returns the string representation
- func (s PrefixListId) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PrefixListId) GoString() string {
- return s.String()
- }
- // Describes the price for a Reserved Instance.
- type PriceSchedule struct {
- _ struct{} `type:"structure"`
- // The current price schedule, as determined by the term remaining for the Reserved
- // Instance in the listing.
- //
- // A specific price schedule is always in effect, but only one price schedule
- // can be active at any time. Take, for example, a Reserved Instance listing
- // that has five months remaining in its term. When you specify price schedules
- // for five months and two months, this means that schedule 1, covering the
- // first three months of the remaining term, will be active during months 5,
- // 4, and 3. Then schedule 2, covering the last two months of the term, will
- // be active for months 2 and 1.
- Active *bool `locationName:"active" type:"boolean"`
- // The currency for transacting the Reserved Instance resale. At this time,
- // the only supported currency is USD.
- CurrencyCode *string `locationName:"currencyCode" type:"string" enum:"CurrencyCodeValues"`
- // The fixed price for the term.
- Price *float64 `locationName:"price" type:"double"`
- // The number of months remaining in the reservation. For example, 2 is the
- // second to the last month before the capacity reservation expires.
- Term *int64 `locationName:"term" type:"long"`
- }
- // String returns the string representation
- func (s PriceSchedule) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PriceSchedule) GoString() string {
- return s.String()
- }
- // Describes the price for a Reserved Instance.
- type PriceScheduleSpecification struct {
- _ struct{} `type:"structure"`
- // The currency for transacting the Reserved Instance resale. At this time,
- // the only supported currency is USD.
- CurrencyCode *string `locationName:"currencyCode" type:"string" enum:"CurrencyCodeValues"`
- // The fixed price for the term.
- Price *float64 `locationName:"price" type:"double"`
- // The number of months remaining in the reservation. For example, 2 is the
- // second to the last month before the capacity reservation expires.
- Term *int64 `locationName:"term" type:"long"`
- }
- // String returns the string representation
- func (s PriceScheduleSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PriceScheduleSpecification) GoString() string {
- return s.String()
- }
- // Describes a Reserved Instance offering.
- type PricingDetail struct {
- _ struct{} `type:"structure"`
- // The number of reservations available for the price.
- Count *int64 `locationName:"count" type:"integer"`
- // The price per instance.
- Price *float64 `locationName:"price" type:"double"`
- }
- // String returns the string representation
- func (s PricingDetail) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PricingDetail) GoString() string {
- return s.String()
- }
- // Describes a secondary private IP address for a network interface.
- type PrivateIpAddressSpecification struct {
- _ struct{} `type:"structure"`
- // Indicates whether the private IP address is the primary private IP address.
- // Only one IP address can be designated as primary.
- Primary *bool `locationName:"primary" type:"boolean"`
- // The private IP addresses.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s PrivateIpAddressSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PrivateIpAddressSpecification) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PrivateIpAddressSpecification) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PrivateIpAddressSpecification"}
- if s.PrivateIpAddress == nil {
- invalidParams.Add(request.NewErrParamRequired("PrivateIpAddress"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a product code.
- type ProductCode struct {
- _ struct{} `type:"structure"`
- // The product code.
- ProductCodeId *string `locationName:"productCode" type:"string"`
- // The type of product code.
- ProductCodeType *string `locationName:"type" type:"string" enum:"ProductCodeValues"`
- }
- // String returns the string representation
- func (s ProductCode) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ProductCode) GoString() string {
- return s.String()
- }
- // Describes a virtual private gateway propagating route.
- type PropagatingVgw struct {
- _ struct{} `type:"structure"`
- // The ID of the virtual private gateway (VGW).
- GatewayId *string `locationName:"gatewayId" type:"string"`
- }
- // String returns the string representation
- func (s PropagatingVgw) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PropagatingVgw) GoString() string {
- return s.String()
- }
- // Reserved. If you need to sustain traffic greater than the documented limits
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html),
- // contact us through the Support Center (https://console.aws.amazon.com/support/home?).
- type ProvisionedBandwidth struct {
- _ struct{} `type:"structure"`
- // Reserved. If you need to sustain traffic greater than the documented limits
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html),
- // contact us through the Support Center (https://console.aws.amazon.com/support/home?).
- ProvisionTime *time.Time `locationName:"provisionTime" type:"timestamp" timestampFormat:"iso8601"`
- // Reserved. If you need to sustain traffic greater than the documented limits
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html),
- // contact us through the Support Center (https://console.aws.amazon.com/support/home?).
- Provisioned *string `locationName:"provisioned" type:"string"`
- // Reserved. If you need to sustain traffic greater than the documented limits
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html),
- // contact us through the Support Center (https://console.aws.amazon.com/support/home?).
- RequestTime *time.Time `locationName:"requestTime" type:"timestamp" timestampFormat:"iso8601"`
- // Reserved. If you need to sustain traffic greater than the documented limits
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html),
- // contact us through the Support Center (https://console.aws.amazon.com/support/home?).
- Requested *string `locationName:"requested" type:"string"`
- // Reserved. If you need to sustain traffic greater than the documented limits
- // (http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/vpc-nat-gateway.html),
- // contact us through the Support Center (https://console.aws.amazon.com/support/home?).
- Status *string `locationName:"status" type:"string"`
- }
- // String returns the string representation
- func (s ProvisionedBandwidth) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ProvisionedBandwidth) GoString() string {
- return s.String()
- }
- // Describes a request to purchase Scheduled Instances.
- type PurchaseRequest struct {
- _ struct{} `type:"structure"`
- // The number of instances.
- InstanceCount *int64 `type:"integer" required:"true"`
- // The purchase token.
- PurchaseToken *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s PurchaseRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PurchaseRequest) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PurchaseRequest) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PurchaseRequest"}
- if s.InstanceCount == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceCount"))
- }
- if s.PurchaseToken == nil {
- invalidParams.Add(request.NewErrParamRequired("PurchaseToken"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the parameters for PurchaseReservedInstancesOffering.
- type PurchaseReservedInstancesOfferingInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The number of Reserved Instances to purchase.
- InstanceCount *int64 `type:"integer" required:"true"`
- // Specified for Reserved Instance Marketplace offerings to limit the total
- // order and ensure that the Reserved Instances are not purchased at unexpected
- // prices.
- LimitPrice *ReservedInstanceLimitPrice `locationName:"limitPrice" type:"structure"`
- // The ID of the Reserved Instance offering to purchase.
- ReservedInstancesOfferingId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s PurchaseReservedInstancesOfferingInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PurchaseReservedInstancesOfferingInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PurchaseReservedInstancesOfferingInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PurchaseReservedInstancesOfferingInput"}
- if s.InstanceCount == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceCount"))
- }
- if s.ReservedInstancesOfferingId == nil {
- invalidParams.Add(request.NewErrParamRequired("ReservedInstancesOfferingId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of PurchaseReservedInstancesOffering.
- type PurchaseReservedInstancesOfferingOutput struct {
- _ struct{} `type:"structure"`
- // The IDs of the purchased Reserved Instances.
- ReservedInstancesId *string `locationName:"reservedInstancesId" type:"string"`
- }
- // String returns the string representation
- func (s PurchaseReservedInstancesOfferingOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PurchaseReservedInstancesOfferingOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for PurchaseScheduledInstances.
- type PurchaseScheduledInstancesInput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier that ensures the idempotency of the request.
- // For more information, see Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `type:"string" idempotencyToken:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // One or more purchase requests.
- PurchaseRequests []*PurchaseRequest `locationName:"PurchaseRequest" locationNameList:"PurchaseRequest" min:"1" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s PurchaseScheduledInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PurchaseScheduledInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PurchaseScheduledInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PurchaseScheduledInstancesInput"}
- if s.PurchaseRequests == nil {
- invalidParams.Add(request.NewErrParamRequired("PurchaseRequests"))
- }
- if s.PurchaseRequests != nil && len(s.PurchaseRequests) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("PurchaseRequests", 1))
- }
- if s.PurchaseRequests != nil {
- for i, v := range s.PurchaseRequests {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "PurchaseRequests", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of PurchaseScheduledInstances.
- type PurchaseScheduledInstancesOutput struct {
- _ struct{} `type:"structure"`
- // Information about the Scheduled Instances.
- ScheduledInstanceSet []*ScheduledInstance `locationName:"scheduledInstanceSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s PurchaseScheduledInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s PurchaseScheduledInstancesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for RebootInstances.
- type RebootInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more instance IDs.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s RebootInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RebootInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RebootInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RebootInstancesInput"}
- if s.InstanceIds == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type RebootInstancesOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s RebootInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RebootInstancesOutput) GoString() string {
- return s.String()
- }
- // Describes a recurring charge.
- type RecurringCharge struct {
- _ struct{} `type:"structure"`
- // The amount of the recurring charge.
- Amount *float64 `locationName:"amount" type:"double"`
- // The frequency of the recurring charge.
- Frequency *string `locationName:"frequency" type:"string" enum:"RecurringChargeFrequency"`
- }
- // String returns the string representation
- func (s RecurringCharge) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RecurringCharge) GoString() string {
- return s.String()
- }
- // Describes a region.
- type Region struct {
- _ struct{} `type:"structure"`
- // The region service endpoint.
- Endpoint *string `locationName:"regionEndpoint" type:"string"`
- // The name of the region.
- RegionName *string `locationName:"regionName" type:"string"`
- }
- // String returns the string representation
- func (s Region) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Region) GoString() string {
- return s.String()
- }
- // Contains the parameters for RegisterImage.
- type RegisterImageInput struct {
- _ struct{} `type:"structure"`
- // The architecture of the AMI.
- //
- // Default: For Amazon EBS-backed AMIs, i386. For instance store-backed AMIs,
- // the architecture specified in the manifest file.
- Architecture *string `locationName:"architecture" type:"string" enum:"ArchitectureValues"`
- // One or more block device mapping entries.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"BlockDeviceMapping" locationNameList:"BlockDeviceMapping" type:"list"`
- // A description for your AMI.
- Description *string `locationName:"description" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Set to true to enable enhanced networking with ENA for the AMI and any instances
- // that you launch from the AMI.
- //
- // This option is supported only for HVM AMIs. Specifying this option with
- // a PV AMI can make instances launched from the AMI unreachable.
- EnaSupport *bool `locationName:"enaSupport" type:"boolean"`
- // The full path to your AMI manifest in Amazon S3 storage.
- ImageLocation *string `type:"string"`
- // The ID of the kernel.
- KernelId *string `locationName:"kernelId" type:"string"`
- // A name for your AMI.
- //
- // Constraints: 3-128 alphanumeric characters, parentheses (()), square brackets
- // ([]), spaces ( ), periods (.), slashes (/), dashes (-), single quotes ('),
- // at-signs (@), or underscores(_)
- Name *string `locationName:"name" type:"string" required:"true"`
- // The ID of the RAM disk.
- RamdiskId *string `locationName:"ramdiskId" type:"string"`
- // The name of the root device (for example, /dev/sda1, or /dev/xvda).
- RootDeviceName *string `locationName:"rootDeviceName" type:"string"`
- // Set to simple to enable enhanced networking with the Intel 82599 Virtual
- // Function interface for the AMI and any instances that you launch from the
- // AMI.
- //
- // There is no way to disable sriovNetSupport at this time.
- //
- // This option is supported only for HVM AMIs. Specifying this option with
- // a PV AMI can make instances launched from the AMI unreachable.
- SriovNetSupport *string `locationName:"sriovNetSupport" type:"string"`
- // The type of virtualization.
- //
- // Default: paravirtual
- VirtualizationType *string `locationName:"virtualizationType" type:"string"`
- }
- // String returns the string representation
- func (s RegisterImageInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RegisterImageInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RegisterImageInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RegisterImageInput"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of RegisterImage.
- type RegisterImageOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the newly registered AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- }
- // String returns the string representation
- func (s RegisterImageOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RegisterImageOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for RejectVpcPeeringConnection.
- type RejectVpcPeeringConnectionInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s RejectVpcPeeringConnectionInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RejectVpcPeeringConnectionInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RejectVpcPeeringConnectionInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RejectVpcPeeringConnectionInput"}
- if s.VpcPeeringConnectionId == nil {
- invalidParams.Add(request.NewErrParamRequired("VpcPeeringConnectionId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of RejectVpcPeeringConnection.
- type RejectVpcPeeringConnectionOutput struct {
- _ struct{} `type:"structure"`
- // Returns true if the request succeeds; otherwise, it returns an error.
- Return *bool `locationName:"return" type:"boolean"`
- }
- // String returns the string representation
- func (s RejectVpcPeeringConnectionOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RejectVpcPeeringConnectionOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ReleaseAddress.
- type ReleaseAddressInput struct {
- _ struct{} `type:"structure"`
- // [EC2-VPC] The allocation ID. Required for EC2-VPC.
- AllocationId *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // [EC2-Classic] The Elastic IP address. Required for EC2-Classic.
- PublicIp *string `type:"string"`
- }
- // String returns the string representation
- func (s ReleaseAddressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReleaseAddressInput) GoString() string {
- return s.String()
- }
- type ReleaseAddressOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ReleaseAddressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReleaseAddressOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ReleaseHosts.
- type ReleaseHostsInput struct {
- _ struct{} `type:"structure"`
- // The IDs of the Dedicated hosts you want to release.
- HostIds []*string `locationName:"hostId" locationNameList:"item" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s ReleaseHostsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReleaseHostsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ReleaseHostsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ReleaseHostsInput"}
- if s.HostIds == nil {
- invalidParams.Add(request.NewErrParamRequired("HostIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ReleaseHosts.
- type ReleaseHostsOutput struct {
- _ struct{} `type:"structure"`
- // The IDs of the Dedicated hosts that were successfully released.
- Successful []*string `locationName:"successful" locationNameList:"item" type:"list"`
- // The IDs of the Dedicated hosts that could not be released, including an error
- // message.
- Unsuccessful []*UnsuccessfulItem `locationName:"unsuccessful" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s ReleaseHostsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReleaseHostsOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ReplaceNetworkAclAssociation.
- type ReplaceNetworkAclAssociationInput struct {
- _ struct{} `type:"structure"`
- // The ID of the current association between the original network ACL and the
- // subnet.
- AssociationId *string `locationName:"associationId" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the new network ACL to associate with the subnet.
- NetworkAclId *string `locationName:"networkAclId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ReplaceNetworkAclAssociationInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceNetworkAclAssociationInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ReplaceNetworkAclAssociationInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ReplaceNetworkAclAssociationInput"}
- if s.AssociationId == nil {
- invalidParams.Add(request.NewErrParamRequired("AssociationId"))
- }
- if s.NetworkAclId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkAclId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ReplaceNetworkAclAssociation.
- type ReplaceNetworkAclAssociationOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the new association.
- NewAssociationId *string `locationName:"newAssociationId" type:"string"`
- }
- // String returns the string representation
- func (s ReplaceNetworkAclAssociationOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceNetworkAclAssociationOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ReplaceNetworkAclEntry.
- type ReplaceNetworkAclEntryInput struct {
- _ struct{} `type:"structure"`
- // The network range to allow or deny, in CIDR notation.
- CidrBlock *string `locationName:"cidrBlock" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Indicates whether to replace the egress rule.
- //
- // Default: If no value is specified, we replace the ingress rule.
- Egress *bool `locationName:"egress" type:"boolean" required:"true"`
- // ICMP protocol: The ICMP type and code. Required if specifying 1 (ICMP) for
- // the protocol.
- IcmpTypeCode *IcmpTypeCode `locationName:"Icmp" type:"structure"`
- // The ID of the ACL.
- NetworkAclId *string `locationName:"networkAclId" type:"string" required:"true"`
- // TCP or UDP protocols: The range of ports the rule applies to. Required if
- // specifying 6 (TCP) or 17 (UDP) for the protocol.
- PortRange *PortRange `locationName:"portRange" type:"structure"`
- // The IP protocol. You can specify all or -1 to mean all protocols.
- Protocol *string `locationName:"protocol" type:"string" required:"true"`
- // Indicates whether to allow or deny the traffic that matches the rule.
- RuleAction *string `locationName:"ruleAction" type:"string" required:"true" enum:"RuleAction"`
- // The rule number of the entry to replace.
- RuleNumber *int64 `locationName:"ruleNumber" type:"integer" required:"true"`
- }
- // String returns the string representation
- func (s ReplaceNetworkAclEntryInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceNetworkAclEntryInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ReplaceNetworkAclEntryInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ReplaceNetworkAclEntryInput"}
- if s.CidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("CidrBlock"))
- }
- if s.Egress == nil {
- invalidParams.Add(request.NewErrParamRequired("Egress"))
- }
- if s.NetworkAclId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkAclId"))
- }
- if s.Protocol == nil {
- invalidParams.Add(request.NewErrParamRequired("Protocol"))
- }
- if s.RuleAction == nil {
- invalidParams.Add(request.NewErrParamRequired("RuleAction"))
- }
- if s.RuleNumber == nil {
- invalidParams.Add(request.NewErrParamRequired("RuleNumber"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ReplaceNetworkAclEntryOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ReplaceNetworkAclEntryOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceNetworkAclEntryOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ReplaceRoute.
- type ReplaceRouteInput struct {
- _ struct{} `type:"structure"`
- // The CIDR address block used for the destination match. The value you provide
- // must match the CIDR of an existing route in the table.
- DestinationCidrBlock *string `locationName:"destinationCidrBlock" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of an Internet gateway or virtual private gateway.
- GatewayId *string `locationName:"gatewayId" type:"string"`
- // The ID of a NAT instance in your VPC.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The ID of a NAT gateway.
- NatGatewayId *string `locationName:"natGatewayId" type:"string"`
- // The ID of a network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // The ID of the route table.
- RouteTableId *string `locationName:"routeTableId" type:"string" required:"true"`
- // The ID of a VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string"`
- }
- // String returns the string representation
- func (s ReplaceRouteInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceRouteInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ReplaceRouteInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ReplaceRouteInput"}
- if s.DestinationCidrBlock == nil {
- invalidParams.Add(request.NewErrParamRequired("DestinationCidrBlock"))
- }
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ReplaceRouteOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ReplaceRouteOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceRouteOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ReplaceRouteTableAssociation.
- type ReplaceRouteTableAssociationInput struct {
- _ struct{} `type:"structure"`
- // The association ID.
- AssociationId *string `locationName:"associationId" type:"string" required:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the new route table to associate with the subnet.
- RouteTableId *string `locationName:"routeTableId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ReplaceRouteTableAssociationInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceRouteTableAssociationInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ReplaceRouteTableAssociationInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ReplaceRouteTableAssociationInput"}
- if s.AssociationId == nil {
- invalidParams.Add(request.NewErrParamRequired("AssociationId"))
- }
- if s.RouteTableId == nil {
- invalidParams.Add(request.NewErrParamRequired("RouteTableId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of ReplaceRouteTableAssociation.
- type ReplaceRouteTableAssociationOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the new association.
- NewAssociationId *string `locationName:"newAssociationId" type:"string"`
- }
- // String returns the string representation
- func (s ReplaceRouteTableAssociationOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReplaceRouteTableAssociationOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ReportInstanceStatus.
- type ReportInstanceStatusInput struct {
- _ struct{} `type:"structure"`
- // Descriptive text about the health state of your instance.
- Description *string `locationName:"description" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The time at which the reported instance health state ended.
- EndTime *time.Time `locationName:"endTime" type:"timestamp" timestampFormat:"iso8601"`
- // One or more instances.
- Instances []*string `locationName:"instanceId" locationNameList:"InstanceId" type:"list" required:"true"`
- // One or more reason codes that describes the health state of your instance.
- //
- // instance-stuck-in-state: My instance is stuck in a state.
- //
- // unresponsive: My instance is unresponsive.
- //
- // not-accepting-credentials: My instance is not accepting my credentials.
- //
- // password-not-available: A password is not available for my instance.
- //
- // performance-network: My instance is experiencing performance problems
- // which I believe are network related.
- //
- // performance-instance-store: My instance is experiencing performance problems
- // which I believe are related to the instance stores.
- //
- // performance-ebs-volume: My instance is experiencing performance problems
- // which I believe are related to an EBS volume.
- //
- // performance-other: My instance is experiencing performance problems.
- //
- // other: [explain using the description parameter]
- ReasonCodes []*string `locationName:"reasonCode" locationNameList:"item" type:"list" required:"true"`
- // The time at which the reported instance health state began.
- StartTime *time.Time `locationName:"startTime" type:"timestamp" timestampFormat:"iso8601"`
- // The status of all instances listed.
- Status *string `locationName:"status" type:"string" required:"true" enum:"ReportStatusType"`
- }
- // String returns the string representation
- func (s ReportInstanceStatusInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReportInstanceStatusInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ReportInstanceStatusInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ReportInstanceStatusInput"}
- if s.Instances == nil {
- invalidParams.Add(request.NewErrParamRequired("Instances"))
- }
- if s.ReasonCodes == nil {
- invalidParams.Add(request.NewErrParamRequired("ReasonCodes"))
- }
- if s.Status == nil {
- invalidParams.Add(request.NewErrParamRequired("Status"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ReportInstanceStatusOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ReportInstanceStatusOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReportInstanceStatusOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for RequestSpotFleet.
- type RequestSpotFleetInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The configuration for the Spot fleet request.
- SpotFleetRequestConfig *SpotFleetRequestConfigData `locationName:"spotFleetRequestConfig" type:"structure" required:"true"`
- }
- // String returns the string representation
- func (s RequestSpotFleetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RequestSpotFleetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RequestSpotFleetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RequestSpotFleetInput"}
- if s.SpotFleetRequestConfig == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotFleetRequestConfig"))
- }
- if s.SpotFleetRequestConfig != nil {
- if err := s.SpotFleetRequestConfig.Validate(); err != nil {
- invalidParams.AddNested("SpotFleetRequestConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of RequestSpotFleet.
- type RequestSpotFleetOutput struct {
- _ struct{} `type:"structure"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s RequestSpotFleetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RequestSpotFleetOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for RequestSpotInstances.
- type RequestSpotInstancesInput struct {
- _ struct{} `type:"structure"`
- // The user-specified name for a logical grouping of bids.
- //
- // When you specify an Availability Zone group in a Spot Instance request,
- // all Spot instances in the request are launched in the same Availability Zone.
- // Instance proximity is maintained with this parameter, but the choice of Availability
- // Zone is not. The group applies only to bids for Spot Instances of the same
- // instance type. Any additional Spot instance requests that are specified with
- // the same Availability Zone group name are launched in that same Availability
- // Zone, as long as at least one instance from the group is still active.
- //
- // If there is no active instance running in the Availability Zone group that
- // you specify for a new Spot instance request (all instances are terminated,
- // the bid is expired, or the bid falls below current market), then Amazon EC2
- // launches the instance in any Availability Zone where the constraint can be
- // met. Consequently, the subsequent set of Spot instances could be placed in
- // a different zone from the original request, even if you specified the same
- // Availability Zone group.
- //
- // Default: Instances are launched in any available Availability Zone.
- AvailabilityZoneGroup *string `locationName:"availabilityZoneGroup" type:"string"`
- // The required duration for the Spot instances (also known as Spot blocks),
- // in minutes. This value must be a multiple of 60 (60, 120, 180, 240, 300,
- // or 360).
- //
- // The duration period starts as soon as your Spot instance receives its instance
- // ID. At the end of the duration period, Amazon EC2 marks the Spot instance
- // for termination and provides a Spot instance termination notice, which gives
- // the instance a two-minute warning before it terminates.
- //
- // Note that you can't specify an Availability Zone group or a launch group
- // if you specify a duration.
- BlockDurationMinutes *int64 `locationName:"blockDurationMinutes" type:"integer"`
- // Unique, case-sensitive identifier that you provide to ensure the idempotency
- // of the request. For more information, see How to Ensure Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- ClientToken *string `locationName:"clientToken" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The maximum number of Spot instances to launch.
- //
- // Default: 1
- InstanceCount *int64 `locationName:"instanceCount" type:"integer"`
- // The instance launch group. Launch groups are Spot instances that launch together
- // and terminate together.
- //
- // Default: Instances are launched and terminated individually
- LaunchGroup *string `locationName:"launchGroup" type:"string"`
- // Describes the launch specification for an instance.
- LaunchSpecification *RequestSpotLaunchSpecification `type:"structure"`
- // The maximum hourly price (bid) for any Spot instance launched to fulfill
- // the request.
- SpotPrice *string `locationName:"spotPrice" type:"string" required:"true"`
- // The Spot instance request type.
- //
- // Default: one-time
- Type *string `locationName:"type" type:"string" enum:"SpotInstanceType"`
- // The start date of the request. If this is a one-time request, the request
- // becomes active at this date and time and remains active until all instances
- // launch, the request expires, or the request is canceled. If the request is
- // persistent, the request becomes active at this date and time and remains
- // active until it expires or is canceled.
- //
- // Default: The request is effective indefinitely.
- ValidFrom *time.Time `locationName:"validFrom" type:"timestamp" timestampFormat:"iso8601"`
- // The end date of the request. If this is a one-time request, the request remains
- // active until all instances launch, the request is canceled, or this date
- // is reached. If the request is persistent, it remains active until it is canceled
- // or this date and time is reached.
- //
- // Default: The request is effective indefinitely.
- ValidUntil *time.Time `locationName:"validUntil" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s RequestSpotInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RequestSpotInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RequestSpotInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RequestSpotInstancesInput"}
- if s.SpotPrice == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotPrice"))
- }
- if s.LaunchSpecification != nil {
- if err := s.LaunchSpecification.Validate(); err != nil {
- invalidParams.AddNested("LaunchSpecification", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of RequestSpotInstances.
- type RequestSpotInstancesOutput struct {
- _ struct{} `type:"structure"`
- // One or more Spot instance requests.
- SpotInstanceRequests []*SpotInstanceRequest `locationName:"spotInstanceRequestSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s RequestSpotInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RequestSpotInstancesOutput) GoString() string {
- return s.String()
- }
- // Describes the launch specification for an instance.
- type RequestSpotLaunchSpecification struct {
- _ struct{} `type:"structure"`
- // Deprecated.
- AddressingType *string `locationName:"addressingType" type:"string"`
- // One or more block device mapping entries.
- //
- // Although you can specify encrypted EBS volumes in this block device mapping
- // for your Spot Instances, these volumes are not encrypted.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // Indicates whether the instance is optimized for EBS I/O. This optimization
- // provides dedicated throughput to Amazon EBS and an optimized configuration
- // stack to provide optimal EBS I/O performance. This optimization isn't available
- // with all instance types. Additional usage charges apply when using an EBS
- // Optimized instance.
- //
- // Default: false
- EbsOptimized *bool `locationName:"ebsOptimized" type:"boolean"`
- // The IAM instance profile.
- IamInstanceProfile *IamInstanceProfileSpecification `locationName:"iamInstanceProfile" type:"structure"`
- // The ID of the AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- // The instance type.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // The ID of the kernel.
- KernelId *string `locationName:"kernelId" type:"string"`
- // The name of the key pair.
- KeyName *string `locationName:"keyName" type:"string"`
- // Describes the monitoring for the instance.
- Monitoring *RunInstancesMonitoringEnabled `locationName:"monitoring" type:"structure"`
- // One or more network interfaces.
- NetworkInterfaces []*InstanceNetworkInterfaceSpecification `locationName:"NetworkInterface" locationNameList:"item" type:"list"`
- // The placement information for the instance.
- Placement *SpotPlacement `locationName:"placement" type:"structure"`
- // The ID of the RAM disk.
- RamdiskId *string `locationName:"ramdiskId" type:"string"`
- SecurityGroupIds []*string `locationName:"SecurityGroupId" locationNameList:"item" type:"list"`
- SecurityGroups []*string `locationName:"SecurityGroup" locationNameList:"item" type:"list"`
- // The ID of the subnet in which to launch the instance.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // The user data to make available to the instances. If you are using an AWS
- // SDK or command line tool, Base64-encoding is performed for you, and you can
- // load the text from a file. Otherwise, you must provide Base64-encoded text.
- UserData *string `locationName:"userData" type:"string"`
- }
- // String returns the string representation
- func (s RequestSpotLaunchSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RequestSpotLaunchSpecification) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RequestSpotLaunchSpecification) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RequestSpotLaunchSpecification"}
- if s.Monitoring != nil {
- if err := s.Monitoring.Validate(); err != nil {
- invalidParams.AddNested("Monitoring", err.(request.ErrInvalidParams))
- }
- }
- if s.NetworkInterfaces != nil {
- for i, v := range s.NetworkInterfaces {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "NetworkInterfaces", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a reservation.
- type Reservation struct {
- _ struct{} `type:"structure"`
- // [EC2-Classic only] One or more security groups.
- Groups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // One or more instances.
- Instances []*Instance `locationName:"instancesSet" locationNameList:"item" type:"list"`
- // The ID of the AWS account that owns the reservation.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // The ID of the requester that launched the instances on your behalf (for example,
- // AWS Management Console or Auto Scaling).
- RequesterId *string `locationName:"requesterId" type:"string"`
- // The ID of the reservation.
- ReservationId *string `locationName:"reservationId" type:"string"`
- }
- // String returns the string representation
- func (s Reservation) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Reservation) GoString() string {
- return s.String()
- }
- // Describes the limit price of a Reserved Instance offering.
- type ReservedInstanceLimitPrice struct {
- _ struct{} `type:"structure"`
- // Used for Reserved Instance Marketplace offerings. Specifies the limit price
- // on the total order (instanceCount * price).
- Amount *float64 `locationName:"amount" type:"double"`
- // The currency in which the limitPrice amount is specified. At this time, the
- // only supported currency is USD.
- CurrencyCode *string `locationName:"currencyCode" type:"string" enum:"CurrencyCodeValues"`
- }
- // String returns the string representation
- func (s ReservedInstanceLimitPrice) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstanceLimitPrice) GoString() string {
- return s.String()
- }
- // Describes a Reserved Instance.
- type ReservedInstances struct {
- _ struct{} `type:"structure"`
- // The Availability Zone in which the Reserved Instance can be used.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The currency of the Reserved Instance. It's specified using ISO 4217 standard
- // currency codes. At this time, the only supported currency is USD.
- CurrencyCode *string `locationName:"currencyCode" type:"string" enum:"CurrencyCodeValues"`
- // The duration of the Reserved Instance, in seconds.
- Duration *int64 `locationName:"duration" type:"long"`
- // The time when the Reserved Instance expires.
- End *time.Time `locationName:"end" type:"timestamp" timestampFormat:"iso8601"`
- // The purchase price of the Reserved Instance.
- FixedPrice *float64 `locationName:"fixedPrice" type:"float"`
- // The number of reservations purchased.
- InstanceCount *int64 `locationName:"instanceCount" type:"integer"`
- // The tenancy of the instance.
- InstanceTenancy *string `locationName:"instanceTenancy" type:"string" enum:"Tenancy"`
- // The instance type on which the Reserved Instance can be used.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // The Reserved Instance offering type.
- OfferingType *string `locationName:"offeringType" type:"string" enum:"OfferingTypeValues"`
- // The Reserved Instance product platform description.
- ProductDescription *string `locationName:"productDescription" type:"string" enum:"RIProductDescription"`
- // The recurring charge tag assigned to the resource.
- RecurringCharges []*RecurringCharge `locationName:"recurringCharges" locationNameList:"item" type:"list"`
- // The ID of the Reserved Instance.
- ReservedInstancesId *string `locationName:"reservedInstancesId" type:"string"`
- // The date and time the Reserved Instance started.
- Start *time.Time `locationName:"start" type:"timestamp" timestampFormat:"iso8601"`
- // The state of the Reserved Instance purchase.
- State *string `locationName:"state" type:"string" enum:"ReservedInstanceState"`
- // Any tags assigned to the resource.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The usage price of the Reserved Instance, per hour.
- UsagePrice *float64 `locationName:"usagePrice" type:"float"`
- }
- // String returns the string representation
- func (s ReservedInstances) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstances) GoString() string {
- return s.String()
- }
- // Describes the configuration settings for the modified Reserved Instances.
- type ReservedInstancesConfiguration struct {
- _ struct{} `type:"structure"`
- // The Availability Zone for the modified Reserved Instances.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The number of modified Reserved Instances.
- InstanceCount *int64 `locationName:"instanceCount" type:"integer"`
- // The instance type for the modified Reserved Instances.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // The network platform of the modified Reserved Instances, which is either
- // EC2-Classic or EC2-VPC.
- Platform *string `locationName:"platform" type:"string"`
- }
- // String returns the string representation
- func (s ReservedInstancesConfiguration) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstancesConfiguration) GoString() string {
- return s.String()
- }
- // Describes the ID of a Reserved Instance.
- type ReservedInstancesId struct {
- _ struct{} `type:"structure"`
- // The ID of the Reserved Instance.
- ReservedInstancesId *string `locationName:"reservedInstancesId" type:"string"`
- }
- // String returns the string representation
- func (s ReservedInstancesId) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstancesId) GoString() string {
- return s.String()
- }
- // Describes a Reserved Instance listing.
- type ReservedInstancesListing struct {
- _ struct{} `type:"structure"`
- // A unique, case-sensitive key supplied by the client to ensure that the request
- // is idempotent. For more information, see Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `locationName:"clientToken" type:"string"`
- // The time the listing was created.
- CreateDate *time.Time `locationName:"createDate" type:"timestamp" timestampFormat:"iso8601"`
- // The number of instances in this state.
- InstanceCounts []*InstanceCount `locationName:"instanceCounts" locationNameList:"item" type:"list"`
- // The price of the Reserved Instance listing.
- PriceSchedules []*PriceSchedule `locationName:"priceSchedules" locationNameList:"item" type:"list"`
- // The ID of the Reserved Instance.
- ReservedInstancesId *string `locationName:"reservedInstancesId" type:"string"`
- // The ID of the Reserved Instance listing.
- ReservedInstancesListingId *string `locationName:"reservedInstancesListingId" type:"string"`
- // The status of the Reserved Instance listing.
- Status *string `locationName:"status" type:"string" enum:"ListingStatus"`
- // The reason for the current status of the Reserved Instance listing. The response
- // can be blank.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- // Any tags assigned to the resource.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The last modified timestamp of the listing.
- UpdateDate *time.Time `locationName:"updateDate" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s ReservedInstancesListing) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstancesListing) GoString() string {
- return s.String()
- }
- // Describes a Reserved Instance modification.
- type ReservedInstancesModification struct {
- _ struct{} `type:"structure"`
- // A unique, case-sensitive key supplied by the client to ensure that the request
- // is idempotent. For more information, see Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `locationName:"clientToken" type:"string"`
- // The time when the modification request was created.
- CreateDate *time.Time `locationName:"createDate" type:"timestamp" timestampFormat:"iso8601"`
- // The time for the modification to become effective.
- EffectiveDate *time.Time `locationName:"effectiveDate" type:"timestamp" timestampFormat:"iso8601"`
- // Contains target configurations along with their corresponding new Reserved
- // Instance IDs.
- ModificationResults []*ReservedInstancesModificationResult `locationName:"modificationResultSet" locationNameList:"item" type:"list"`
- // The IDs of one or more Reserved Instances.
- ReservedInstancesIds []*ReservedInstancesId `locationName:"reservedInstancesSet" locationNameList:"item" type:"list"`
- // A unique ID for the Reserved Instance modification.
- ReservedInstancesModificationId *string `locationName:"reservedInstancesModificationId" type:"string"`
- // The status of the Reserved Instances modification request.
- Status *string `locationName:"status" type:"string"`
- // The reason for the status.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- // The time when the modification request was last updated.
- UpdateDate *time.Time `locationName:"updateDate" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s ReservedInstancesModification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstancesModification) GoString() string {
- return s.String()
- }
- // Describes the modification request/s.
- type ReservedInstancesModificationResult struct {
- _ struct{} `type:"structure"`
- // The ID for the Reserved Instances that were created as part of the modification
- // request. This field is only available when the modification is fulfilled.
- ReservedInstancesId *string `locationName:"reservedInstancesId" type:"string"`
- // The target Reserved Instances configurations supplied as part of the modification
- // request.
- TargetConfiguration *ReservedInstancesConfiguration `locationName:"targetConfiguration" type:"structure"`
- }
- // String returns the string representation
- func (s ReservedInstancesModificationResult) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstancesModificationResult) GoString() string {
- return s.String()
- }
- // Describes a Reserved Instance offering.
- type ReservedInstancesOffering struct {
- _ struct{} `type:"structure"`
- // The Availability Zone in which the Reserved Instance can be used.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The currency of the Reserved Instance offering you are purchasing. It's specified
- // using ISO 4217 standard currency codes. At this time, the only supported
- // currency is USD.
- CurrencyCode *string `locationName:"currencyCode" type:"string" enum:"CurrencyCodeValues"`
- // The duration of the Reserved Instance, in seconds.
- Duration *int64 `locationName:"duration" type:"long"`
- // The purchase price of the Reserved Instance.
- FixedPrice *float64 `locationName:"fixedPrice" type:"float"`
- // The tenancy of the instance.
- InstanceTenancy *string `locationName:"instanceTenancy" type:"string" enum:"Tenancy"`
- // The instance type on which the Reserved Instance can be used.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // Indicates whether the offering is available through the Reserved Instance
- // Marketplace (resale) or AWS. If it's a Reserved Instance Marketplace offering,
- // this is true.
- Marketplace *bool `locationName:"marketplace" type:"boolean"`
- // The Reserved Instance offering type.
- OfferingType *string `locationName:"offeringType" type:"string" enum:"OfferingTypeValues"`
- // The pricing details of the Reserved Instance offering.
- PricingDetails []*PricingDetail `locationName:"pricingDetailsSet" locationNameList:"item" type:"list"`
- // The Reserved Instance product platform description.
- ProductDescription *string `locationName:"productDescription" type:"string" enum:"RIProductDescription"`
- // The recurring charge tag assigned to the resource.
- RecurringCharges []*RecurringCharge `locationName:"recurringCharges" locationNameList:"item" type:"list"`
- // The ID of the Reserved Instance offering.
- ReservedInstancesOfferingId *string `locationName:"reservedInstancesOfferingId" type:"string"`
- // The usage price of the Reserved Instance, per hour.
- UsagePrice *float64 `locationName:"usagePrice" type:"float"`
- }
- // String returns the string representation
- func (s ReservedInstancesOffering) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ReservedInstancesOffering) GoString() string {
- return s.String()
- }
- // Contains the parameters for ResetImageAttribute.
- type ResetImageAttributeInput struct {
- _ struct{} `type:"structure"`
- // The attribute to reset (currently you can only reset the launch permission
- // attribute).
- Attribute *string `type:"string" required:"true" enum:"ResetImageAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the AMI.
- ImageId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ResetImageAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetImageAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ResetImageAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ResetImageAttributeInput"}
- if s.Attribute == nil {
- invalidParams.Add(request.NewErrParamRequired("Attribute"))
- }
- if s.ImageId == nil {
- invalidParams.Add(request.NewErrParamRequired("ImageId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ResetImageAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ResetImageAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetImageAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ResetInstanceAttribute.
- type ResetInstanceAttributeInput struct {
- _ struct{} `type:"structure"`
- // The attribute to reset.
- //
- // You can only reset the following attributes: kernel | ramdisk | sourceDestCheck.
- // To change an instance attribute, use ModifyInstanceAttribute.
- Attribute *string `locationName:"attribute" type:"string" required:"true" enum:"InstanceAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ResetInstanceAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetInstanceAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ResetInstanceAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ResetInstanceAttributeInput"}
- if s.Attribute == nil {
- invalidParams.Add(request.NewErrParamRequired("Attribute"))
- }
- if s.InstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ResetInstanceAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ResetInstanceAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetInstanceAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ResetNetworkInterfaceAttribute.
- type ResetNetworkInterfaceAttributeInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string" required:"true"`
- // The source/destination checking attribute. Resets the value to true.
- SourceDestCheck *string `locationName:"sourceDestCheck" type:"string"`
- }
- // String returns the string representation
- func (s ResetNetworkInterfaceAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetNetworkInterfaceAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ResetNetworkInterfaceAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ResetNetworkInterfaceAttributeInput"}
- if s.NetworkInterfaceId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkInterfaceId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ResetNetworkInterfaceAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ResetNetworkInterfaceAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetNetworkInterfaceAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for ResetSnapshotAttribute.
- type ResetSnapshotAttributeInput struct {
- _ struct{} `type:"structure"`
- // The attribute to reset. Currently, only the attribute for permission to create
- // volumes can be reset.
- Attribute *string `type:"string" required:"true" enum:"SnapshotAttributeName"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The ID of the snapshot.
- SnapshotId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s ResetSnapshotAttributeInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetSnapshotAttributeInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ResetSnapshotAttributeInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ResetSnapshotAttributeInput"}
- if s.Attribute == nil {
- invalidParams.Add(request.NewErrParamRequired("Attribute"))
- }
- if s.SnapshotId == nil {
- invalidParams.Add(request.NewErrParamRequired("SnapshotId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type ResetSnapshotAttributeOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s ResetSnapshotAttributeOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ResetSnapshotAttributeOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for RestoreAddressToClassic.
- type RestoreAddressToClassicInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The Elastic IP address.
- PublicIp *string `locationName:"publicIp" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s RestoreAddressToClassicInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RestoreAddressToClassicInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RestoreAddressToClassicInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RestoreAddressToClassicInput"}
- if s.PublicIp == nil {
- invalidParams.Add(request.NewErrParamRequired("PublicIp"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of RestoreAddressToClassic.
- type RestoreAddressToClassicOutput struct {
- _ struct{} `type:"structure"`
- // The Elastic IP address.
- PublicIp *string `locationName:"publicIp" type:"string"`
- // The move status for the IP address.
- Status *string `locationName:"status" type:"string" enum:"Status"`
- }
- // String returns the string representation
- func (s RestoreAddressToClassicOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RestoreAddressToClassicOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for RevokeSecurityGroupEgress.
- type RevokeSecurityGroupEgressInput struct {
- _ struct{} `type:"structure"`
- // The CIDR IP address range. We recommend that you specify the CIDR range in
- // a set of IP permissions instead.
- CidrIp *string `locationName:"cidrIp" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The start of port range for the TCP and UDP protocols, or an ICMP type number.
- // We recommend that you specify the port range in a set of IP permissions instead.
- FromPort *int64 `locationName:"fromPort" type:"integer"`
- // The ID of the security group.
- GroupId *string `locationName:"groupId" type:"string" required:"true"`
- // A set of IP permissions. You can't specify a destination security group and
- // a CIDR IP address range.
- IpPermissions []*IpPermission `locationName:"ipPermissions" locationNameList:"item" type:"list"`
- // The IP protocol name or number. We recommend that you specify the protocol
- // in a set of IP permissions instead.
- IpProtocol *string `locationName:"ipProtocol" type:"string"`
- // The name of a destination security group. To revoke outbound access to a
- // destination security group, we recommend that you use a set of IP permissions
- // instead.
- SourceSecurityGroupName *string `locationName:"sourceSecurityGroupName" type:"string"`
- // The AWS account number for a destination security group. To revoke outbound
- // access to a destination security group, we recommend that you use a set of
- // IP permissions instead.
- SourceSecurityGroupOwnerId *string `locationName:"sourceSecurityGroupOwnerId" type:"string"`
- // The end of port range for the TCP and UDP protocols, or an ICMP type number.
- // We recommend that you specify the port range in a set of IP permissions instead.
- ToPort *int64 `locationName:"toPort" type:"integer"`
- }
- // String returns the string representation
- func (s RevokeSecurityGroupEgressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RevokeSecurityGroupEgressInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RevokeSecurityGroupEgressInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RevokeSecurityGroupEgressInput"}
- if s.GroupId == nil {
- invalidParams.Add(request.NewErrParamRequired("GroupId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type RevokeSecurityGroupEgressOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s RevokeSecurityGroupEgressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RevokeSecurityGroupEgressOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for RevokeSecurityGroupIngress.
- type RevokeSecurityGroupIngressInput struct {
- _ struct{} `type:"structure"`
- // The CIDR IP address range. You can't specify this parameter when specifying
- // a source security group.
- CidrIp *string `type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // The start of port range for the TCP and UDP protocols, or an ICMP type number.
- // For the ICMP type number, use -1 to specify all ICMP types.
- FromPort *int64 `type:"integer"`
- // The ID of the security group. Required for a security group in a nondefault
- // VPC.
- GroupId *string `type:"string"`
- // [EC2-Classic, default VPC] The name of the security group.
- GroupName *string `type:"string"`
- // A set of IP permissions. You can't specify a source security group and a
- // CIDR IP address range.
- IpPermissions []*IpPermission `locationNameList:"item" type:"list"`
- // The IP protocol name (tcp, udp, icmp) or number (see Protocol Numbers (http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xhtml)).
- // Use -1 to specify all.
- IpProtocol *string `type:"string"`
- // [EC2-Classic, default VPC] The name of the source security group. You can't
- // specify this parameter in combination with the following parameters: the
- // CIDR IP address range, the start of the port range, the IP protocol, and
- // the end of the port range. For EC2-VPC, the source security group must be
- // in the same VPC. To revoke a specific rule for an IP protocol and port range,
- // use a set of IP permissions instead.
- SourceSecurityGroupName *string `type:"string"`
- // [EC2-Classic] The AWS account ID of the source security group, if the source
- // security group is in a different account. You can't specify this parameter
- // in combination with the following parameters: the CIDR IP address range,
- // the IP protocol, the start of the port range, and the end of the port range.
- // To revoke a specific rule for an IP protocol and port range, use a set of
- // IP permissions instead.
- SourceSecurityGroupOwnerId *string `type:"string"`
- // The end of port range for the TCP and UDP protocols, or an ICMP code number.
- // For the ICMP code number, use -1 to specify all ICMP codes for the ICMP type.
- ToPort *int64 `type:"integer"`
- }
- // String returns the string representation
- func (s RevokeSecurityGroupIngressInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RevokeSecurityGroupIngressInput) GoString() string {
- return s.String()
- }
- type RevokeSecurityGroupIngressOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s RevokeSecurityGroupIngressOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RevokeSecurityGroupIngressOutput) GoString() string {
- return s.String()
- }
- // Describes a route in a route table.
- type Route struct {
- _ struct{} `type:"structure"`
- // The CIDR block used for the destination match.
- DestinationCidrBlock *string `locationName:"destinationCidrBlock" type:"string"`
- // The prefix of the AWS service.
- DestinationPrefixListId *string `locationName:"destinationPrefixListId" type:"string"`
- // The ID of a gateway attached to your VPC.
- GatewayId *string `locationName:"gatewayId" type:"string"`
- // The ID of a NAT instance in your VPC.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The AWS account ID of the owner of the instance.
- InstanceOwnerId *string `locationName:"instanceOwnerId" type:"string"`
- // The ID of a NAT gateway.
- NatGatewayId *string `locationName:"natGatewayId" type:"string"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string"`
- // Describes how the route was created.
- //
- // CreateRouteTable - The route was automatically created when the route
- // table was created.
- //
- // CreateRoute - The route was manually added to the route table.
- //
- // EnableVgwRoutePropagation - The route was propagated by route propagation.
- Origin *string `locationName:"origin" type:"string" enum:"RouteOrigin"`
- // The state of the route. The blackhole state indicates that the route's target
- // isn't available (for example, the specified gateway isn't attached to the
- // VPC, or the specified NAT instance has been terminated).
- State *string `locationName:"state" type:"string" enum:"RouteState"`
- // The ID of the VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string"`
- }
- // String returns the string representation
- func (s Route) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Route) GoString() string {
- return s.String()
- }
- // Describes a route table.
- type RouteTable struct {
- _ struct{} `type:"structure"`
- // The associations between the route table and one or more subnets.
- Associations []*RouteTableAssociation `locationName:"associationSet" locationNameList:"item" type:"list"`
- // Any virtual private gateway (VGW) propagating routes.
- PropagatingVgws []*PropagatingVgw `locationName:"propagatingVgwSet" locationNameList:"item" type:"list"`
- // The ID of the route table.
- RouteTableId *string `locationName:"routeTableId" type:"string"`
- // The routes in the route table.
- Routes []*Route `locationName:"routeSet" locationNameList:"item" type:"list"`
- // Any tags assigned to the route table.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s RouteTable) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RouteTable) GoString() string {
- return s.String()
- }
- // Describes an association between a route table and a subnet.
- type RouteTableAssociation struct {
- _ struct{} `type:"structure"`
- // Indicates whether this is the main route table.
- Main *bool `locationName:"main" type:"boolean"`
- // The ID of the association between a route table and a subnet.
- RouteTableAssociationId *string `locationName:"routeTableAssociationId" type:"string"`
- // The ID of the route table.
- RouteTableId *string `locationName:"routeTableId" type:"string"`
- // The ID of the subnet. A subnet ID is not returned for an implicit association.
- SubnetId *string `locationName:"subnetId" type:"string"`
- }
- // String returns the string representation
- func (s RouteTableAssociation) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RouteTableAssociation) GoString() string {
- return s.String()
- }
- // Contains the parameters for RunInstances.
- type RunInstancesInput struct {
- _ struct{} `type:"structure"`
- // Reserved.
- AdditionalInfo *string `locationName:"additionalInfo" type:"string"`
- // The block device mapping.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"BlockDeviceMapping" locationNameList:"BlockDeviceMapping" type:"list"`
- // Unique, case-sensitive identifier you provide to ensure the idempotency of
- // the request. For more information, see Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- //
- // Constraints: Maximum 64 ASCII characters
- ClientToken *string `locationName:"clientToken" type:"string"`
- // If you set this parameter to true, you can't terminate the instance using
- // the Amazon EC2 console, CLI, or API; otherwise, you can. If you set this
- // parameter to true and then later want to be able to terminate the instance,
- // you must first change the value of the disableApiTermination attribute to
- // false using ModifyInstanceAttribute. Alternatively, if you set InstanceInitiatedShutdownBehavior
- // to terminate, you can terminate the instance by running the shutdown command
- // from the instance.
- //
- // Default: false
- DisableApiTermination *bool `locationName:"disableApiTermination" type:"boolean"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Indicates whether the instance is optimized for EBS I/O. This optimization
- // provides dedicated throughput to Amazon EBS and an optimized configuration
- // stack to provide optimal EBS I/O performance. This optimization isn't available
- // with all instance types. Additional usage charges apply when using an EBS-optimized
- // instance.
- //
- // Default: false
- EbsOptimized *bool `locationName:"ebsOptimized" type:"boolean"`
- // The IAM instance profile.
- IamInstanceProfile *IamInstanceProfileSpecification `locationName:"iamInstanceProfile" type:"structure"`
- // The ID of the AMI, which you can get by calling DescribeImages.
- ImageId *string `type:"string" required:"true"`
- // Indicates whether an instance stops or terminates when you initiate shutdown
- // from the instance (using the operating system command for system shutdown).
- //
- // Default: stop
- InstanceInitiatedShutdownBehavior *string `locationName:"instanceInitiatedShutdownBehavior" type:"string" enum:"ShutdownBehavior"`
- // The instance type. For more information, see Instance Types (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instance-types.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Default: m1.small
- InstanceType *string `type:"string" enum:"InstanceType"`
- // The ID of the kernel.
- //
- // We recommend that you use PV-GRUB instead of kernels and RAM disks. For
- // more information, see PV-GRUB (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UserProvidedkernels.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- KernelId *string `type:"string"`
- // The name of the key pair. You can create a key pair using CreateKeyPair or
- // ImportKeyPair.
- //
- // If you do not specify a key pair, you can't connect to the instance unless
- // you choose an AMI that is configured to allow users another way to log in.
- KeyName *string `type:"string"`
- // The maximum number of instances to launch. If you specify more instances
- // than Amazon EC2 can launch in the target Availability Zone, Amazon EC2 launches
- // the largest possible number of instances above MinCount.
- //
- // Constraints: Between 1 and the maximum number you're allowed for the specified
- // instance type. For more information about the default limits, and how to
- // request an increase, see How many instances can I run in Amazon EC2 (http://aws.amazon.com/ec2/faqs/#How_many_instances_can_I_run_in_Amazon_EC2)
- // in the Amazon EC2 FAQ.
- MaxCount *int64 `type:"integer" required:"true"`
- // The minimum number of instances to launch. If you specify a minimum that
- // is more instances than Amazon EC2 can launch in the target Availability Zone,
- // Amazon EC2 launches no instances.
- //
- // Constraints: Between 1 and the maximum number you're allowed for the specified
- // instance type. For more information about the default limits, and how to
- // request an increase, see How many instances can I run in Amazon EC2 (http://aws.amazon.com/ec2/faqs/#How_many_instances_can_I_run_in_Amazon_EC2)
- // in the Amazon EC2 General FAQ.
- MinCount *int64 `type:"integer" required:"true"`
- // The monitoring for the instance.
- Monitoring *RunInstancesMonitoringEnabled `type:"structure"`
- // One or more network interfaces.
- NetworkInterfaces []*InstanceNetworkInterfaceSpecification `locationName:"networkInterface" locationNameList:"item" type:"list"`
- // The placement for the instance.
- Placement *Placement `type:"structure"`
- // [EC2-VPC] The primary IP address. You must specify a value from the IP address
- // range of the subnet.
- //
- // Only one private IP address can be designated as primary. Therefore, you
- // can't specify this parameter if PrivateIpAddresses.n.Primary is set to true
- // and PrivateIpAddresses.n.PrivateIpAddress is set to an IP address.
- //
- // Default: We select an IP address from the IP address range of the subnet.
- PrivateIpAddress *string `locationName:"privateIpAddress" type:"string"`
- // The ID of the RAM disk.
- //
- // We recommend that you use PV-GRUB instead of kernels and RAM disks. For
- // more information, see PV-GRUB (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UserProvidedkernels.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- RamdiskId *string `type:"string"`
- // One or more security group IDs. You can create a security group using CreateSecurityGroup.
- //
- // Default: Amazon EC2 uses the default security group.
- SecurityGroupIds []*string `locationName:"SecurityGroupId" locationNameList:"SecurityGroupId" type:"list"`
- // [EC2-Classic, default VPC] One or more security group names. For a nondefault
- // VPC, you must use security group IDs instead.
- //
- // Default: Amazon EC2 uses the default security group.
- SecurityGroups []*string `locationName:"SecurityGroup" locationNameList:"SecurityGroup" type:"list"`
- // [EC2-VPC] The ID of the subnet to launch the instance into.
- SubnetId *string `type:"string"`
- // The user data to make available to the instance. For more information, see
- // Running Commands on Your Linux Instance at Launch (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/user-data.html)
- // (Linux) and Adding User Data (http://docs.aws.amazon.com/AWSEC2/latest/WindowsGuide/ec2-instance-metadata.html#instancedata-add-user-data)
- // (Windows). If you are using an AWS SDK or command line tool, Base64-encoding
- // is performed for you, and you can load the text from a file. Otherwise, you
- // must provide Base64-encoded text.
- UserData *string `type:"string"`
- }
- // String returns the string representation
- func (s RunInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RunInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RunInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RunInstancesInput"}
- if s.ImageId == nil {
- invalidParams.Add(request.NewErrParamRequired("ImageId"))
- }
- if s.MaxCount == nil {
- invalidParams.Add(request.NewErrParamRequired("MaxCount"))
- }
- if s.MinCount == nil {
- invalidParams.Add(request.NewErrParamRequired("MinCount"))
- }
- if s.Monitoring != nil {
- if err := s.Monitoring.Validate(); err != nil {
- invalidParams.AddNested("Monitoring", err.(request.ErrInvalidParams))
- }
- }
- if s.NetworkInterfaces != nil {
- for i, v := range s.NetworkInterfaces {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "NetworkInterfaces", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes the monitoring for the instance.
- type RunInstancesMonitoringEnabled struct {
- _ struct{} `type:"structure"`
- // Indicates whether monitoring is enabled for the instance.
- Enabled *bool `locationName:"enabled" type:"boolean" required:"true"`
- }
- // String returns the string representation
- func (s RunInstancesMonitoringEnabled) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RunInstancesMonitoringEnabled) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RunInstancesMonitoringEnabled) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RunInstancesMonitoringEnabled"}
- if s.Enabled == nil {
- invalidParams.Add(request.NewErrParamRequired("Enabled"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the parameters for RunScheduledInstances.
- type RunScheduledInstancesInput struct {
- _ struct{} `type:"structure"`
- // Unique, case-sensitive identifier that ensures the idempotency of the request.
- // For more information, see Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `type:"string" idempotencyToken:"true"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `type:"boolean"`
- // The number of instances.
- //
- // Default: 1
- InstanceCount *int64 `type:"integer"`
- // The launch specification.
- LaunchSpecification *ScheduledInstancesLaunchSpecification `type:"structure" required:"true"`
- // The Scheduled Instance ID.
- ScheduledInstanceId *string `type:"string" required:"true"`
- }
- // String returns the string representation
- func (s RunScheduledInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RunScheduledInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RunScheduledInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RunScheduledInstancesInput"}
- if s.LaunchSpecification == nil {
- invalidParams.Add(request.NewErrParamRequired("LaunchSpecification"))
- }
- if s.ScheduledInstanceId == nil {
- invalidParams.Add(request.NewErrParamRequired("ScheduledInstanceId"))
- }
- if s.LaunchSpecification != nil {
- if err := s.LaunchSpecification.Validate(); err != nil {
- invalidParams.AddNested("LaunchSpecification", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of RunScheduledInstances.
- type RunScheduledInstancesOutput struct {
- _ struct{} `type:"structure"`
- // The IDs of the newly launched instances.
- InstanceIdSet []*string `locationName:"instanceIdSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s RunScheduledInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s RunScheduledInstancesOutput) GoString() string {
- return s.String()
- }
- // Describes the storage parameters for S3 and S3 buckets for an instance store-backed
- // AMI.
- type S3Storage struct {
- _ struct{} `type:"structure"`
- // The access key ID of the owner of the bucket. Before you specify a value
- // for your access key ID, review and follow the guidance in Best Practices
- // for Managing AWS Access Keys (http://docs.aws.amazon.com/general/latest/gr/aws-access-keys-best-practices.html).
- AWSAccessKeyId *string `type:"string"`
- // The bucket in which to store the AMI. You can specify a bucket that you already
- // own or a new bucket that Amazon EC2 creates on your behalf. If you specify
- // a bucket that belongs to someone else, Amazon EC2 returns an error.
- Bucket *string `locationName:"bucket" type:"string"`
- // The beginning of the file name of the AMI.
- Prefix *string `locationName:"prefix" type:"string"`
- // An Amazon S3 upload policy that gives Amazon EC2 permission to upload items
- // into Amazon S3 on your behalf.
- //
- // UploadPolicy is automatically base64 encoded/decoded by the SDK.
- UploadPolicy []byte `locationName:"uploadPolicy" type:"blob"`
- // The signature of the JSON document.
- UploadPolicySignature *string `locationName:"uploadPolicySignature" type:"string"`
- }
- // String returns the string representation
- func (s S3Storage) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s S3Storage) GoString() string {
- return s.String()
- }
- // Describes a Scheduled Instance.
- type ScheduledInstance struct {
- _ struct{} `type:"structure"`
- // The Availability Zone.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The date when the Scheduled Instance was purchased.
- CreateDate *time.Time `locationName:"createDate" type:"timestamp" timestampFormat:"iso8601"`
- // The hourly price for a single instance.
- HourlyPrice *string `locationName:"hourlyPrice" type:"string"`
- // The number of instances.
- InstanceCount *int64 `locationName:"instanceCount" type:"integer"`
- // The instance type.
- InstanceType *string `locationName:"instanceType" type:"string"`
- // The network platform (EC2-Classic or EC2-VPC).
- NetworkPlatform *string `locationName:"networkPlatform" type:"string"`
- // The time for the next schedule to start.
- NextSlotStartTime *time.Time `locationName:"nextSlotStartTime" type:"timestamp" timestampFormat:"iso8601"`
- // The platform (Linux/UNIX or Windows).
- Platform *string `locationName:"platform" type:"string"`
- // The time that the previous schedule ended or will end.
- PreviousSlotEndTime *time.Time `locationName:"previousSlotEndTime" type:"timestamp" timestampFormat:"iso8601"`
- // The schedule recurrence.
- Recurrence *ScheduledInstanceRecurrence `locationName:"recurrence" type:"structure"`
- // The Scheduled Instance ID.
- ScheduledInstanceId *string `locationName:"scheduledInstanceId" type:"string"`
- // The number of hours in the schedule.
- SlotDurationInHours *int64 `locationName:"slotDurationInHours" type:"integer"`
- // The end date for the Scheduled Instance.
- TermEndDate *time.Time `locationName:"termEndDate" type:"timestamp" timestampFormat:"iso8601"`
- // The start date for the Scheduled Instance.
- TermStartDate *time.Time `locationName:"termStartDate" type:"timestamp" timestampFormat:"iso8601"`
- // The total number of hours for a single instance for the entire term.
- TotalScheduledInstanceHours *int64 `locationName:"totalScheduledInstanceHours" type:"integer"`
- }
- // String returns the string representation
- func (s ScheduledInstance) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstance) GoString() string {
- return s.String()
- }
- // Describes a schedule that is available for your Scheduled Instances.
- type ScheduledInstanceAvailability struct {
- _ struct{} `type:"structure"`
- // The Availability Zone.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The number of available instances.
- AvailableInstanceCount *int64 `locationName:"availableInstanceCount" type:"integer"`
- // The time period for the first schedule to start.
- FirstSlotStartTime *time.Time `locationName:"firstSlotStartTime" type:"timestamp" timestampFormat:"iso8601"`
- // The hourly price for a single instance.
- HourlyPrice *string `locationName:"hourlyPrice" type:"string"`
- // The instance type. You can specify one of the C3, C4, M4, or R3 instance
- // types.
- InstanceType *string `locationName:"instanceType" type:"string"`
- // The maximum term. The only possible value is 365 days.
- MaxTermDurationInDays *int64 `locationName:"maxTermDurationInDays" type:"integer"`
- // The minimum term. The only possible value is 365 days.
- MinTermDurationInDays *int64 `locationName:"minTermDurationInDays" type:"integer"`
- // The network platform (EC2-Classic or EC2-VPC).
- NetworkPlatform *string `locationName:"networkPlatform" type:"string"`
- // The platform (Linux/UNIX or Windows).
- Platform *string `locationName:"platform" type:"string"`
- // The purchase token. This token expires in two hours.
- PurchaseToken *string `locationName:"purchaseToken" type:"string"`
- // The schedule recurrence.
- Recurrence *ScheduledInstanceRecurrence `locationName:"recurrence" type:"structure"`
- // The number of hours in the schedule.
- SlotDurationInHours *int64 `locationName:"slotDurationInHours" type:"integer"`
- // The total number of hours for a single instance for the entire term.
- TotalScheduledInstanceHours *int64 `locationName:"totalScheduledInstanceHours" type:"integer"`
- }
- // String returns the string representation
- func (s ScheduledInstanceAvailability) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstanceAvailability) GoString() string {
- return s.String()
- }
- // Describes the recurring schedule for a Scheduled Instance.
- type ScheduledInstanceRecurrence struct {
- _ struct{} `type:"structure"`
- // The frequency (Daily, Weekly, or Monthly).
- Frequency *string `locationName:"frequency" type:"string"`
- // The interval quantity. The interval unit depends on the value of frequency.
- // For example, every 2 weeks or every 2 months.
- Interval *int64 `locationName:"interval" type:"integer"`
- // The days. For a monthly schedule, this is one or more days of the month (1-31).
- // For a weekly schedule, this is one or more days of the week (1-7, where 1
- // is Sunday).
- OccurrenceDaySet []*int64 `locationName:"occurrenceDaySet" locationNameList:"item" type:"list"`
- // Indicates whether the occurrence is relative to the end of the specified
- // week or month.
- OccurrenceRelativeToEnd *bool `locationName:"occurrenceRelativeToEnd" type:"boolean"`
- // The unit for occurrenceDaySet (DayOfWeek or DayOfMonth).
- OccurrenceUnit *string `locationName:"occurrenceUnit" type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstanceRecurrence) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstanceRecurrence) GoString() string {
- return s.String()
- }
- // Describes the recurring schedule for a Scheduled Instance.
- type ScheduledInstanceRecurrenceRequest struct {
- _ struct{} `type:"structure"`
- // The frequency (Daily, Weekly, or Monthly).
- Frequency *string `type:"string"`
- // The interval quantity. The interval unit depends on the value of Frequency.
- // For example, every 2 weeks or every 2 months.
- Interval *int64 `type:"integer"`
- // The days. For a monthly schedule, this is one or more days of the month (1-31).
- // For a weekly schedule, this is one or more days of the week (1-7, where 1
- // is Sunday). You can't specify this value with a daily schedule. If the occurrence
- // is relative to the end of the month, you can specify only a single day.
- OccurrenceDays []*int64 `locationName:"OccurrenceDay" locationNameList:"OccurenceDay" type:"list"`
- // Indicates whether the occurrence is relative to the end of the specified
- // week or month. You can't specify this value with a daily schedule.
- OccurrenceRelativeToEnd *bool `type:"boolean"`
- // The unit for OccurrenceDays (DayOfWeek or DayOfMonth). This value is required
- // for a monthly schedule. You can't specify DayOfWeek with a weekly schedule.
- // You can't specify this value with a daily schedule.
- OccurrenceUnit *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstanceRecurrenceRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstanceRecurrenceRequest) GoString() string {
- return s.String()
- }
- // Describes a block device mapping for a Scheduled Instance.
- type ScheduledInstancesBlockDeviceMapping struct {
- _ struct{} `type:"structure"`
- // The device name exposed to the instance (for example, /dev/sdh or xvdh).
- DeviceName *string `type:"string"`
- // Parameters used to set up EBS volumes automatically when the instance is
- // launched.
- Ebs *ScheduledInstancesEbs `type:"structure"`
- // Suppresses the specified device included in the block device mapping of the
- // AMI.
- NoDevice *string `type:"string"`
- // The virtual device name (ephemeralN). Instance store volumes are numbered
- // starting from 0. An instance type with two available instance store volumes
- // can specify mappings for ephemeral0 and ephemeral1.The number of available
- // instance store volumes depends on the instance type. After you connect to
- // the instance, you must mount the volume.
- //
- // Constraints: For M3 instances, you must specify instance store volumes in
- // the block device mapping for the instance. When you launch an M3 instance,
- // we ignore any instance store volumes specified in the block device mapping
- // for the AMI.
- VirtualName *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstancesBlockDeviceMapping) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesBlockDeviceMapping) GoString() string {
- return s.String()
- }
- // Describes an EBS volume for a Scheduled Instance.
- type ScheduledInstancesEbs struct {
- _ struct{} `type:"structure"`
- // Indicates whether the volume is deleted on instance termination.
- DeleteOnTermination *bool `type:"boolean"`
- // Indicates whether the volume is encrypted. You can attached encrypted volumes
- // only to instances that support them.
- Encrypted *bool `type:"boolean"`
- // The number of I/O operations per second (IOPS) that the volume supports.
- // For io1 volumes, this represents the number of IOPS that are provisioned
- // for the volume. For gp2 volumes, this represents the baseline performance
- // of the volume and the rate at which the volume accumulates I/O credits for
- // bursting. For more information about gp2 baseline performance, I/O credits,
- // and bursting, see Amazon EBS Volume Types (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSVolumeTypes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Constraint: Range is 100-20000 IOPS for io1 volumes and 100-10000 IOPS for
- // gp2 volumes.
- //
- // Condition: This parameter is required for requests to create io1volumes;
- // it is not used in requests to create gp2, st1, sc1, or standard volumes.
- Iops *int64 `type:"integer"`
- // The ID of the snapshot.
- SnapshotId *string `type:"string"`
- // The size of the volume, in GiB.
- //
- // Default: If you're creating the volume from a snapshot and don't specify
- // a volume size, the default is the snapshot size.
- VolumeSize *int64 `type:"integer"`
- // The volume type. gp2 for General Purpose SSD, io1 for Provisioned IOPS SSD,
- // Throughput Optimized HDD for st1, Cold HDD for sc1, or standard for Magnetic.
- //
- // Default: standard
- VolumeType *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstancesEbs) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesEbs) GoString() string {
- return s.String()
- }
- // Describes an IAM instance profile for a Scheduled Instance.
- type ScheduledInstancesIamInstanceProfile struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN).
- Arn *string `type:"string"`
- // The name.
- Name *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstancesIamInstanceProfile) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesIamInstanceProfile) GoString() string {
- return s.String()
- }
- // Describes the launch specification for a Scheduled Instance.
- //
- // If you are launching the Scheduled Instance in EC2-VPC, you must specify
- // the ID of the subnet. You can specify the subnet using either SubnetId or
- // NetworkInterface.
- type ScheduledInstancesLaunchSpecification struct {
- _ struct{} `type:"structure"`
- // One or more block device mapping entries.
- BlockDeviceMappings []*ScheduledInstancesBlockDeviceMapping `locationName:"BlockDeviceMapping" locationNameList:"BlockDeviceMapping" type:"list"`
- // Indicates whether the instances are optimized for EBS I/O. This optimization
- // provides dedicated throughput to Amazon EBS and an optimized configuration
- // stack to provide optimal EBS I/O performance. This optimization isn't available
- // with all instance types. Additional usage charges apply when using an EBS-optimized
- // instance.
- //
- // Default: false
- EbsOptimized *bool `type:"boolean"`
- // The IAM instance profile.
- IamInstanceProfile *ScheduledInstancesIamInstanceProfile `type:"structure"`
- // The ID of the Amazon Machine Image (AMI).
- ImageId *string `type:"string" required:"true"`
- // The instance type.
- InstanceType *string `type:"string"`
- // The ID of the kernel.
- KernelId *string `type:"string"`
- // The name of the key pair.
- KeyName *string `type:"string"`
- // Enable or disable monitoring for the instances.
- Monitoring *ScheduledInstancesMonitoring `type:"structure"`
- // One or more network interfaces.
- NetworkInterfaces []*ScheduledInstancesNetworkInterface `locationName:"NetworkInterface" locationNameList:"NetworkInterface" type:"list"`
- // The placement information.
- Placement *ScheduledInstancesPlacement `type:"structure"`
- // The ID of the RAM disk.
- RamdiskId *string `type:"string"`
- // The IDs of one or more security groups.
- SecurityGroupIds []*string `locationName:"SecurityGroupId" locationNameList:"SecurityGroupId" type:"list"`
- // The ID of the subnet in which to launch the instances.
- SubnetId *string `type:"string"`
- // The base64-encoded MIME user data.
- UserData *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstancesLaunchSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesLaunchSpecification) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ScheduledInstancesLaunchSpecification) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ScheduledInstancesLaunchSpecification"}
- if s.ImageId == nil {
- invalidParams.Add(request.NewErrParamRequired("ImageId"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes whether monitoring is enabled for a Scheduled Instance.
- type ScheduledInstancesMonitoring struct {
- _ struct{} `type:"structure"`
- // Indicates whether monitoring is enabled.
- Enabled *bool `type:"boolean"`
- }
- // String returns the string representation
- func (s ScheduledInstancesMonitoring) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesMonitoring) GoString() string {
- return s.String()
- }
- // Describes a network interface for a Scheduled Instance.
- type ScheduledInstancesNetworkInterface struct {
- _ struct{} `type:"structure"`
- // Indicates whether to assign a public IP address to instances launched in
- // a VPC. The public IP address can only be assigned to a network interface
- // for eth0, and can only be assigned to a new network interface, not an existing
- // one. You cannot specify more than one network interface in the request. If
- // launching into a default subnet, the default value is true.
- AssociatePublicIpAddress *bool `type:"boolean"`
- // Indicates whether to delete the interface when the instance is terminated.
- DeleteOnTermination *bool `type:"boolean"`
- // The description.
- Description *string `type:"string"`
- // The index of the device for the network interface attachment.
- DeviceIndex *int64 `type:"integer"`
- // The IDs of one or more security groups.
- Groups []*string `locationName:"Group" locationNameList:"SecurityGroupId" type:"list"`
- // The ID of the network interface.
- NetworkInterfaceId *string `type:"string"`
- // The IP address of the network interface within the subnet.
- PrivateIpAddress *string `type:"string"`
- // The private IP addresses.
- PrivateIpAddressConfigs []*ScheduledInstancesPrivateIpAddressConfig `locationName:"PrivateIpAddressConfig" locationNameList:"PrivateIpAddressConfigSet" type:"list"`
- // The number of secondary private IP addresses.
- SecondaryPrivateIpAddressCount *int64 `type:"integer"`
- // The ID of the subnet.
- SubnetId *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstancesNetworkInterface) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesNetworkInterface) GoString() string {
- return s.String()
- }
- // Describes the placement for a Scheduled Instance.
- type ScheduledInstancesPlacement struct {
- _ struct{} `type:"structure"`
- // The Availability Zone.
- AvailabilityZone *string `type:"string"`
- // The name of the placement group.
- GroupName *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstancesPlacement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesPlacement) GoString() string {
- return s.String()
- }
- // Describes a private IP address for a Scheduled Instance.
- type ScheduledInstancesPrivateIpAddressConfig struct {
- _ struct{} `type:"structure"`
- // Indicates whether this is a primary IP address. Otherwise, this is a secondary
- // IP address.
- Primary *bool `type:"boolean"`
- // The IP address.
- PrivateIpAddress *string `type:"string"`
- }
- // String returns the string representation
- func (s ScheduledInstancesPrivateIpAddressConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s ScheduledInstancesPrivateIpAddressConfig) GoString() string {
- return s.String()
- }
- // Describes a security group
- type SecurityGroup struct {
- _ struct{} `type:"structure"`
- // A description of the security group.
- Description *string `locationName:"groupDescription" type:"string"`
- // The ID of the security group.
- GroupId *string `locationName:"groupId" type:"string"`
- // The name of the security group.
- GroupName *string `locationName:"groupName" type:"string"`
- // One or more inbound rules associated with the security group.
- IpPermissions []*IpPermission `locationName:"ipPermissions" locationNameList:"item" type:"list"`
- // [EC2-VPC] One or more outbound rules associated with the security group.
- IpPermissionsEgress []*IpPermission `locationName:"ipPermissionsEgress" locationNameList:"item" type:"list"`
- // The AWS account ID of the owner of the security group.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // Any tags assigned to the security group.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // [EC2-VPC] The ID of the VPC for the security group.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s SecurityGroup) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SecurityGroup) GoString() string {
- return s.String()
- }
- // Describes a VPC with a security group that references your security group.
- type SecurityGroupReference struct {
- _ struct{} `type:"structure"`
- // The ID of your security group.
- GroupId *string `locationName:"groupId" type:"string" required:"true"`
- // The ID of the VPC with the referencing security group.
- ReferencingVpcId *string `locationName:"referencingVpcId" type:"string" required:"true"`
- // The ID of the VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string"`
- }
- // String returns the string representation
- func (s SecurityGroupReference) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SecurityGroupReference) GoString() string {
- return s.String()
- }
- // Describes the time period for a Scheduled Instance to start its first schedule.
- // The time period must span less than one day.
- type SlotDateTimeRangeRequest struct {
- _ struct{} `type:"structure"`
- // The earliest date and time, in UTC, for the Scheduled Instance to start.
- EarliestTime *time.Time `type:"timestamp" timestampFormat:"iso8601" required:"true"`
- // The latest date and time, in UTC, for the Scheduled Instance to start. This
- // value must be later than or equal to the earliest date and at most three
- // months in the future.
- LatestTime *time.Time `type:"timestamp" timestampFormat:"iso8601" required:"true"`
- }
- // String returns the string representation
- func (s SlotDateTimeRangeRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SlotDateTimeRangeRequest) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *SlotDateTimeRangeRequest) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "SlotDateTimeRangeRequest"}
- if s.EarliestTime == nil {
- invalidParams.Add(request.NewErrParamRequired("EarliestTime"))
- }
- if s.LatestTime == nil {
- invalidParams.Add(request.NewErrParamRequired("LatestTime"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes the time period for a Scheduled Instance to start its first schedule.
- type SlotStartTimeRangeRequest struct {
- _ struct{} `type:"structure"`
- // The earliest date and time, in UTC, for the Scheduled Instance to start.
- EarliestTime *time.Time `type:"timestamp" timestampFormat:"iso8601"`
- // The latest date and time, in UTC, for the Scheduled Instance to start.
- LatestTime *time.Time `type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s SlotStartTimeRangeRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SlotStartTimeRangeRequest) GoString() string {
- return s.String()
- }
- // Describes a snapshot.
- type Snapshot struct {
- _ struct{} `type:"structure"`
- // The data encryption key identifier for the snapshot. This value is a unique
- // identifier that corresponds to the data encryption key that was used to encrypt
- // the original volume or snapshot copy. Because data encryption keys are inherited
- // by volumes created from snapshots, and vice versa, if snapshots share the
- // same data encryption key identifier, then they belong to the same volume/snapshot
- // lineage. This parameter is only returned by the DescribeSnapshots API operation.
- DataEncryptionKeyId *string `locationName:"dataEncryptionKeyId" type:"string"`
- // The description for the snapshot.
- Description *string `locationName:"description" type:"string"`
- // Indicates whether the snapshot is encrypted.
- Encrypted *bool `locationName:"encrypted" type:"boolean"`
- // The full ARN of the AWS Key Management Service (AWS KMS) customer master
- // key (CMK) that was used to protect the volume encryption key for the parent
- // volume.
- KmsKeyId *string `locationName:"kmsKeyId" type:"string"`
- // The AWS account alias (for example, amazon, self) or AWS account ID that
- // owns the snapshot.
- OwnerAlias *string `locationName:"ownerAlias" type:"string"`
- // The AWS account ID of the EBS snapshot owner.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // The progress of the snapshot, as a percentage.
- Progress *string `locationName:"progress" type:"string"`
- // The ID of the snapshot. Each snapshot receives a unique identifier when it
- // is created.
- SnapshotId *string `locationName:"snapshotId" type:"string"`
- // The time stamp when the snapshot was initiated.
- StartTime *time.Time `locationName:"startTime" type:"timestamp" timestampFormat:"iso8601"`
- // The snapshot state.
- State *string `locationName:"status" type:"string" enum:"SnapshotState"`
- // Encrypted Amazon EBS snapshots are copied asynchronously. If a snapshot copy
- // operation fails (for example, if the proper AWS Key Management Service (AWS
- // KMS) permissions are not obtained) this field displays error state details
- // to help you diagnose why the error occurred. This parameter is only returned
- // by the DescribeSnapshots API operation.
- StateMessage *string `locationName:"statusMessage" type:"string"`
- // Any tags assigned to the snapshot.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the volume that was used to create the snapshot. Snapshots created
- // by the CopySnapshot action have an arbitrary volume ID that should not be
- // used for any purpose.
- VolumeId *string `locationName:"volumeId" type:"string"`
- // The size of the volume, in GiB.
- VolumeSize *int64 `locationName:"volumeSize" type:"integer"`
- }
- // String returns the string representation
- func (s Snapshot) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Snapshot) GoString() string {
- return s.String()
- }
- // Describes the snapshot created from the imported disk.
- type SnapshotDetail struct {
- _ struct{} `type:"structure"`
- // A description for the snapshot.
- Description *string `locationName:"description" type:"string"`
- // The block device mapping for the snapshot.
- DeviceName *string `locationName:"deviceName" type:"string"`
- // The size of the disk in the snapshot, in GiB.
- DiskImageSize *float64 `locationName:"diskImageSize" type:"double"`
- // The format of the disk image from which the snapshot is created.
- Format *string `locationName:"format" type:"string"`
- // The percentage of progress for the task.
- Progress *string `locationName:"progress" type:"string"`
- // The snapshot ID of the disk being imported.
- SnapshotId *string `locationName:"snapshotId" type:"string"`
- // A brief status of the snapshot creation.
- Status *string `locationName:"status" type:"string"`
- // A detailed status message for the snapshot creation.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- // The URL used to access the disk image.
- Url *string `locationName:"url" type:"string"`
- // The S3 bucket for the disk image.
- UserBucket *UserBucketDetails `locationName:"userBucket" type:"structure"`
- }
- // String returns the string representation
- func (s SnapshotDetail) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SnapshotDetail) GoString() string {
- return s.String()
- }
- // The disk container object for the import snapshot request.
- type SnapshotDiskContainer struct {
- _ struct{} `type:"structure"`
- // The description of the disk image being imported.
- Description *string `type:"string"`
- // The format of the disk image being imported.
- //
- // Valid values: RAW | VHD | VMDK | OVA
- Format *string `type:"string"`
- // The URL to the Amazon S3-based disk image being imported. It can either be
- // a https URL (https://..) or an Amazon S3 URL (s3://..).
- Url *string `type:"string"`
- // The S3 bucket for the disk image.
- UserBucket *UserBucket `type:"structure"`
- }
- // String returns the string representation
- func (s SnapshotDiskContainer) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SnapshotDiskContainer) GoString() string {
- return s.String()
- }
- // Details about the import snapshot task.
- type SnapshotTaskDetail struct {
- _ struct{} `type:"structure"`
- // The description of the snapshot.
- Description *string `locationName:"description" type:"string"`
- // The size of the disk in the snapshot, in GiB.
- DiskImageSize *float64 `locationName:"diskImageSize" type:"double"`
- // The format of the disk image from which the snapshot is created.
- Format *string `locationName:"format" type:"string"`
- // The percentage of completion for the import snapshot task.
- Progress *string `locationName:"progress" type:"string"`
- // The snapshot ID of the disk being imported.
- SnapshotId *string `locationName:"snapshotId" type:"string"`
- // A brief status for the import snapshot task.
- Status *string `locationName:"status" type:"string"`
- // A detailed status message for the import snapshot task.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- // The URL of the disk image from which the snapshot is created.
- Url *string `locationName:"url" type:"string"`
- // The S3 bucket for the disk image.
- UserBucket *UserBucketDetails `locationName:"userBucket" type:"structure"`
- }
- // String returns the string representation
- func (s SnapshotTaskDetail) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SnapshotTaskDetail) GoString() string {
- return s.String()
- }
- // Describes the data feed for a Spot instance.
- type SpotDatafeedSubscription struct {
- _ struct{} `type:"structure"`
- // The Amazon S3 bucket where the Spot instance data feed is located.
- Bucket *string `locationName:"bucket" type:"string"`
- // The fault codes for the Spot instance request, if any.
- Fault *SpotInstanceStateFault `locationName:"fault" type:"structure"`
- // The AWS account ID of the account.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // The prefix that is prepended to data feed files.
- Prefix *string `locationName:"prefix" type:"string"`
- // The state of the Spot instance data feed subscription.
- State *string `locationName:"state" type:"string" enum:"DatafeedSubscriptionState"`
- }
- // String returns the string representation
- func (s SpotDatafeedSubscription) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotDatafeedSubscription) GoString() string {
- return s.String()
- }
- // Describes the launch specification for one or more Spot instances.
- type SpotFleetLaunchSpecification struct {
- _ struct{} `type:"structure"`
- // Deprecated.
- AddressingType *string `locationName:"addressingType" type:"string"`
- // One or more block device mapping entries.
- BlockDeviceMappings []*BlockDeviceMapping `locationName:"blockDeviceMapping" locationNameList:"item" type:"list"`
- // Indicates whether the instances are optimized for EBS I/O. This optimization
- // provides dedicated throughput to Amazon EBS and an optimized configuration
- // stack to provide optimal EBS I/O performance. This optimization isn't available
- // with all instance types. Additional usage charges apply when using an EBS
- // Optimized instance.
- //
- // Default: false
- EbsOptimized *bool `locationName:"ebsOptimized" type:"boolean"`
- // The IAM instance profile.
- IamInstanceProfile *IamInstanceProfileSpecification `locationName:"iamInstanceProfile" type:"structure"`
- // The ID of the AMI.
- ImageId *string `locationName:"imageId" type:"string"`
- // The instance type.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // The ID of the kernel.
- KernelId *string `locationName:"kernelId" type:"string"`
- // The name of the key pair.
- KeyName *string `locationName:"keyName" type:"string"`
- // Enable or disable monitoring for the instances.
- Monitoring *SpotFleetMonitoring `locationName:"monitoring" type:"structure"`
- // One or more network interfaces.
- NetworkInterfaces []*InstanceNetworkInterfaceSpecification `locationName:"networkInterfaceSet" locationNameList:"item" type:"list"`
- // The placement information.
- Placement *SpotPlacement `locationName:"placement" type:"structure"`
- // The ID of the RAM disk.
- RamdiskId *string `locationName:"ramdiskId" type:"string"`
- // One or more security groups. When requesting instances in a VPC, you must
- // specify the IDs of the security groups. When requesting instances in EC2-Classic,
- // you can specify the names or the IDs of the security groups.
- SecurityGroups []*GroupIdentifier `locationName:"groupSet" locationNameList:"item" type:"list"`
- // The bid price per unit hour for the specified instance type. If this value
- // is not specified, the default is the Spot bid price specified for the fleet.
- // To determine the bid price per unit hour, divide the Spot bid price by the
- // value of WeightedCapacity.
- SpotPrice *string `locationName:"spotPrice" type:"string"`
- // The ID of the subnet in which to launch the instances. To specify multiple
- // subnets, separate them using commas; for example, "subnet-a61dafcf, subnet-65ea5f08".
- SubnetId *string `locationName:"subnetId" type:"string"`
- // The user data to make available to the instances. If you are using an AWS
- // SDK or command line tool, Base64-encoding is performed for you, and you can
- // load the text from a file. Otherwise, you must provide Base64-encoded text.
- UserData *string `locationName:"userData" type:"string"`
- // The number of units provided by the specified instance type. These are the
- // same units that you chose to set the target capacity in terms (instances
- // or a performance characteristic such as vCPUs, memory, or I/O).
- //
- // If the target capacity divided by this value is not a whole number, we round
- // the number of instances to the next whole number. If this value is not specified,
- // the default is 1.
- WeightedCapacity *float64 `locationName:"weightedCapacity" type:"double"`
- }
- // String returns the string representation
- func (s SpotFleetLaunchSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotFleetLaunchSpecification) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *SpotFleetLaunchSpecification) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "SpotFleetLaunchSpecification"}
- if s.NetworkInterfaces != nil {
- for i, v := range s.NetworkInterfaces {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "NetworkInterfaces", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes whether monitoring is enabled.
- type SpotFleetMonitoring struct {
- _ struct{} `type:"structure"`
- // Enables monitoring for the instance.
- //
- // Default: false
- Enabled *bool `locationName:"enabled" type:"boolean"`
- }
- // String returns the string representation
- func (s SpotFleetMonitoring) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotFleetMonitoring) GoString() string {
- return s.String()
- }
- // Describes a Spot fleet request.
- type SpotFleetRequestConfig struct {
- _ struct{} `type:"structure"`
- // The creation date and time of the request.
- CreateTime *time.Time `locationName:"createTime" type:"timestamp" timestampFormat:"iso8601" required:"true"`
- // Information about the configuration of the Spot fleet request.
- SpotFleetRequestConfig *SpotFleetRequestConfigData `locationName:"spotFleetRequestConfig" type:"structure" required:"true"`
- // The ID of the Spot fleet request.
- SpotFleetRequestId *string `locationName:"spotFleetRequestId" type:"string" required:"true"`
- // The state of the Spot fleet request.
- SpotFleetRequestState *string `locationName:"spotFleetRequestState" type:"string" required:"true" enum:"BatchState"`
- }
- // String returns the string representation
- func (s SpotFleetRequestConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotFleetRequestConfig) GoString() string {
- return s.String()
- }
- // Describes the configuration of a Spot fleet request.
- type SpotFleetRequestConfigData struct {
- _ struct{} `type:"structure"`
- // Indicates how to allocate the target capacity across the Spot pools specified
- // by the Spot fleet request. The default is lowestPrice.
- AllocationStrategy *string `locationName:"allocationStrategy" type:"string" enum:"AllocationStrategy"`
- // A unique, case-sensitive identifier you provide to ensure idempotency of
- // your listings. This helps avoid duplicate listings. For more information,
- // see Ensuring Idempotency (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
- ClientToken *string `locationName:"clientToken" type:"string"`
- // Indicates whether running Spot instances should be terminated if the target
- // capacity of the Spot fleet request is decreased below the current size of
- // the Spot fleet.
- ExcessCapacityTerminationPolicy *string `locationName:"excessCapacityTerminationPolicy" type:"string" enum:"ExcessCapacityTerminationPolicy"`
- // The number of units fulfilled by this request compared to the set target
- // capacity.
- FulfilledCapacity *float64 `locationName:"fulfilledCapacity" type:"double"`
- // Grants the Spot fleet permission to terminate Spot instances on your behalf
- // when you cancel its Spot fleet request using CancelSpotFleetRequests or when
- // the Spot fleet request expires, if you set terminateInstancesWithExpiration.
- IamFleetRole *string `locationName:"iamFleetRole" type:"string" required:"true"`
- // Information about the launch specifications for the Spot fleet request.
- LaunchSpecifications []*SpotFleetLaunchSpecification `locationName:"launchSpecifications" locationNameList:"item" min:"1" type:"list" required:"true"`
- // The bid price per unit hour.
- SpotPrice *string `locationName:"spotPrice" type:"string" required:"true"`
- // The number of units to request. You can choose to set the target capacity
- // in terms of instances or a performance characteristic that is important to
- // your application workload, such as vCPUs, memory, or I/O.
- TargetCapacity *int64 `locationName:"targetCapacity" type:"integer" required:"true"`
- // Indicates whether running Spot instances should be terminated when the Spot
- // fleet request expires.
- TerminateInstancesWithExpiration *bool `locationName:"terminateInstancesWithExpiration" type:"boolean"`
- // The type of request. Indicates whether the fleet will only request the target
- // capacity or also attempt to maintain it. When you request a certain target
- // capacity, the fleet will only place the required bids. It will not attempt
- // to replenish Spot instances if capacity is diminished, nor will it submit
- // bids in alternative Spot pools if capacity is not available. When you want
- // to maintain a certain target capacity, fleet will place the required bids
- // to meet this target capacity. It will also automatically replenish any interrupted
- // instances. Default: maintain.
- Type *string `locationName:"type" type:"string" enum:"FleetType"`
- // The start date and time of the request, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- // The default is to start fulfilling the request immediately.
- ValidFrom *time.Time `locationName:"validFrom" type:"timestamp" timestampFormat:"iso8601"`
- // The end date and time of the request, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- // At this point, no new Spot instance requests are placed or enabled to fulfill
- // the request.
- ValidUntil *time.Time `locationName:"validUntil" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s SpotFleetRequestConfigData) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotFleetRequestConfigData) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *SpotFleetRequestConfigData) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "SpotFleetRequestConfigData"}
- if s.IamFleetRole == nil {
- invalidParams.Add(request.NewErrParamRequired("IamFleetRole"))
- }
- if s.LaunchSpecifications == nil {
- invalidParams.Add(request.NewErrParamRequired("LaunchSpecifications"))
- }
- if s.LaunchSpecifications != nil && len(s.LaunchSpecifications) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LaunchSpecifications", 1))
- }
- if s.SpotPrice == nil {
- invalidParams.Add(request.NewErrParamRequired("SpotPrice"))
- }
- if s.TargetCapacity == nil {
- invalidParams.Add(request.NewErrParamRequired("TargetCapacity"))
- }
- if s.LaunchSpecifications != nil {
- for i, v := range s.LaunchSpecifications {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "LaunchSpecifications", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a Spot instance request.
- type SpotInstanceRequest struct {
- _ struct{} `type:"structure"`
- // If you specified a duration and your Spot instance request was fulfilled,
- // this is the fixed hourly price in effect for the Spot instance while it runs.
- ActualBlockHourlyPrice *string `locationName:"actualBlockHourlyPrice" type:"string"`
- // The Availability Zone group. If you specify the same Availability Zone group
- // for all Spot instance requests, all Spot instances are launched in the same
- // Availability Zone.
- AvailabilityZoneGroup *string `locationName:"availabilityZoneGroup" type:"string"`
- // The duration for the Spot instance, in minutes.
- BlockDurationMinutes *int64 `locationName:"blockDurationMinutes" type:"integer"`
- // The date and time when the Spot instance request was created, in UTC format
- // (for example, YYYY-MM-DDTHH:MM:SSZ).
- CreateTime *time.Time `locationName:"createTime" type:"timestamp" timestampFormat:"iso8601"`
- // The fault codes for the Spot instance request, if any.
- Fault *SpotInstanceStateFault `locationName:"fault" type:"structure"`
- // The instance ID, if an instance has been launched to fulfill the Spot instance
- // request.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The instance launch group. Launch groups are Spot instances that launch together
- // and terminate together.
- LaunchGroup *string `locationName:"launchGroup" type:"string"`
- // Additional information for launching instances.
- LaunchSpecification *LaunchSpecification `locationName:"launchSpecification" type:"structure"`
- // The Availability Zone in which the bid is launched.
- LaunchedAvailabilityZone *string `locationName:"launchedAvailabilityZone" type:"string"`
- // The product description associated with the Spot instance.
- ProductDescription *string `locationName:"productDescription" type:"string" enum:"RIProductDescription"`
- // The ID of the Spot instance request.
- SpotInstanceRequestId *string `locationName:"spotInstanceRequestId" type:"string"`
- // The maximum hourly price (bid) for the Spot instance launched to fulfill
- // the request.
- SpotPrice *string `locationName:"spotPrice" type:"string"`
- // The state of the Spot instance request. Spot bid status information can help
- // you track your Spot instance requests. For more information, see Spot Bid
- // Status (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-bid-status.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- State *string `locationName:"state" type:"string" enum:"SpotInstanceState"`
- // The status code and status message describing the Spot instance request.
- Status *SpotInstanceStatus `locationName:"status" type:"structure"`
- // Any tags assigned to the resource.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The Spot instance request type.
- Type *string `locationName:"type" type:"string" enum:"SpotInstanceType"`
- // The start date of the request, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- // The request becomes active at this date and time.
- ValidFrom *time.Time `locationName:"validFrom" type:"timestamp" timestampFormat:"iso8601"`
- // The end date of the request, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- // If this is a one-time request, it remains active until all instances launch,
- // the request is canceled, or this date is reached. If the request is persistent,
- // it remains active until it is canceled or this date is reached.
- ValidUntil *time.Time `locationName:"validUntil" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s SpotInstanceRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotInstanceRequest) GoString() string {
- return s.String()
- }
- // Describes a Spot instance state change.
- type SpotInstanceStateFault struct {
- _ struct{} `type:"structure"`
- // The reason code for the Spot instance state change.
- Code *string `locationName:"code" type:"string"`
- // The message for the Spot instance state change.
- Message *string `locationName:"message" type:"string"`
- }
- // String returns the string representation
- func (s SpotInstanceStateFault) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotInstanceStateFault) GoString() string {
- return s.String()
- }
- // Describes the status of a Spot instance request.
- type SpotInstanceStatus struct {
- _ struct{} `type:"structure"`
- // The status code. For a list of status codes, see Spot Bid Status Codes (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-bid-status.html#spot-instance-bid-status-understand)
- // in the Amazon Elastic Compute Cloud User Guide.
- Code *string `locationName:"code" type:"string"`
- // The description for the status code.
- Message *string `locationName:"message" type:"string"`
- // The date and time of the most recent status update, in UTC format (for example,
- // YYYY-MM-DDTHH:MM:SSZ).
- UpdateTime *time.Time `locationName:"updateTime" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s SpotInstanceStatus) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotInstanceStatus) GoString() string {
- return s.String()
- }
- // Describes Spot instance placement.
- type SpotPlacement struct {
- _ struct{} `type:"structure"`
- // The Availability Zone.
- //
- // [Spot fleet only] To specify multiple Availability Zones, separate them
- // using commas; for example, "us-west-2a, us-west-2b".
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The name of the placement group (for cluster instances).
- GroupName *string `locationName:"groupName" type:"string"`
- }
- // String returns the string representation
- func (s SpotPlacement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotPlacement) GoString() string {
- return s.String()
- }
- // Describes the maximum hourly price (bid) for any Spot instance launched to
- // fulfill the request.
- type SpotPrice struct {
- _ struct{} `type:"structure"`
- // The Availability Zone.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The instance type.
- InstanceType *string `locationName:"instanceType" type:"string" enum:"InstanceType"`
- // A general description of the AMI.
- ProductDescription *string `locationName:"productDescription" type:"string" enum:"RIProductDescription"`
- // The maximum price (bid) that you are willing to pay for a Spot instance.
- SpotPrice *string `locationName:"spotPrice" type:"string"`
- // The date and time the request was created, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ).
- Timestamp *time.Time `locationName:"timestamp" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s SpotPrice) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s SpotPrice) GoString() string {
- return s.String()
- }
- // Describes a stale rule in a security group.
- type StaleIpPermission struct {
- _ struct{} `type:"structure"`
- // The start of the port range for the TCP and UDP protocols, or an ICMP type
- // number. A value of -1 indicates all ICMP types.
- FromPort *int64 `locationName:"fromPort" type:"integer"`
- // The IP protocol name (for tcp, udp, and icmp) or number (see Protocol Numbers)
- // (http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xhtml).
- IpProtocol *string `locationName:"ipProtocol" type:"string"`
- // One or more IP ranges. Not applicable for stale security group rules.
- IpRanges []*string `locationName:"ipRanges" locationNameList:"item" type:"list"`
- // One or more prefix list IDs for an AWS service. Not applicable for stale
- // security group rules.
- PrefixListIds []*string `locationName:"prefixListIds" locationNameList:"item" type:"list"`
- // The end of the port range for the TCP and UDP protocols, or an ICMP type
- // number. A value of -1 indicates all ICMP types.
- ToPort *int64 `locationName:"toPort" type:"integer"`
- // One or more security group pairs. Returns the ID of the referenced security
- // group and VPC, and the ID and status of the VPC peering connection.
- UserIdGroupPairs []*UserIdGroupPair `locationName:"groups" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s StaleIpPermission) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s StaleIpPermission) GoString() string {
- return s.String()
- }
- // Describes a stale security group (a security group that contains stale rules).
- type StaleSecurityGroup struct {
- _ struct{} `type:"structure"`
- // The description of the security group.
- Description *string `locationName:"description" type:"string"`
- // The ID of the security group.
- GroupId *string `locationName:"groupId" type:"string" required:"true"`
- // The name of the security group.
- GroupName *string `locationName:"groupName" type:"string"`
- // Information about the stale inbound rules in the security group.
- StaleIpPermissions []*StaleIpPermission `locationName:"staleIpPermissions" locationNameList:"item" type:"list"`
- // Information about the stale outbound rules in the security group.
- StaleIpPermissionsEgress []*StaleIpPermission `locationName:"staleIpPermissionsEgress" locationNameList:"item" type:"list"`
- // The ID of the VPC for the security group.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s StaleSecurityGroup) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s StaleSecurityGroup) GoString() string {
- return s.String()
- }
- // Contains the parameters for StartInstances.
- type StartInstancesInput struct {
- _ struct{} `type:"structure"`
- // Reserved.
- AdditionalInfo *string `locationName:"additionalInfo" type:"string"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more instance IDs.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s StartInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s StartInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *StartInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "StartInstancesInput"}
- if s.InstanceIds == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of StartInstances.
- type StartInstancesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more started instances.
- StartingInstances []*InstanceStateChange `locationName:"instancesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s StartInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s StartInstancesOutput) GoString() string {
- return s.String()
- }
- // Describes a state change.
- type StateReason struct {
- _ struct{} `type:"structure"`
- // The reason code for the state change.
- Code *string `locationName:"code" type:"string"`
- // The message for the state change.
- //
- // Server.SpotInstanceTermination: A Spot instance was terminated due to
- // an increase in the market price.
- //
- // Server.InternalError: An internal error occurred during instance launch,
- // resulting in termination.
- //
- // Server.InsufficientInstanceCapacity: There was insufficient instance
- // capacity to satisfy the launch request.
- //
- // Client.InternalError: A client error caused the instance to terminate
- // on launch.
- //
- // Client.InstanceInitiatedShutdown: The instance was shut down using the
- // shutdown -h command from the instance.
- //
- // Client.UserInitiatedShutdown: The instance was shut down using the Amazon
- // EC2 API.
- //
- // Client.VolumeLimitExceeded: The limit on the number of EBS volumes or
- // total storage was exceeded. Decrease usage or request an increase in your
- // limits.
- //
- // Client.InvalidSnapshot.NotFound: The specified snapshot was not found.
- Message *string `locationName:"message" type:"string"`
- }
- // String returns the string representation
- func (s StateReason) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s StateReason) GoString() string {
- return s.String()
- }
- // Contains the parameters for StopInstances.
- type StopInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // Forces the instances to stop. The instances do not have an opportunity to
- // flush file system caches or file system metadata. If you use this option,
- // you must perform file system check and repair procedures. This option is
- // not recommended for Windows instances.
- //
- // Default: false
- Force *bool `locationName:"force" type:"boolean"`
- // One or more instance IDs.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s StopInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s StopInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *StopInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "StopInstancesInput"}
- if s.InstanceIds == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of StopInstances.
- type StopInstancesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more stopped instances.
- StoppingInstances []*InstanceStateChange `locationName:"instancesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s StopInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s StopInstancesOutput) GoString() string {
- return s.String()
- }
- // Describes the storage location for an instance store-backed AMI.
- type Storage struct {
- _ struct{} `type:"structure"`
- // An Amazon S3 storage location.
- S3 *S3Storage `type:"structure"`
- }
- // String returns the string representation
- func (s Storage) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Storage) GoString() string {
- return s.String()
- }
- // Describes a subnet.
- type Subnet struct {
- _ struct{} `type:"structure"`
- // The Availability Zone of the subnet.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The number of unused IP addresses in the subnet. Note that the IP addresses
- // for any stopped instances are considered unavailable.
- AvailableIpAddressCount *int64 `locationName:"availableIpAddressCount" type:"integer"`
- // The CIDR block assigned to the subnet.
- CidrBlock *string `locationName:"cidrBlock" type:"string"`
- // Indicates whether this is the default subnet for the Availability Zone.
- DefaultForAz *bool `locationName:"defaultForAz" type:"boolean"`
- // Indicates whether instances launched in this subnet receive a public IP address.
- MapPublicIpOnLaunch *bool `locationName:"mapPublicIpOnLaunch" type:"boolean"`
- // The current state of the subnet.
- State *string `locationName:"state" type:"string" enum:"SubnetState"`
- // The ID of the subnet.
- SubnetId *string `locationName:"subnetId" type:"string"`
- // Any tags assigned to the subnet.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC the subnet is in.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s Subnet) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Subnet) GoString() string {
- return s.String()
- }
- // Describes a tag.
- type Tag struct {
- _ struct{} `type:"structure"`
- // The key of the tag.
- //
- // Constraints: Tag keys are case-sensitive and accept a maximum of 127 Unicode
- // characters. May not begin with aws:
- Key *string `locationName:"key" type:"string"`
- // The value of the tag.
- //
- // Constraints: Tag values are case-sensitive and accept a maximum of 255 Unicode
- // characters.
- Value *string `locationName:"value" type:"string"`
- }
- // String returns the string representation
- func (s Tag) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Tag) GoString() string {
- return s.String()
- }
- // Describes a tag.
- type TagDescription struct {
- _ struct{} `type:"structure"`
- // The tag key.
- Key *string `locationName:"key" type:"string"`
- // The ID of the resource. For example, ami-1a2b3c4d.
- ResourceId *string `locationName:"resourceId" type:"string"`
- // The resource type.
- ResourceType *string `locationName:"resourceType" type:"string" enum:"ResourceType"`
- // The tag value.
- Value *string `locationName:"value" type:"string"`
- }
- // String returns the string representation
- func (s TagDescription) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s TagDescription) GoString() string {
- return s.String()
- }
- // Contains the parameters for TerminateInstances.
- type TerminateInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more instance IDs.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s TerminateInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s TerminateInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *TerminateInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "TerminateInstancesInput"}
- if s.InstanceIds == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of TerminateInstances.
- type TerminateInstancesOutput struct {
- _ struct{} `type:"structure"`
- // Information about one or more terminated instances.
- TerminatingInstances []*InstanceStateChange `locationName:"instancesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s TerminateInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s TerminateInstancesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for UnassignPrivateIpAddresses.
- type UnassignPrivateIpAddressesInput struct {
- _ struct{} `type:"structure"`
- // The ID of the network interface.
- NetworkInterfaceId *string `locationName:"networkInterfaceId" type:"string" required:"true"`
- // The secondary private IP addresses to unassign from the network interface.
- // You can specify this option multiple times to unassign more than one IP address.
- PrivateIpAddresses []*string `locationName:"privateIpAddress" locationNameList:"PrivateIpAddress" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s UnassignPrivateIpAddressesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UnassignPrivateIpAddressesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UnassignPrivateIpAddressesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UnassignPrivateIpAddressesInput"}
- if s.NetworkInterfaceId == nil {
- invalidParams.Add(request.NewErrParamRequired("NetworkInterfaceId"))
- }
- if s.PrivateIpAddresses == nil {
- invalidParams.Add(request.NewErrParamRequired("PrivateIpAddresses"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- type UnassignPrivateIpAddressesOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation
- func (s UnassignPrivateIpAddressesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UnassignPrivateIpAddressesOutput) GoString() string {
- return s.String()
- }
- // Contains the parameters for UnmonitorInstances.
- type UnmonitorInstancesInput struct {
- _ struct{} `type:"structure"`
- // Checks whether you have the required permissions for the action, without
- // actually making the request, and provides an error response. If you have
- // the required permissions, the error response is DryRunOperation. Otherwise,
- // it is UnauthorizedOperation.
- DryRun *bool `locationName:"dryRun" type:"boolean"`
- // One or more instance IDs.
- InstanceIds []*string `locationName:"InstanceId" locationNameList:"InstanceId" type:"list" required:"true"`
- }
- // String returns the string representation
- func (s UnmonitorInstancesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UnmonitorInstancesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UnmonitorInstancesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UnmonitorInstancesInput"}
- if s.InstanceIds == nil {
- invalidParams.Add(request.NewErrParamRequired("InstanceIds"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Contains the output of UnmonitorInstances.
- type UnmonitorInstancesOutput struct {
- _ struct{} `type:"structure"`
- // Monitoring information for one or more instances.
- InstanceMonitorings []*InstanceMonitoring `locationName:"instancesSet" locationNameList:"item" type:"list"`
- }
- // String returns the string representation
- func (s UnmonitorInstancesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UnmonitorInstancesOutput) GoString() string {
- return s.String()
- }
- // Information about items that were not successfully processed in a batch call.
- type UnsuccessfulItem struct {
- _ struct{} `type:"structure"`
- // Information about the error.
- Error *UnsuccessfulItemError `locationName:"error" type:"structure" required:"true"`
- // The ID of the resource.
- ResourceId *string `locationName:"resourceId" type:"string"`
- }
- // String returns the string representation
- func (s UnsuccessfulItem) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UnsuccessfulItem) GoString() string {
- return s.String()
- }
- // Information about the error that occurred. For more information about errors,
- // see Error Codes (http://docs.aws.amazon.com/AWSEC2/latest/APIReference/errors-overview.html).
- type UnsuccessfulItemError struct {
- _ struct{} `type:"structure"`
- // The error code.
- Code *string `locationName:"code" type:"string" required:"true"`
- // The error message accompanying the error code.
- Message *string `locationName:"message" type:"string" required:"true"`
- }
- // String returns the string representation
- func (s UnsuccessfulItemError) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UnsuccessfulItemError) GoString() string {
- return s.String()
- }
- // Describes the S3 bucket for the disk image.
- type UserBucket struct {
- _ struct{} `type:"structure"`
- // The name of the S3 bucket where the disk image is located.
- S3Bucket *string `type:"string"`
- // The file name of the disk image.
- S3Key *string `type:"string"`
- }
- // String returns the string representation
- func (s UserBucket) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UserBucket) GoString() string {
- return s.String()
- }
- // Describes the S3 bucket for the disk image.
- type UserBucketDetails struct {
- _ struct{} `type:"structure"`
- // The S3 bucket from which the disk image was created.
- S3Bucket *string `locationName:"s3Bucket" type:"string"`
- // The file name of the disk image.
- S3Key *string `locationName:"s3Key" type:"string"`
- }
- // String returns the string representation
- func (s UserBucketDetails) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UserBucketDetails) GoString() string {
- return s.String()
- }
- // Describes the user data for an instance.
- type UserData struct {
- _ struct{} `type:"structure"`
- // The user data. If you are using an AWS SDK or command line tool, Base64-encoding
- // is performed for you, and you can load the text from a file. Otherwise, you
- // must provide Base64-encoded text.
- Data *string `locationName:"data" type:"string"`
- }
- // String returns the string representation
- func (s UserData) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UserData) GoString() string {
- return s.String()
- }
- // Describes a security group and AWS account ID pair.
- type UserIdGroupPair struct {
- _ struct{} `type:"structure"`
- // The ID of the security group.
- GroupId *string `locationName:"groupId" type:"string"`
- // The name of the security group. In a request, use this parameter for a security
- // group in EC2-Classic or a default VPC only. For a security group in a nondefault
- // VPC, use the security group ID.
- GroupName *string `locationName:"groupName" type:"string"`
- // The status of a VPC peering connection, if applicable.
- PeeringStatus *string `locationName:"peeringStatus" type:"string"`
- // The ID of an AWS account. For a referenced security group in another VPC,
- // the account ID of the referenced security group is returned.
- //
- // [EC2-Classic] Required when adding or removing rules that reference a security
- // group in another AWS account.
- UserId *string `locationName:"userId" type:"string"`
- // The ID of the VPC for the referenced security group, if applicable.
- VpcId *string `locationName:"vpcId" type:"string"`
- // The ID of the VPC peering connection, if applicable.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string"`
- }
- // String returns the string representation
- func (s UserIdGroupPair) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s UserIdGroupPair) GoString() string {
- return s.String()
- }
- // Describes telemetry for a VPN tunnel.
- type VgwTelemetry struct {
- _ struct{} `type:"structure"`
- // The number of accepted routes.
- AcceptedRouteCount *int64 `locationName:"acceptedRouteCount" type:"integer"`
- // The date and time of the last change in status.
- LastStatusChange *time.Time `locationName:"lastStatusChange" type:"timestamp" timestampFormat:"iso8601"`
- // The Internet-routable IP address of the virtual private gateway's outside
- // interface.
- OutsideIpAddress *string `locationName:"outsideIpAddress" type:"string"`
- // The status of the VPN tunnel.
- Status *string `locationName:"status" type:"string" enum:"TelemetryStatus"`
- // If an error occurs, a description of the error.
- StatusMessage *string `locationName:"statusMessage" type:"string"`
- }
- // String returns the string representation
- func (s VgwTelemetry) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VgwTelemetry) GoString() string {
- return s.String()
- }
- // Describes a volume.
- type Volume struct {
- _ struct{} `type:"structure"`
- // Information about the volume attachments.
- Attachments []*VolumeAttachment `locationName:"attachmentSet" locationNameList:"item" type:"list"`
- // The Availability Zone for the volume.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The time stamp when volume creation was initiated.
- CreateTime *time.Time `locationName:"createTime" type:"timestamp" timestampFormat:"iso8601"`
- // Indicates whether the volume will be encrypted.
- Encrypted *bool `locationName:"encrypted" type:"boolean"`
- // The number of I/O operations per second (IOPS) that the volume supports.
- // For Provisioned IOPS SSD volumes, this represents the number of IOPS that
- // are provisioned for the volume. For General Purpose SSD volumes, this represents
- // the baseline performance of the volume and the rate at which the volume accumulates
- // I/O credits for bursting. For more information on General Purpose SSD baseline
- // performance, I/O credits, and bursting, see Amazon EBS Volume Types (http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSVolumeTypes.html)
- // in the Amazon Elastic Compute Cloud User Guide.
- //
- // Constraint: Range is 100-20000 IOPS for io1 volumes and 100-10000 IOPS for
- // gp2 volumes.
- //
- // Condition: This parameter is required for requests to create io1 volumes;
- // it is not used in requests to create gp2, st1, sc1, or standard volumes.
- Iops *int64 `locationName:"iops" type:"integer"`
- // The full ARN of the AWS Key Management Service (AWS KMS) customer master
- // key (CMK) that was used to protect the volume encryption key for the volume.
- KmsKeyId *string `locationName:"kmsKeyId" type:"string"`
- // The size of the volume, in GiBs.
- Size *int64 `locationName:"size" type:"integer"`
- // The snapshot from which the volume was created, if applicable.
- SnapshotId *string `locationName:"snapshotId" type:"string"`
- // The volume state.
- State *string `locationName:"status" type:"string" enum:"VolumeState"`
- // Any tags assigned to the volume.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the volume.
- VolumeId *string `locationName:"volumeId" type:"string"`
- // The volume type. This can be gp2 for General Purpose SSD, io1 for Provisioned
- // IOPS SSD, st1 for Throughput Optimized HDD, sc1 for Cold HDD, or standard
- // for Magnetic volumes.
- VolumeType *string `locationName:"volumeType" type:"string" enum:"VolumeType"`
- }
- // String returns the string representation
- func (s Volume) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Volume) GoString() string {
- return s.String()
- }
- // Describes volume attachment details.
- type VolumeAttachment struct {
- _ struct{} `type:"structure"`
- // The time stamp when the attachment initiated.
- AttachTime *time.Time `locationName:"attachTime" type:"timestamp" timestampFormat:"iso8601"`
- // Indicates whether the EBS volume is deleted on instance termination.
- DeleteOnTermination *bool `locationName:"deleteOnTermination" type:"boolean"`
- // The device name.
- Device *string `locationName:"device" type:"string"`
- // The ID of the instance.
- InstanceId *string `locationName:"instanceId" type:"string"`
- // The attachment state of the volume.
- State *string `locationName:"status" type:"string" enum:"VolumeAttachmentState"`
- // The ID of the volume.
- VolumeId *string `locationName:"volumeId" type:"string"`
- }
- // String returns the string representation
- func (s VolumeAttachment) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VolumeAttachment) GoString() string {
- return s.String()
- }
- // Describes an EBS volume.
- type VolumeDetail struct {
- _ struct{} `type:"structure"`
- // The size of the volume, in GiB.
- Size *int64 `locationName:"size" type:"long" required:"true"`
- }
- // String returns the string representation
- func (s VolumeDetail) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VolumeDetail) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *VolumeDetail) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "VolumeDetail"}
- if s.Size == nil {
- invalidParams.Add(request.NewErrParamRequired("Size"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // Describes a volume status operation code.
- type VolumeStatusAction struct {
- _ struct{} `type:"structure"`
- // The code identifying the operation, for example, enable-volume-io.
- Code *string `locationName:"code" type:"string"`
- // A description of the operation.
- Description *string `locationName:"description" type:"string"`
- // The ID of the event associated with this operation.
- EventId *string `locationName:"eventId" type:"string"`
- // The event type associated with this operation.
- EventType *string `locationName:"eventType" type:"string"`
- }
- // String returns the string representation
- func (s VolumeStatusAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VolumeStatusAction) GoString() string {
- return s.String()
- }
- // Describes a volume status.
- type VolumeStatusDetails struct {
- _ struct{} `type:"structure"`
- // The name of the volume status.
- Name *string `locationName:"name" type:"string" enum:"VolumeStatusName"`
- // The intended status of the volume status.
- Status *string `locationName:"status" type:"string"`
- }
- // String returns the string representation
- func (s VolumeStatusDetails) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VolumeStatusDetails) GoString() string {
- return s.String()
- }
- // Describes a volume status event.
- type VolumeStatusEvent struct {
- _ struct{} `type:"structure"`
- // A description of the event.
- Description *string `locationName:"description" type:"string"`
- // The ID of this event.
- EventId *string `locationName:"eventId" type:"string"`
- // The type of this event.
- EventType *string `locationName:"eventType" type:"string"`
- // The latest end time of the event.
- NotAfter *time.Time `locationName:"notAfter" type:"timestamp" timestampFormat:"iso8601"`
- // The earliest start time of the event.
- NotBefore *time.Time `locationName:"notBefore" type:"timestamp" timestampFormat:"iso8601"`
- }
- // String returns the string representation
- func (s VolumeStatusEvent) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VolumeStatusEvent) GoString() string {
- return s.String()
- }
- // Describes the status of a volume.
- type VolumeStatusInfo struct {
- _ struct{} `type:"structure"`
- // The details of the volume status.
- Details []*VolumeStatusDetails `locationName:"details" locationNameList:"item" type:"list"`
- // The status of the volume.
- Status *string `locationName:"status" type:"string" enum:"VolumeStatusInfoStatus"`
- }
- // String returns the string representation
- func (s VolumeStatusInfo) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VolumeStatusInfo) GoString() string {
- return s.String()
- }
- // Describes the volume status.
- type VolumeStatusItem struct {
- _ struct{} `type:"structure"`
- // The details of the operation.
- Actions []*VolumeStatusAction `locationName:"actionsSet" locationNameList:"item" type:"list"`
- // The Availability Zone of the volume.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // A list of events associated with the volume.
- Events []*VolumeStatusEvent `locationName:"eventsSet" locationNameList:"item" type:"list"`
- // The volume ID.
- VolumeId *string `locationName:"volumeId" type:"string"`
- // The volume status.
- VolumeStatus *VolumeStatusInfo `locationName:"volumeStatus" type:"structure"`
- }
- // String returns the string representation
- func (s VolumeStatusItem) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VolumeStatusItem) GoString() string {
- return s.String()
- }
- // Describes a VPC.
- type Vpc struct {
- _ struct{} `type:"structure"`
- // The CIDR block for the VPC.
- CidrBlock *string `locationName:"cidrBlock" type:"string"`
- // The ID of the set of DHCP options you've associated with the VPC (or default
- // if the default options are associated with the VPC).
- DhcpOptionsId *string `locationName:"dhcpOptionsId" type:"string"`
- // The allowed tenancy of instances launched into the VPC.
- InstanceTenancy *string `locationName:"instanceTenancy" type:"string" enum:"Tenancy"`
- // Indicates whether the VPC is the default VPC.
- IsDefault *bool `locationName:"isDefault" type:"boolean"`
- // The current state of the VPC.
- State *string `locationName:"state" type:"string" enum:"VpcState"`
- // Any tags assigned to the VPC.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s Vpc) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s Vpc) GoString() string {
- return s.String()
- }
- // Describes an attachment between a virtual private gateway and a VPC.
- type VpcAttachment struct {
- _ struct{} `type:"structure"`
- // The current state of the attachment.
- State *string `locationName:"state" type:"string" enum:"AttachmentStatus"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s VpcAttachment) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpcAttachment) GoString() string {
- return s.String()
- }
- // Describes whether a VPC is enabled for ClassicLink.
- type VpcClassicLink struct {
- _ struct{} `type:"structure"`
- // Indicates whether the VPC is enabled for ClassicLink.
- ClassicLinkEnabled *bool `locationName:"classicLinkEnabled" type:"boolean"`
- // Any tags assigned to the VPC.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s VpcClassicLink) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpcClassicLink) GoString() string {
- return s.String()
- }
- // Describes a VPC endpoint.
- type VpcEndpoint struct {
- _ struct{} `type:"structure"`
- // The date and time the VPC endpoint was created.
- CreationTimestamp *time.Time `locationName:"creationTimestamp" type:"timestamp" timestampFormat:"iso8601"`
- // The policy document associated with the endpoint.
- PolicyDocument *string `locationName:"policyDocument" type:"string"`
- // One or more route tables associated with the endpoint.
- RouteTableIds []*string `locationName:"routeTableIdSet" locationNameList:"item" type:"list"`
- // The name of the AWS service to which the endpoint is associated.
- ServiceName *string `locationName:"serviceName" type:"string"`
- // The state of the VPC endpoint.
- State *string `locationName:"state" type:"string" enum:"State"`
- // The ID of the VPC endpoint.
- VpcEndpointId *string `locationName:"vpcEndpointId" type:"string"`
- // The ID of the VPC to which the endpoint is associated.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s VpcEndpoint) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpcEndpoint) GoString() string {
- return s.String()
- }
- // Describes a VPC peering connection.
- type VpcPeeringConnection struct {
- _ struct{} `type:"structure"`
- // Information about the accepter VPC. CIDR block information is not returned
- // when creating a VPC peering connection, or when describing a VPC peering
- // connection that's in the initiating-request or pending-acceptance state.
- AccepterVpcInfo *VpcPeeringConnectionVpcInfo `locationName:"accepterVpcInfo" type:"structure"`
- // The time that an unaccepted VPC peering connection will expire.
- ExpirationTime *time.Time `locationName:"expirationTime" type:"timestamp" timestampFormat:"iso8601"`
- // Information about the requester VPC.
- RequesterVpcInfo *VpcPeeringConnectionVpcInfo `locationName:"requesterVpcInfo" type:"structure"`
- // The status of the VPC peering connection.
- Status *VpcPeeringConnectionStateReason `locationName:"status" type:"structure"`
- // Any tags assigned to the resource.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The ID of the VPC peering connection.
- VpcPeeringConnectionId *string `locationName:"vpcPeeringConnectionId" type:"string"`
- }
- // String returns the string representation
- func (s VpcPeeringConnection) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpcPeeringConnection) GoString() string {
- return s.String()
- }
- // Describes the VPC peering connection options.
- type VpcPeeringConnectionOptionsDescription struct {
- _ struct{} `type:"structure"`
- // Indicates whether a local VPC can resolve public DNS hostnames to private
- // IP addresses when queried from instances in a peer VPC.
- AllowDnsResolutionFromRemoteVpc *bool `locationName:"allowDnsResolutionFromRemoteVpc" type:"boolean"`
- // Indicates whether a local ClassicLink connection can communicate with the
- // peer VPC over the VPC peering connection.
- AllowEgressFromLocalClassicLinkToRemoteVpc *bool `locationName:"allowEgressFromLocalClassicLinkToRemoteVpc" type:"boolean"`
- // Indicates whether a local VPC can communicate with a ClassicLink connection
- // in the peer VPC over the VPC peering connection.
- AllowEgressFromLocalVpcToRemoteClassicLink *bool `locationName:"allowEgressFromLocalVpcToRemoteClassicLink" type:"boolean"`
- }
- // String returns the string representation
- func (s VpcPeeringConnectionOptionsDescription) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpcPeeringConnectionOptionsDescription) GoString() string {
- return s.String()
- }
- // Describes the status of a VPC peering connection.
- type VpcPeeringConnectionStateReason struct {
- _ struct{} `type:"structure"`
- // The status of the VPC peering connection.
- Code *string `locationName:"code" type:"string" enum:"VpcPeeringConnectionStateReasonCode"`
- // A message that provides more information about the status, if applicable.
- Message *string `locationName:"message" type:"string"`
- }
- // String returns the string representation
- func (s VpcPeeringConnectionStateReason) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpcPeeringConnectionStateReason) GoString() string {
- return s.String()
- }
- // Describes a VPC in a VPC peering connection.
- type VpcPeeringConnectionVpcInfo struct {
- _ struct{} `type:"structure"`
- // The CIDR block for the VPC.
- CidrBlock *string `locationName:"cidrBlock" type:"string"`
- // The AWS account ID of the VPC owner.
- OwnerId *string `locationName:"ownerId" type:"string"`
- // Information about the VPC peering connection options for the accepter or
- // requester VPC.
- PeeringOptions *VpcPeeringConnectionOptionsDescription `locationName:"peeringOptions" type:"structure"`
- // The ID of the VPC.
- VpcId *string `locationName:"vpcId" type:"string"`
- }
- // String returns the string representation
- func (s VpcPeeringConnectionVpcInfo) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpcPeeringConnectionVpcInfo) GoString() string {
- return s.String()
- }
- // Describes a VPN connection.
- type VpnConnection struct {
- _ struct{} `type:"structure"`
- // The configuration information for the VPN connection's customer gateway (in
- // the native XML format). This element is always present in the CreateVpnConnection
- // response; however, it's present in the DescribeVpnConnections response only
- // if the VPN connection is in the pending or available state.
- CustomerGatewayConfiguration *string `locationName:"customerGatewayConfiguration" type:"string"`
- // The ID of the customer gateway at your end of the VPN connection.
- CustomerGatewayId *string `locationName:"customerGatewayId" type:"string"`
- // The VPN connection options.
- Options *VpnConnectionOptions `locationName:"options" type:"structure"`
- // The static routes associated with the VPN connection.
- Routes []*VpnStaticRoute `locationName:"routes" locationNameList:"item" type:"list"`
- // The current state of the VPN connection.
- State *string `locationName:"state" type:"string" enum:"VpnState"`
- // Any tags assigned to the VPN connection.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The type of VPN connection.
- Type *string `locationName:"type" type:"string" enum:"GatewayType"`
- // Information about the VPN tunnel.
- VgwTelemetry []*VgwTelemetry `locationName:"vgwTelemetry" locationNameList:"item" type:"list"`
- // The ID of the VPN connection.
- VpnConnectionId *string `locationName:"vpnConnectionId" type:"string"`
- // The ID of the virtual private gateway at the AWS side of the VPN connection.
- VpnGatewayId *string `locationName:"vpnGatewayId" type:"string"`
- }
- // String returns the string representation
- func (s VpnConnection) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpnConnection) GoString() string {
- return s.String()
- }
- // Describes VPN connection options.
- type VpnConnectionOptions struct {
- _ struct{} `type:"structure"`
- // Indicates whether the VPN connection uses static routes only. Static routes
- // must be used for devices that don't support BGP.
- StaticRoutesOnly *bool `locationName:"staticRoutesOnly" type:"boolean"`
- }
- // String returns the string representation
- func (s VpnConnectionOptions) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpnConnectionOptions) GoString() string {
- return s.String()
- }
- // Describes VPN connection options.
- type VpnConnectionOptionsSpecification struct {
- _ struct{} `type:"structure"`
- // Indicates whether the VPN connection uses static routes only. Static routes
- // must be used for devices that don't support BGP.
- StaticRoutesOnly *bool `locationName:"staticRoutesOnly" type:"boolean"`
- }
- // String returns the string representation
- func (s VpnConnectionOptionsSpecification) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpnConnectionOptionsSpecification) GoString() string {
- return s.String()
- }
- // Describes a virtual private gateway.
- type VpnGateway struct {
- _ struct{} `type:"structure"`
- // The Availability Zone where the virtual private gateway was created, if applicable.
- // This field may be empty or not returned.
- AvailabilityZone *string `locationName:"availabilityZone" type:"string"`
- // The current state of the virtual private gateway.
- State *string `locationName:"state" type:"string" enum:"VpnState"`
- // Any tags assigned to the virtual private gateway.
- Tags []*Tag `locationName:"tagSet" locationNameList:"item" type:"list"`
- // The type of VPN connection the virtual private gateway supports.
- Type *string `locationName:"type" type:"string" enum:"GatewayType"`
- // Any VPCs attached to the virtual private gateway.
- VpcAttachments []*VpcAttachment `locationName:"attachments" locationNameList:"item" type:"list"`
- // The ID of the virtual private gateway.
- VpnGatewayId *string `locationName:"vpnGatewayId" type:"string"`
- }
- // String returns the string representation
- func (s VpnGateway) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpnGateway) GoString() string {
- return s.String()
- }
- // Describes a static route for a VPN connection.
- type VpnStaticRoute struct {
- _ struct{} `type:"structure"`
- // The CIDR block associated with the local subnet of the customer data center.
- DestinationCidrBlock *string `locationName:"destinationCidrBlock" type:"string"`
- // Indicates how the routes were provided.
- Source *string `locationName:"source" type:"string" enum:"VpnStaticRouteSource"`
- // The current state of the static route.
- State *string `locationName:"state" type:"string" enum:"VpnState"`
- }
- // String returns the string representation
- func (s VpnStaticRoute) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation
- func (s VpnStaticRoute) GoString() string {
- return s.String()
- }
- const (
- // @enum AccountAttributeName
- AccountAttributeNameSupportedPlatforms = "supported-platforms"
- // @enum AccountAttributeName
- AccountAttributeNameDefaultVpc = "default-vpc"
- )
- const (
- // @enum Affinity
- AffinityDefault = "default"
- // @enum Affinity
- AffinityHost = "host"
- )
- const (
- // @enum AllocationState
- AllocationStateAvailable = "available"
- // @enum AllocationState
- AllocationStateUnderAssessment = "under-assessment"
- // @enum AllocationState
- AllocationStatePermanentFailure = "permanent-failure"
- // @enum AllocationState
- AllocationStateReleased = "released"
- // @enum AllocationState
- AllocationStateReleasedPermanentFailure = "released-permanent-failure"
- )
- const (
- // @enum AllocationStrategy
- AllocationStrategyLowestPrice = "lowestPrice"
- // @enum AllocationStrategy
- AllocationStrategyDiversified = "diversified"
- )
- const (
- // @enum ArchitectureValues
- ArchitectureValuesI386 = "i386"
- // @enum ArchitectureValues
- ArchitectureValuesX8664 = "x86_64"
- )
- const (
- // @enum AttachmentStatus
- AttachmentStatusAttaching = "attaching"
- // @enum AttachmentStatus
- AttachmentStatusAttached = "attached"
- // @enum AttachmentStatus
- AttachmentStatusDetaching = "detaching"
- // @enum AttachmentStatus
- AttachmentStatusDetached = "detached"
- )
- const (
- // @enum AutoPlacement
- AutoPlacementOn = "on"
- // @enum AutoPlacement
- AutoPlacementOff = "off"
- )
- const (
- // @enum AvailabilityZoneState
- AvailabilityZoneStateAvailable = "available"
- // @enum AvailabilityZoneState
- AvailabilityZoneStateInformation = "information"
- // @enum AvailabilityZoneState
- AvailabilityZoneStateImpaired = "impaired"
- // @enum AvailabilityZoneState
- AvailabilityZoneStateUnavailable = "unavailable"
- )
- const (
- // @enum BatchState
- BatchStateSubmitted = "submitted"
- // @enum BatchState
- BatchStateActive = "active"
- // @enum BatchState
- BatchStateCancelled = "cancelled"
- // @enum BatchState
- BatchStateFailed = "failed"
- // @enum BatchState
- BatchStateCancelledRunning = "cancelled_running"
- // @enum BatchState
- BatchStateCancelledTerminating = "cancelled_terminating"
- // @enum BatchState
- BatchStateModifying = "modifying"
- )
- const (
- // @enum BundleTaskState
- BundleTaskStatePending = "pending"
- // @enum BundleTaskState
- BundleTaskStateWaitingForShutdown = "waiting-for-shutdown"
- // @enum BundleTaskState
- BundleTaskStateBundling = "bundling"
- // @enum BundleTaskState
- BundleTaskStateStoring = "storing"
- // @enum BundleTaskState
- BundleTaskStateCancelling = "cancelling"
- // @enum BundleTaskState
- BundleTaskStateComplete = "complete"
- // @enum BundleTaskState
- BundleTaskStateFailed = "failed"
- )
- const (
- // @enum CancelBatchErrorCode
- CancelBatchErrorCodeFleetRequestIdDoesNotExist = "fleetRequestIdDoesNotExist"
- // @enum CancelBatchErrorCode
- CancelBatchErrorCodeFleetRequestIdMalformed = "fleetRequestIdMalformed"
- // @enum CancelBatchErrorCode
- CancelBatchErrorCodeFleetRequestNotInCancellableState = "fleetRequestNotInCancellableState"
- // @enum CancelBatchErrorCode
- CancelBatchErrorCodeUnexpectedError = "unexpectedError"
- )
- const (
- // @enum CancelSpotInstanceRequestState
- CancelSpotInstanceRequestStateActive = "active"
- // @enum CancelSpotInstanceRequestState
- CancelSpotInstanceRequestStateOpen = "open"
- // @enum CancelSpotInstanceRequestState
- CancelSpotInstanceRequestStateClosed = "closed"
- // @enum CancelSpotInstanceRequestState
- CancelSpotInstanceRequestStateCancelled = "cancelled"
- // @enum CancelSpotInstanceRequestState
- CancelSpotInstanceRequestStateCompleted = "completed"
- )
- const (
- // @enum ContainerFormat
- ContainerFormatOva = "ova"
- )
- const (
- // @enum ConversionTaskState
- ConversionTaskStateActive = "active"
- // @enum ConversionTaskState
- ConversionTaskStateCancelling = "cancelling"
- // @enum ConversionTaskState
- ConversionTaskStateCancelled = "cancelled"
- // @enum ConversionTaskState
- ConversionTaskStateCompleted = "completed"
- )
- const (
- // @enum CurrencyCodeValues
- CurrencyCodeValuesUsd = "USD"
- )
- const (
- // @enum DatafeedSubscriptionState
- DatafeedSubscriptionStateActive = "Active"
- // @enum DatafeedSubscriptionState
- DatafeedSubscriptionStateInactive = "Inactive"
- )
- const (
- // @enum DeviceType
- DeviceTypeEbs = "ebs"
- // @enum DeviceType
- DeviceTypeInstanceStore = "instance-store"
- )
- const (
- // @enum DiskImageFormat
- DiskImageFormatVmdk = "VMDK"
- // @enum DiskImageFormat
- DiskImageFormatRaw = "RAW"
- // @enum DiskImageFormat
- DiskImageFormatVhd = "VHD"
- )
- const (
- // @enum DomainType
- DomainTypeVpc = "vpc"
- // @enum DomainType
- DomainTypeStandard = "standard"
- )
- const (
- // @enum EventCode
- EventCodeInstanceReboot = "instance-reboot"
- // @enum EventCode
- EventCodeSystemReboot = "system-reboot"
- // @enum EventCode
- EventCodeSystemMaintenance = "system-maintenance"
- // @enum EventCode
- EventCodeInstanceRetirement = "instance-retirement"
- // @enum EventCode
- EventCodeInstanceStop = "instance-stop"
- )
- const (
- // @enum EventType
- EventTypeInstanceChange = "instanceChange"
- // @enum EventType
- EventTypeFleetRequestChange = "fleetRequestChange"
- // @enum EventType
- EventTypeError = "error"
- )
- const (
- // @enum ExcessCapacityTerminationPolicy
- ExcessCapacityTerminationPolicyNoTermination = "noTermination"
- // @enum ExcessCapacityTerminationPolicy
- ExcessCapacityTerminationPolicyDefault = "default"
- )
- const (
- // @enum ExportEnvironment
- ExportEnvironmentCitrix = "citrix"
- // @enum ExportEnvironment
- ExportEnvironmentVmware = "vmware"
- // @enum ExportEnvironment
- ExportEnvironmentMicrosoft = "microsoft"
- )
- const (
- // @enum ExportTaskState
- ExportTaskStateActive = "active"
- // @enum ExportTaskState
- ExportTaskStateCancelling = "cancelling"
- // @enum ExportTaskState
- ExportTaskStateCancelled = "cancelled"
- // @enum ExportTaskState
- ExportTaskStateCompleted = "completed"
- )
- const (
- // @enum FleetType
- FleetTypeRequest = "request"
- // @enum FleetType
- FleetTypeMaintain = "maintain"
- )
- const (
- // @enum FlowLogsResourceType
- FlowLogsResourceTypeVpc = "VPC"
- // @enum FlowLogsResourceType
- FlowLogsResourceTypeSubnet = "Subnet"
- // @enum FlowLogsResourceType
- FlowLogsResourceTypeNetworkInterface = "NetworkInterface"
- )
- const (
- // @enum GatewayType
- GatewayTypeIpsec1 = "ipsec.1"
- )
- const (
- // @enum HostTenancy
- HostTenancyDedicated = "dedicated"
- // @enum HostTenancy
- HostTenancyHost = "host"
- )
- const (
- // @enum HypervisorType
- HypervisorTypeOvm = "ovm"
- // @enum HypervisorType
- HypervisorTypeXen = "xen"
- )
- const (
- // @enum ImageAttributeName
- ImageAttributeNameDescription = "description"
- // @enum ImageAttributeName
- ImageAttributeNameKernel = "kernel"
- // @enum ImageAttributeName
- ImageAttributeNameRamdisk = "ramdisk"
- // @enum ImageAttributeName
- ImageAttributeNameLaunchPermission = "launchPermission"
- // @enum ImageAttributeName
- ImageAttributeNameProductCodes = "productCodes"
- // @enum ImageAttributeName
- ImageAttributeNameBlockDeviceMapping = "blockDeviceMapping"
- // @enum ImageAttributeName
- ImageAttributeNameSriovNetSupport = "sriovNetSupport"
- )
- const (
- // @enum ImageState
- ImageStatePending = "pending"
- // @enum ImageState
- ImageStateAvailable = "available"
- // @enum ImageState
- ImageStateInvalid = "invalid"
- // @enum ImageState
- ImageStateDeregistered = "deregistered"
- // @enum ImageState
- ImageStateTransient = "transient"
- // @enum ImageState
- ImageStateFailed = "failed"
- // @enum ImageState
- ImageStateError = "error"
- )
- const (
- // @enum ImageTypeValues
- ImageTypeValuesMachine = "machine"
- // @enum ImageTypeValues
- ImageTypeValuesKernel = "kernel"
- // @enum ImageTypeValues
- ImageTypeValuesRamdisk = "ramdisk"
- )
- const (
- // @enum InstanceAttributeName
- InstanceAttributeNameInstanceType = "instanceType"
- // @enum InstanceAttributeName
- InstanceAttributeNameKernel = "kernel"
- // @enum InstanceAttributeName
- InstanceAttributeNameRamdisk = "ramdisk"
- // @enum InstanceAttributeName
- InstanceAttributeNameUserData = "userData"
- // @enum InstanceAttributeName
- InstanceAttributeNameDisableApiTermination = "disableApiTermination"
- // @enum InstanceAttributeName
- InstanceAttributeNameInstanceInitiatedShutdownBehavior = "instanceInitiatedShutdownBehavior"
- // @enum InstanceAttributeName
- InstanceAttributeNameRootDeviceName = "rootDeviceName"
- // @enum InstanceAttributeName
- InstanceAttributeNameBlockDeviceMapping = "blockDeviceMapping"
- // @enum InstanceAttributeName
- InstanceAttributeNameProductCodes = "productCodes"
- // @enum InstanceAttributeName
- InstanceAttributeNameSourceDestCheck = "sourceDestCheck"
- // @enum InstanceAttributeName
- InstanceAttributeNameGroupSet = "groupSet"
- // @enum InstanceAttributeName
- InstanceAttributeNameEbsOptimized = "ebsOptimized"
- // @enum InstanceAttributeName
- InstanceAttributeNameSriovNetSupport = "sriovNetSupport"
- // @enum InstanceAttributeName
- InstanceAttributeNameEnaSupport = "enaSupport"
- )
- const (
- // @enum InstanceLifecycleType
- InstanceLifecycleTypeSpot = "spot"
- // @enum InstanceLifecycleType
- InstanceLifecycleTypeScheduled = "scheduled"
- )
- const (
- // @enum InstanceStateName
- InstanceStateNamePending = "pending"
- // @enum InstanceStateName
- InstanceStateNameRunning = "running"
- // @enum InstanceStateName
- InstanceStateNameShuttingDown = "shutting-down"
- // @enum InstanceStateName
- InstanceStateNameTerminated = "terminated"
- // @enum InstanceStateName
- InstanceStateNameStopping = "stopping"
- // @enum InstanceStateName
- InstanceStateNameStopped = "stopped"
- )
- const (
- // @enum InstanceType
- InstanceTypeT1Micro = "t1.micro"
- // @enum InstanceType
- InstanceTypeT2Nano = "t2.nano"
- // @enum InstanceType
- InstanceTypeT2Micro = "t2.micro"
- // @enum InstanceType
- InstanceTypeT2Small = "t2.small"
- // @enum InstanceType
- InstanceTypeT2Medium = "t2.medium"
- // @enum InstanceType
- InstanceTypeT2Large = "t2.large"
- // @enum InstanceType
- InstanceTypeM1Small = "m1.small"
- // @enum InstanceType
- InstanceTypeM1Medium = "m1.medium"
- // @enum InstanceType
- InstanceTypeM1Large = "m1.large"
- // @enum InstanceType
- InstanceTypeM1Xlarge = "m1.xlarge"
- // @enum InstanceType
- InstanceTypeM3Medium = "m3.medium"
- // @enum InstanceType
- InstanceTypeM3Large = "m3.large"
- // @enum InstanceType
- InstanceTypeM3Xlarge = "m3.xlarge"
- // @enum InstanceType
- InstanceTypeM32xlarge = "m3.2xlarge"
- // @enum InstanceType
- InstanceTypeM4Large = "m4.large"
- // @enum InstanceType
- InstanceTypeM4Xlarge = "m4.xlarge"
- // @enum InstanceType
- InstanceTypeM42xlarge = "m4.2xlarge"
- // @enum InstanceType
- InstanceTypeM44xlarge = "m4.4xlarge"
- // @enum InstanceType
- InstanceTypeM410xlarge = "m4.10xlarge"
- // @enum InstanceType
- InstanceTypeM2Xlarge = "m2.xlarge"
- // @enum InstanceType
- InstanceTypeM22xlarge = "m2.2xlarge"
- // @enum InstanceType
- InstanceTypeM24xlarge = "m2.4xlarge"
- // @enum InstanceType
- InstanceTypeCr18xlarge = "cr1.8xlarge"
- // @enum InstanceType
- InstanceTypeR3Large = "r3.large"
- // @enum InstanceType
- InstanceTypeR3Xlarge = "r3.xlarge"
- // @enum InstanceType
- InstanceTypeR32xlarge = "r3.2xlarge"
- // @enum InstanceType
- InstanceTypeR34xlarge = "r3.4xlarge"
- // @enum InstanceType
- InstanceTypeR38xlarge = "r3.8xlarge"
- // @enum InstanceType
- InstanceTypeX14xlarge = "x1.4xlarge"
- // @enum InstanceType
- InstanceTypeX18xlarge = "x1.8xlarge"
- // @enum InstanceType
- InstanceTypeX116xlarge = "x1.16xlarge"
- // @enum InstanceType
- InstanceTypeX132xlarge = "x1.32xlarge"
- // @enum InstanceType
- InstanceTypeI2Xlarge = "i2.xlarge"
- // @enum InstanceType
- InstanceTypeI22xlarge = "i2.2xlarge"
- // @enum InstanceType
- InstanceTypeI24xlarge = "i2.4xlarge"
- // @enum InstanceType
- InstanceTypeI28xlarge = "i2.8xlarge"
- // @enum InstanceType
- InstanceTypeHi14xlarge = "hi1.4xlarge"
- // @enum InstanceType
- InstanceTypeHs18xlarge = "hs1.8xlarge"
- // @enum InstanceType
- InstanceTypeC1Medium = "c1.medium"
- // @enum InstanceType
- InstanceTypeC1Xlarge = "c1.xlarge"
- // @enum InstanceType
- InstanceTypeC3Large = "c3.large"
- // @enum InstanceType
- InstanceTypeC3Xlarge = "c3.xlarge"
- // @enum InstanceType
- InstanceTypeC32xlarge = "c3.2xlarge"
- // @enum InstanceType
- InstanceTypeC34xlarge = "c3.4xlarge"
- // @enum InstanceType
- InstanceTypeC38xlarge = "c3.8xlarge"
- // @enum InstanceType
- InstanceTypeC4Large = "c4.large"
- // @enum InstanceType
- InstanceTypeC4Xlarge = "c4.xlarge"
- // @enum InstanceType
- InstanceTypeC42xlarge = "c4.2xlarge"
- // @enum InstanceType
- InstanceTypeC44xlarge = "c4.4xlarge"
- // @enum InstanceType
- InstanceTypeC48xlarge = "c4.8xlarge"
- // @enum InstanceType
- InstanceTypeCc14xlarge = "cc1.4xlarge"
- // @enum InstanceType
- InstanceTypeCc28xlarge = "cc2.8xlarge"
- // @enum InstanceType
- InstanceTypeG22xlarge = "g2.2xlarge"
- // @enum InstanceType
- InstanceTypeG28xlarge = "g2.8xlarge"
- // @enum InstanceType
- InstanceTypeCg14xlarge = "cg1.4xlarge"
- // @enum InstanceType
- InstanceTypeD2Xlarge = "d2.xlarge"
- // @enum InstanceType
- InstanceTypeD22xlarge = "d2.2xlarge"
- // @enum InstanceType
- InstanceTypeD24xlarge = "d2.4xlarge"
- // @enum InstanceType
- InstanceTypeD28xlarge = "d2.8xlarge"
- )
- const (
- // @enum ListingState
- ListingStateAvailable = "available"
- // @enum ListingState
- ListingStateSold = "sold"
- // @enum ListingState
- ListingStateCancelled = "cancelled"
- // @enum ListingState
- ListingStatePending = "pending"
- )
- const (
- // @enum ListingStatus
- ListingStatusActive = "active"
- // @enum ListingStatus
- ListingStatusPending = "pending"
- // @enum ListingStatus
- ListingStatusCancelled = "cancelled"
- // @enum ListingStatus
- ListingStatusClosed = "closed"
- )
- const (
- // @enum MonitoringState
- MonitoringStateDisabled = "disabled"
- // @enum MonitoringState
- MonitoringStateDisabling = "disabling"
- // @enum MonitoringState
- MonitoringStateEnabled = "enabled"
- // @enum MonitoringState
- MonitoringStatePending = "pending"
- )
- const (
- // @enum MoveStatus
- MoveStatusMovingToVpc = "movingToVpc"
- // @enum MoveStatus
- MoveStatusRestoringToClassic = "restoringToClassic"
- )
- const (
- // @enum NatGatewayState
- NatGatewayStatePending = "pending"
- // @enum NatGatewayState
- NatGatewayStateFailed = "failed"
- // @enum NatGatewayState
- NatGatewayStateAvailable = "available"
- // @enum NatGatewayState
- NatGatewayStateDeleting = "deleting"
- // @enum NatGatewayState
- NatGatewayStateDeleted = "deleted"
- )
- const (
- // @enum NetworkInterfaceAttribute
- NetworkInterfaceAttributeDescription = "description"
- // @enum NetworkInterfaceAttribute
- NetworkInterfaceAttributeGroupSet = "groupSet"
- // @enum NetworkInterfaceAttribute
- NetworkInterfaceAttributeSourceDestCheck = "sourceDestCheck"
- // @enum NetworkInterfaceAttribute
- NetworkInterfaceAttributeAttachment = "attachment"
- )
- const (
- // @enum NetworkInterfaceStatus
- NetworkInterfaceStatusAvailable = "available"
- // @enum NetworkInterfaceStatus
- NetworkInterfaceStatusAttaching = "attaching"
- // @enum NetworkInterfaceStatus
- NetworkInterfaceStatusInUse = "in-use"
- // @enum NetworkInterfaceStatus
- NetworkInterfaceStatusDetaching = "detaching"
- )
- const (
- // @enum NetworkInterfaceType
- NetworkInterfaceTypeInterface = "interface"
- // @enum NetworkInterfaceType
- NetworkInterfaceTypeNatGateway = "natGateway"
- )
- const (
- // @enum OfferingTypeValues
- OfferingTypeValuesHeavyUtilization = "Heavy Utilization"
- // @enum OfferingTypeValues
- OfferingTypeValuesMediumUtilization = "Medium Utilization"
- // @enum OfferingTypeValues
- OfferingTypeValuesLightUtilization = "Light Utilization"
- // @enum OfferingTypeValues
- OfferingTypeValuesNoUpfront = "No Upfront"
- // @enum OfferingTypeValues
- OfferingTypeValuesPartialUpfront = "Partial Upfront"
- // @enum OfferingTypeValues
- OfferingTypeValuesAllUpfront = "All Upfront"
- )
- const (
- // @enum OperationType
- OperationTypeAdd = "add"
- // @enum OperationType
- OperationTypeRemove = "remove"
- )
- const (
- // @enum PermissionGroup
- PermissionGroupAll = "all"
- )
- const (
- // @enum PlacementGroupState
- PlacementGroupStatePending = "pending"
- // @enum PlacementGroupState
- PlacementGroupStateAvailable = "available"
- // @enum PlacementGroupState
- PlacementGroupStateDeleting = "deleting"
- // @enum PlacementGroupState
- PlacementGroupStateDeleted = "deleted"
- )
- const (
- // @enum PlacementStrategy
- PlacementStrategyCluster = "cluster"
- )
- const (
- // @enum PlatformValues
- PlatformValuesWindows = "Windows"
- )
- const (
- // @enum ProductCodeValues
- ProductCodeValuesDevpay = "devpay"
- // @enum ProductCodeValues
- ProductCodeValuesMarketplace = "marketplace"
- )
- const (
- // @enum RIProductDescription
- RIProductDescriptionLinuxUnix = "Linux/UNIX"
- // @enum RIProductDescription
- RIProductDescriptionLinuxUnixamazonVpc = "Linux/UNIX (Amazon VPC)"
- // @enum RIProductDescription
- RIProductDescriptionWindows = "Windows"
- // @enum RIProductDescription
- RIProductDescriptionWindowsAmazonVpc = "Windows (Amazon VPC)"
- )
- const (
- // @enum RecurringChargeFrequency
- RecurringChargeFrequencyHourly = "Hourly"
- )
- const (
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesInstanceStuckInState = "instance-stuck-in-state"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesUnresponsive = "unresponsive"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesNotAcceptingCredentials = "not-accepting-credentials"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesPasswordNotAvailable = "password-not-available"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesPerformanceNetwork = "performance-network"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesPerformanceInstanceStore = "performance-instance-store"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesPerformanceEbsVolume = "performance-ebs-volume"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesPerformanceOther = "performance-other"
- // @enum ReportInstanceReasonCodes
- ReportInstanceReasonCodesOther = "other"
- )
- const (
- // @enum ReportStatusType
- ReportStatusTypeOk = "ok"
- // @enum ReportStatusType
- ReportStatusTypeImpaired = "impaired"
- )
- const (
- // @enum ReservedInstanceState
- ReservedInstanceStatePaymentPending = "payment-pending"
- // @enum ReservedInstanceState
- ReservedInstanceStateActive = "active"
- // @enum ReservedInstanceState
- ReservedInstanceStatePaymentFailed = "payment-failed"
- // @enum ReservedInstanceState
- ReservedInstanceStateRetired = "retired"
- )
- const (
- // @enum ResetImageAttributeName
- ResetImageAttributeNameLaunchPermission = "launchPermission"
- )
- const (
- // @enum ResourceType
- ResourceTypeCustomerGateway = "customer-gateway"
- // @enum ResourceType
- ResourceTypeDhcpOptions = "dhcp-options"
- // @enum ResourceType
- ResourceTypeImage = "image"
- // @enum ResourceType
- ResourceTypeInstance = "instance"
- // @enum ResourceType
- ResourceTypeInternetGateway = "internet-gateway"
- // @enum ResourceType
- ResourceTypeNetworkAcl = "network-acl"
- // @enum ResourceType
- ResourceTypeNetworkInterface = "network-interface"
- // @enum ResourceType
- ResourceTypeReservedInstances = "reserved-instances"
- // @enum ResourceType
- ResourceTypeRouteTable = "route-table"
- // @enum ResourceType
- ResourceTypeSnapshot = "snapshot"
- // @enum ResourceType
- ResourceTypeSpotInstancesRequest = "spot-instances-request"
- // @enum ResourceType
- ResourceTypeSubnet = "subnet"
- // @enum ResourceType
- ResourceTypeSecurityGroup = "security-group"
- // @enum ResourceType
- ResourceTypeVolume = "volume"
- // @enum ResourceType
- ResourceTypeVpc = "vpc"
- // @enum ResourceType
- ResourceTypeVpnConnection = "vpn-connection"
- // @enum ResourceType
- ResourceTypeVpnGateway = "vpn-gateway"
- )
- const (
- // @enum RouteOrigin
- RouteOriginCreateRouteTable = "CreateRouteTable"
- // @enum RouteOrigin
- RouteOriginCreateRoute = "CreateRoute"
- // @enum RouteOrigin
- RouteOriginEnableVgwRoutePropagation = "EnableVgwRoutePropagation"
- )
- const (
- // @enum RouteState
- RouteStateActive = "active"
- // @enum RouteState
- RouteStateBlackhole = "blackhole"
- )
- const (
- // @enum RuleAction
- RuleActionAllow = "allow"
- // @enum RuleAction
- RuleActionDeny = "deny"
- )
- const (
- // @enum ShutdownBehavior
- ShutdownBehaviorStop = "stop"
- // @enum ShutdownBehavior
- ShutdownBehaviorTerminate = "terminate"
- )
- const (
- // @enum SnapshotAttributeName
- SnapshotAttributeNameProductCodes = "productCodes"
- // @enum SnapshotAttributeName
- SnapshotAttributeNameCreateVolumePermission = "createVolumePermission"
- )
- const (
- // @enum SnapshotState
- SnapshotStatePending = "pending"
- // @enum SnapshotState
- SnapshotStateCompleted = "completed"
- // @enum SnapshotState
- SnapshotStateError = "error"
- )
- const (
- // @enum SpotInstanceState
- SpotInstanceStateOpen = "open"
- // @enum SpotInstanceState
- SpotInstanceStateActive = "active"
- // @enum SpotInstanceState
- SpotInstanceStateClosed = "closed"
- // @enum SpotInstanceState
- SpotInstanceStateCancelled = "cancelled"
- // @enum SpotInstanceState
- SpotInstanceStateFailed = "failed"
- )
- const (
- // @enum SpotInstanceType
- SpotInstanceTypeOneTime = "one-time"
- // @enum SpotInstanceType
- SpotInstanceTypePersistent = "persistent"
- )
- const (
- // @enum State
- StatePending = "Pending"
- // @enum State
- StateAvailable = "Available"
- // @enum State
- StateDeleting = "Deleting"
- // @enum State
- StateDeleted = "Deleted"
- )
- const (
- // @enum Status
- StatusMoveInProgress = "MoveInProgress"
- // @enum Status
- StatusInVpc = "InVpc"
- // @enum Status
- StatusInClassic = "InClassic"
- )
- const (
- // @enum StatusName
- StatusNameReachability = "reachability"
- )
- const (
- // @enum StatusType
- StatusTypePassed = "passed"
- // @enum StatusType
- StatusTypeFailed = "failed"
- // @enum StatusType
- StatusTypeInsufficientData = "insufficient-data"
- // @enum StatusType
- StatusTypeInitializing = "initializing"
- )
- const (
- // @enum SubnetState
- SubnetStatePending = "pending"
- // @enum SubnetState
- SubnetStateAvailable = "available"
- )
- const (
- // @enum SummaryStatus
- SummaryStatusOk = "ok"
- // @enum SummaryStatus
- SummaryStatusImpaired = "impaired"
- // @enum SummaryStatus
- SummaryStatusInsufficientData = "insufficient-data"
- // @enum SummaryStatus
- SummaryStatusNotApplicable = "not-applicable"
- // @enum SummaryStatus
- SummaryStatusInitializing = "initializing"
- )
- const (
- // @enum TelemetryStatus
- TelemetryStatusUp = "UP"
- // @enum TelemetryStatus
- TelemetryStatusDown = "DOWN"
- )
- const (
- // @enum Tenancy
- TenancyDefault = "default"
- // @enum Tenancy
- TenancyDedicated = "dedicated"
- // @enum Tenancy
- TenancyHost = "host"
- )
- const (
- // @enum TrafficType
- TrafficTypeAccept = "ACCEPT"
- // @enum TrafficType
- TrafficTypeReject = "REJECT"
- // @enum TrafficType
- TrafficTypeAll = "ALL"
- )
- const (
- // @enum VirtualizationType
- VirtualizationTypeHvm = "hvm"
- // @enum VirtualizationType
- VirtualizationTypeParavirtual = "paravirtual"
- )
- const (
- // @enum VolumeAttachmentState
- VolumeAttachmentStateAttaching = "attaching"
- // @enum VolumeAttachmentState
- VolumeAttachmentStateAttached = "attached"
- // @enum VolumeAttachmentState
- VolumeAttachmentStateDetaching = "detaching"
- // @enum VolumeAttachmentState
- VolumeAttachmentStateDetached = "detached"
- )
- const (
- // @enum VolumeAttributeName
- VolumeAttributeNameAutoEnableIo = "autoEnableIO"
- // @enum VolumeAttributeName
- VolumeAttributeNameProductCodes = "productCodes"
- )
- const (
- // @enum VolumeState
- VolumeStateCreating = "creating"
- // @enum VolumeState
- VolumeStateAvailable = "available"
- // @enum VolumeState
- VolumeStateInUse = "in-use"
- // @enum VolumeState
- VolumeStateDeleting = "deleting"
- // @enum VolumeState
- VolumeStateDeleted = "deleted"
- // @enum VolumeState
- VolumeStateError = "error"
- )
- const (
- // @enum VolumeStatusInfoStatus
- VolumeStatusInfoStatusOk = "ok"
- // @enum VolumeStatusInfoStatus
- VolumeStatusInfoStatusImpaired = "impaired"
- // @enum VolumeStatusInfoStatus
- VolumeStatusInfoStatusInsufficientData = "insufficient-data"
- )
- const (
- // @enum VolumeStatusName
- VolumeStatusNameIoEnabled = "io-enabled"
- // @enum VolumeStatusName
- VolumeStatusNameIoPerformance = "io-performance"
- )
- const (
- // @enum VolumeType
- VolumeTypeStandard = "standard"
- // @enum VolumeType
- VolumeTypeIo1 = "io1"
- // @enum VolumeType
- VolumeTypeGp2 = "gp2"
- // @enum VolumeType
- VolumeTypeSc1 = "sc1"
- // @enum VolumeType
- VolumeTypeSt1 = "st1"
- )
- const (
- // @enum VpcAttributeName
- VpcAttributeNameEnableDnsSupport = "enableDnsSupport"
- // @enum VpcAttributeName
- VpcAttributeNameEnableDnsHostnames = "enableDnsHostnames"
- )
- const (
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeInitiatingRequest = "initiating-request"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodePendingAcceptance = "pending-acceptance"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeActive = "active"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeDeleted = "deleted"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeRejected = "rejected"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeFailed = "failed"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeExpired = "expired"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeProvisioning = "provisioning"
- // @enum VpcPeeringConnectionStateReasonCode
- VpcPeeringConnectionStateReasonCodeDeleting = "deleting"
- )
- const (
- // @enum VpcState
- VpcStatePending = "pending"
- // @enum VpcState
- VpcStateAvailable = "available"
- )
- const (
- // @enum VpnState
- VpnStatePending = "pending"
- // @enum VpnState
- VpnStateAvailable = "available"
- // @enum VpnState
- VpnStateDeleting = "deleting"
- // @enum VpnState
- VpnStateDeleted = "deleted"
- )
- const (
- // @enum VpnStaticRouteSource
- VpnStaticRouteSourceStatic = "Static"
- )
|